2 * pop2.c -- POP2 protocol methods
4 * Copyright 1997 by Eric S. Raymond
5 * For license terms, see the file COPYING in this directory.
12 #if defined(STDC_HEADERS)
15 #include "fetchmail.h"
18 static int pound_arg, equal_arg;
20 static int pop2_ok (int sock, char *argbuf)
21 /* parse POP2 command response */
24 char buf [POPBUFSIZE+1];
26 pound_arg = equal_arg = -1;
28 if ((ok = gen_recv(sock, buf, sizeof(buf))) == 0)
32 else if (buf[0] == '#')
34 pound_arg = atoi(buf+1);
37 else if (buf[0] == '=')
39 equal_arg = atoi(buf+1);
42 else if (buf[0] == '-')
54 static int pop2_getauth(int sock, struct query *ctl, char *buf)
55 /* apply for connection authorization */
59 strcpy(shroud, ctl->password);
60 status = gen_transact(sock,
62 ctl->remotename, ctl->password);
66 static int pop2_getrange(int sock, struct query *ctl, const char *folder,
67 int *countp, int *newp, int *bytes)
68 /* get range of messages to be fetched */
70 /* maybe the user wanted a non-default folder */
73 int ok = gen_transact(sock, "FOLD %s", folder);
82 * We should have picked up a count of messages in the user's
83 * default inbox from the pop2_getauth() response.
85 * Note: this logic only works because there is no way to select
86 * both the unnamed folder and named folders within a single
87 * fetchmail run. If that assumption ever becomes invalid, the
88 * pop2_getauth code will have to stash the pound response away
89 * explicitly in case it gets stepped on.
100 static int pop2_fetch(int sock, struct query *ctl, int number, int *lenp)
101 /* request nth message */
106 ok = gen_transact(sock, "READ %d", number);
111 gen_send(sock, "RETR");
116 static int pop2_trail(int sock, struct query *ctl, int number)
117 /* send acknowledgement for message data */
119 return(gen_transact(sock, ctl->keep ? "ACKS" : "ACKD"));
122 static int pop2_logout(int sock, struct query *ctl)
123 /* send logout command */
125 return(gen_transact(sock, "QUIT"));
128 const static struct method pop2 =
130 "POP2", /* Post Office Protocol v2 */
132 "pop2", /* standard POP2 port */
133 "pop2", /* ssl POP2 port */
134 #else /* INET6_ENABLE */
135 109, /* standard POP2 port */
136 109, /* ssl POP2 port - not */
137 #endif /* INET6_ENABLE */
138 FALSE, /* this is not a tagged protocol */
139 FALSE, /* does not use message delimiter */
140 pop2_ok, /* parse command response */
141 pop2_getauth, /* get authorization */
142 pop2_getrange, /* query range of messages */
143 NULL, /* no way to get sizes */
144 NULL, /* messages are always new */
145 pop2_fetch, /* request given message */
146 NULL, /* no way to fetch body alone */
147 pop2_trail, /* eat message trailer */
148 NULL, /* no POP2 delete method */
149 pop2_logout, /* log out, we're done */
150 FALSE, /* no, we can't re-poll */
153 int doPOP2 (struct query *ctl)
154 /* retrieve messages using POP2 */
156 peek_capable = FALSE;
157 return(do_protocol(ctl, &pop2));
159 #endif /* POP2_ENABLE */
161 /* pop2.c ends here */