1 /* Copyright 1993-95 by Carl Harris, Jr. Copyright 1996 by Eric S. Raymond
3 * For license terms, see the file COPYING in this directory.
6 /***********************************************************************
9 programmer: Carl Harris, ceharris@mal.com
10 description: global constant, type, and variable definitions.
12 ***********************************************************************/
14 /* constants designating the various supported protocols */
22 /* definitions for buffer sizes -- somewhat arbitrary */
23 #define POPBUFSIZE 512 /* per RFC 937 */
24 #define MSGBUFSIZE 2048 /* size of message read buffer */
25 #define HOSTLEN 128 /* max hostname length */
26 #define USERNAMELEN 32 /* max user-length */
27 #define PASSWORDLEN MAX_PASSWORD_LENGTH
28 #define FOLDERLEN 256 /* max folder name length */
29 #define DIGESTLEN 33 /* length of MD5 digest */
30 #define IDLEN 128 /* length of UIDL message ID */
32 /* exit code values */
33 #define PS_SUCCESS 0 /* successful receipt of messages */
34 #define PS_NOMAIL 1 /* no mail available */
35 #define PS_SOCKET 2 /* socket I/O woes */
36 #define PS_AUTHFAIL 3 /* user authorization failed */
37 #define PS_PROTOCOL 4 /* protocol violation */
38 #define PS_SYNTAX 5 /* command-line syntax error */
39 #define PS_IOERR 6 /* bad permissions on rc file */
40 #define PS_ERROR 7 /* protocol error */
41 #define PS_EXCLUDE 8 /* exclusion error */
42 #define PS_SMTP 9 /* SMTP error */
43 #define PS_UNDEFINED 10 /* something I hadn't thought of */
45 /* output noise level */
46 #define O_SILENT 0 /* mute, max squelch, etc. */
47 #define O_NORMAL 1 /* user-friendly */
48 #define O_VERBOSE 2 /* excessive */
50 #define SIZETICKER 1024 /* print 1 dot per this many bytes */
55 char servername [HOSTLEN+1];
56 char localname [USERNAMELEN+1];
57 char remotename [USERNAMELEN+1];
58 char password [PASSWORDLEN+1];
59 char remotefolder [FOLDERLEN];
60 char smtphost[HOSTLEN+1];
72 struct hostrec *next; /* next host in chain */
73 char digest [DIGESTLEN];
78 char *name; /* protocol name */
79 int port; /* service port */
80 int tagged; /* if true, generate & expect command tags */
81 int delimited; /* if true, accept "." message delimiter */
82 int (*parse_response)(); /* response_parsing function */
83 int (*getauth)(); /* authorization fetcher */
84 int (*getrange)(); /* get message range to fetch */
85 int (*is_old)(); /* check for old message */
86 int (*fetch)(); /* fetch a given message */
87 int (*trail)(); /* eat trailer of a message */
88 int (*delete)(); /* delete method */
89 char *expunge_cmd; /* expunge command */
90 char *exit_cmd; /* exit command */
94 extern char tag[TAGLEN];
96 /* controls the detail level of status/progress messages written to stderr */
97 extern int outlevel; /* see the O_.* constants above */
98 extern int yydebug; /* enable parse debugging */
100 /* daemon mode control */
101 extern int poll_interval; /* poll interval in seconds */
102 extern char *logfile; /* log file for daemon mode */
103 extern int quitmode; /* if --quit was set */
105 /* miscellaneous global controls */
106 extern char *rcfile; /* path name of rc file */
107 extern int linelimit; /* limit # lines retrieved per site */
108 extern int versioninfo; /* emit only version info */
110 #ifdef HAVE_PROTOTYPES
112 /* prototypes for globally callable functions */
116 int doPOP2 (struct hostrec *);
117 int doPOP3 (struct hostrec *);
118 int doIMAP (struct hostrec *);
120 int parsecmdline (int, char **, struct hostrec *);
121 int setdefaults (struct hostrec *);
122 char *getnextserver (int argc, char **, int *);
123 char *MD5Digest (char *);
124 void append_server_names(int *, char **, int);
125 int daemonize(const char *, void (*)(int));
129 char *getnextserver();
131 void append_server_names ();