/[cvs]/eggdrop1.4/src/eggdrop.h
ViewVC logotype

Contents of /eggdrop1.4/src/eggdrop.h

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.1.1.1 - (show annotations) (download) (as text) (vendor branch)
Wed Jun 23 19:51:28 1999 UTC (20 years, 5 months ago) by segfault
Branch: eggdev
CVS Tags: start
Changes since 1.1: +0 -0 lines
File MIME type: text/x-csrc
Eggdrop 1.3.28 CVS Code

1 /*
2 * EGGDROP compile-time settings
3 *
4 * IF YOU ALTER THIS FILE, YOU NEED TO RECOMPILE THE BOT.
5 */
6 /*
7 * This file is part of the eggdrop source code
8 * copyright (c) 1997 Robey Pointer
9 * and is distributed according to the GNU general public license.
10 * For full details, read the top of 'main.c' or the file called
11 * COPYING that was distributed with this code.
12 */
13
14 #ifndef _H_EGGDROP
15 #define _H_EGGDROP
16
17 /*
18 * if you're *only* going to link to new version bots (1.3.0 or higher)
19 * then you can safely define this
20 */
21
22 #undef NO_OLD_BOTNET
23
24 /***********************************************************************/
25 /***** the 'configure' script should make this next part automatic *****/
26 /***********************************************************************/
27
28 /*
29 * define the maximum length a handle on the bot can be.
30 * (standard is 9 characters long)
31 * (DO NOT MAKE THIS VALUE LESS THAN 9 UNLESS YOU WANT TROUBLE!)
32 * (beware that using lengths over 9 chars is 'non-standard' and if you
33 * wish to link to other bots, they _must_ both have the same maximum
34 * handle length)
35 */
36
37 #define HANDLEN 9 /* valid values 9->NICKMAX */
38
39 /* handy maximum string lengths */
40 #define NICKMAX 15 /* valid values HANDLEN->32 */
41 #define UHOSTLEN 161 /* reasonable, i think? */
42 #define DIRLEN 256 /* paranoia */
43 #define MAX_LOG_LINE (767) /* for misc.c/putlog() <cybah> */
44
45 #define NICKLEN NICKMAX + 1
46 #define NOTENAMELEN ((HANDLEN * 2) + 1)
47 /* have to use a weird way to make the compiler error out cos not all
48 * compilers support #error or error */
49 #if !HAVE_VSPRINTF
50 #include "error_you_need_vsprintf_to_compile_eggdrop"
51 #endif
52
53 #if HAVE_UNISTD_H
54 #include <unistd.h>
55 #endif
56
57 #ifndef STATIC
58 #if (!defined(MODULES_OK) || !defined(HAVE_DLOPEN)) && !defined(HPUX_HACKS)
59 #include "you_can't_compile_with_module_support_on_this_system_try_make_static"
60 #endif
61 #endif
62
63 #if !defined(STDC_HEADERS)
64 #include "you_need_to_upgrade_your_compiler_to_a_standard_c_one_mate!"
65 #endif
66
67 #if (NICKMAX < 9) || (NICKMAX > 32)
68 #include "invalid NIXMAX value"
69 #endif
70
71 #if (HANDLEN < 9) || (HANDLEN > 32)
72 #include "invalid HANDLEN value"
73 #endif
74
75 #if HANDLEN > NICKMAX
76 #include "HANDLEN MUST BE <= NICKMAX"
77 #endif
78
79 /* almost every module needs some sort of time thingy, so... */
80 #if TIME_WITH_SYS_TIME
81 #include <sys/time.h>
82 #include <time.h>
83 #else
84 #if HAVE_SYS_TIME_H
85 #include <sys/time.h>
86 #else
87 #include <time.h>
88 #endif
89 #endif
90
91 #if !HAVE_RENAME
92 #define rename movefile
93 #endif
94
95 #if !HAVE_SRANDOM
96 #define srandom(x) srand(x)
97 #endif
98
99 #if !HAVE_RANDOM
100 #define random() (rand()/16)
101 #endif
102
103 #if !HAVE_SIGACTION /* old "weird signals" */
104 #define sigaction sigvec
105 #ifndef sa_handler
106 #define sa_handler sv_handler
107 #define sa_mask sv_mask
108 #define sa_flags sv_flags
109 #endif
110 #endif
111
112 #if !HAVE_SIGEMPTYSET
113 /* and they probably won't have sigemptyset, dammit */
114 #define sigemptyset(x) ((*(int *)(x))=0)
115 #endif
116
117 /* handy aliases for memory tracking and core dumps */
118
119 #define nmalloc(x) n_malloc((x),__FILE__,__LINE__)
120 #define nrealloc(x,y) n_realloc((x),(y),__FILE__,__LINE__)
121 #define nfree(x) n_free((x),__FILE__,__LINE__)
122
123 #define context { cx_ptr=((cx_ptr + 1) & 15); \
124 strcpy(cx_file[cx_ptr],__FILE__); \
125 cx_line[cx_ptr]=__LINE__; \
126 cx_note[cx_ptr][0] = 0; }
127 /* It's usefull to track variables too <cybah> */
128 #define contextnote(string) { cx_ptr=((cx_ptr + 1) & 15); \
129 strncpy(cx_file[cx_ptr],__FILE__,29); \
130 cx_file[cx_ptr][29] = 0; \
131 cx_line[cx_ptr]=__LINE__; \
132 strncpy(cx_note[cx_ptr],string,255); \
133 cx_note[cx_ptr][255] = 0; }
134 /* move these here, makes more sense to me :) */
135 extern int cx_line[16];
136 extern char cx_file[16][30];
137 extern char cx_note[16][256];
138 extern int cx_ptr;
139
140 #undef malloc
141 #undef free
142 #define malloc(x) dont_use_old_malloc(x)
143 #define free(x) dont_use_old_free(x)
144
145 /* IP type */
146 #if SIZEOF_INT==4
147 typedef unsigned int IP;
148
149 #else
150 #if SIZEOF_LONG==4
151 typedef unsigned long IP;
152
153 #else
154 #include "cant/find/32bit/type"
155 #endif
156 #endif
157
158 /* macro for simplifying patches */
159 #define PATCH(str) { \
160 char *p=strchr(egg_version,'+'); \
161 if (p==NULL) p=&egg_version[strlen(egg_version)]; \
162 sprintf(p,"+%s",str); \
163 egg_numver++; \
164 sprintf(&egg_xtra[strlen(egg_xtra)]," %s",str); \
165 }
166
167 #define debug0(x) putlog(LOG_DEBUG,"*",x)
168 #define debug1(x,a1) putlog(LOG_DEBUG,"*",x,a1)
169 #define debug2(x,a1,a2) putlog(LOG_DEBUG,"*",x,a1,a2)
170 #define debug3(x,a1,a2,a3) putlog(LOG_DEBUG,"*",x,a1,a2,a3)
171 #define debug4(x,a1,a2,a3,a4) putlog(LOG_DEBUG,"*",x,a1,a2,a3,a4)
172
173 /***********************************************************************/
174
175 /* public structure for the listening port map */
176 struct portmap {
177 int realport;
178 int mappedto;
179 struct portmap *next;
180 };
181
182 /* public structure of all the dcc connections */
183 struct dcc_table {
184 char *name;
185 int flags;
186 void (*eof) (int);
187 void (*activity) (int, char *, int);
188 int *timeout_val;
189 void (*timeout) ();
190 void (*display) (int, char *);
191 int (*expmem) (void *);
192 void (*kill) (int, void *);
193 void (*output) (int, char *, void *);
194 };
195
196 struct userrec;
197
198 struct dcc_t {
199 long sock; /* this should be a long to keep 64-bit machines sane */
200 IP addr;
201 unsigned int port;
202 struct userrec *user;
203 char nick[NICKLEN];
204 char host[UHOSTLEN + 1]; /* extra safety char ;) */
205 struct dcc_table *type;
206 time_t timeval; /* use for any timing stuff
207 * - this is used for timeout checking */
208 unsigned long status; /* A LOT of dcc types have status thingos, this
209 * makes it more avaliabe */
210 union {
211 struct chat_info *chat;
212 struct file_info *file;
213 struct edit_info *edit;
214 struct xfer_info *xfer;
215 struct bot_info *bot;
216 struct relay_info *relay;
217 struct script_info *script;
218 int ident_sock;
219 void *other;
220 } u; /* special use depending on type */
221 };
222
223 struct chat_info {
224 char *away; /* non-NULL if user is away */
225 int msgs_per_sec; /* used to stop flooding */
226 int con_flags; /* with console: what to show */
227 int strip_flags; /* what codes to strip (b,r,u,c,a,g,*) */
228 char con_chan[81]; /* with console: what channel to view */
229 int channel; /* 0=party line, -1=off */
230 struct msgq *buffer; /* a buffer of outgoing lines (for .page cmd) */
231 int max_line; /* maximum lines at once */
232 int line_count; /* number of lines sent since last page */
233 int current_lines; /* number of lines total stored */
234 char *su_nick;
235 };
236
237 struct file_info {
238 struct chat_info *chat;
239 char dir[161];
240 };
241
242 struct xfer_info {
243 char filename[121];
244 char dir[121]; /* used when uploads go to the current dir */
245 unsigned long length;
246 unsigned long acked;
247 char buf[4]; /* you only need 5 bytes! */
248 unsigned char sofar; /* how much of the byte count received */
249 char from[NICKLEN]; /* [GET] user who offered the file */
250 FILE *f; /* pointer to file being sent/received */
251 };
252
253 struct bot_info {
254 char version[121]; /* channel/version info */
255 char linker[NOTENAMELEN + 1]; /* who requested this link */
256 int numver;
257 int port; /* base port */
258 };
259
260 struct relay_info {
261 struct chat_info *chat;
262 int sock;
263 int port;
264 int old_status;
265 };
266
267 struct script_info {
268 struct dcc_table *type;
269 union {
270 struct chat_info *chat;
271 struct file_info *file;
272 void *other;
273 } u;
274 char command[121];
275 };
276
277 /* flags about dcc types */
278 #define DCT_CHAT 0x00000001 /* this dcc type receives botnet chatter */
279 #define DCT_MASTER 0x00000002 /* received master chatter */
280 #define DCT_SHOWWHO 0x00000004 /* show the user in .who */
281 #define DCT_REMOTEWHO 0x00000008 /* show in remote who */
282 #define DCT_VALIDIDX 0x00000010 /* valid idx for outputting to in tcl */
283 #define DCT_SIMUL 0x00000020 /* can be tcl_simul'd */
284 #define DCT_CANBOOT 0x00000040 /* can be booted */
285 #define DCT_GETNOTES DCT_CHAT /* can receive notes */
286 #define DCT_FILES 0x00000080 /* gratuitous hack ;) */
287 #define DCT_FORKTYPE 0x00000100 /* a forking type */
288 #define DCT_BOT 0x00000200 /* a bot connection of some sort... */
289 #define DCT_FILETRAN 0x00000400 /* a file transfer of some sort */
290 #define DCT_FILESEND 0x00000800 /* a sending file transfer, getting = !this */
291 #define DCT_LISTEN 0x00001000 /* a listening port of some sort */
292
293 /* for dcc chat & files: */
294 #define STAT_ECHO 1 /* echo commands back? */
295 #define STAT_DENY 2 /* bad username (ignore password & deny access) */
296 /*#define STAT_XFER 4 has 'x' flag on chat line */
297 #define STAT_CHAT 8 /* in file-system but may return */
298 #define STAT_TELNET 16 /* connected via telnet */
299 #define STAT_PARTY 32 /* only on party line via 'p' flag */
300 #define STAT_BOTONLY 64 /* telnet on bots-only connect */
301 #define STAT_USRONLY 128 /* telnet on users-only connect */
302 #define STAT_PAGE 256 /* page output to the user */
303
304 /* for stripping out mIRC codes */
305 #define STRIP_COLOR 1 /* remove mIRC color codes */
306 #define STRIP_BOLD 2 /* remove bold codes */
307 #define STRIP_REV 4 /* remove reverse video codes */
308 #define STRIP_UNDER 8 /* remove underline codes */
309 #define STRIP_ANSI 16 /* remove ALL ansi codes */
310 #define STRIP_BELLS 32 /* remote ctrl-g's */
311 #define STRIP_ALL 63 /* remove every damn thing! */
312
313 /* for dcc bot links: */
314 #define STAT_PINGED 0x01 /* waiting for ping to return */
315 #define STAT_SHARE 0x02 /* sharing user data with the bot */
316 #define STAT_CALLED 0x04 /* this bot called me */
317 #define STAT_OFFERED 0x08 /* offered her the user file */
318 #define STAT_SENDING 0x10 /* in the process of sending a user list */
319 #define STAT_GETTING 0x20 /* in the process of getting a user list */
320 #define STAT_WARNED 0x40 /* warned him about unleaflike behavior */
321 #define STAT_LEAF 0x80 /* this bot is a leaf only */
322 #define STAT_LINKING 0x100 /* the bot is currently going through the
323 * linking stage */
324 #define STAT_AGGRESSIVE 0x200 /* aggressively sharing with this bot */
325
326 /* chan & global */
327 #define FLOOD_PRIVMSG 0
328 #define FLOOD_NOTICE 1
329 #define FLOOD_CTCP 2
330 #define FLOOD_NICK 3
331 #define FLOOD_JOIN 4
332 #define FLOOD_KICK 5
333 #define FLOOD_DEOP 6
334 #define FLOOD_CHAN_MAX 7
335 #define FLOOD_GLOBAL_MAX 3
336
337 /* for local console: */
338 #define STDIN 0
339 #define STDOUT 1
340 #define STDERR 2
341
342 /* structure for internal logs */
343 typedef struct {
344 char *filename;
345 unsigned int mask; /* what to send to this log */
346 char *chname; /* which channel */
347 char szLast[MAX_LOG_LINE + 1]; /* for 'Last message repeated n times'
348 * stuff in misc.c/putlog() <cybah> */
349 int Repeats; /* number of times szLast has been repeated */
350 FILE *f; /* existing file */
351 } log_t;
352
353 /* logfile display flags */
354 #define LOG_MSGS 0x000001 /* m msgs/notice/ctcps */
355 #define LOG_PUBLIC 0x000002 /* p public msg/notice/ctcps */
356 #define LOG_JOIN 0x000004 /* j channel joins/parts/etc */
357 #define LOG_MODES 0x000008 /* k mode changes/kicks/bans */
358 #define LOG_CMDS 0x000010 /* c user dcc or msg commands */
359 #define LOG_MISC 0x000020 /* o other misc bot things */
360 #define LOG_BOTS 0x000040 /* b bot notices */
361 #define LOG_RAW 0x000080 /* r raw server stuff coming in */
362 #define LOG_FILES 0x000100 /* x file transfer commands and stats */
363 #define LOG_LEV1 0x000200 /* 1 user log level */
364 #define LOG_LEV2 0x000400 /* 2 user log level */
365 #define LOG_LEV3 0x000800 /* 3 user log level */
366 #define LOG_LEV4 0x001000 /* 4 user log level */
367 #define LOG_LEV5 0x002000 /* 5 user log level */
368 #define LOG_LEV6 0x004000 /* 6 user log level */
369 #define LOG_LEV7 0x008000 /* 7 user log level */
370 #define LOG_LEV8 0x010000 /* 8 user log level */
371 #define LOG_SERV 0x020000 /* s server information */
372 #define LOG_DEBUG 0x040000 /* d debug */
373 #define LOG_WALL 0x080000 /* w wallops */
374 #define LOG_SRVOUT 0x100000 /* v server output */
375 #define LOG_BOTNET 0x200000 /* t botnet traffic */
376 #define LOG_BOTSHARE 0x400000 /* h share traffic */
377 #define LOG_ALL 0x7fffff /* (dump to all logfiles) */
378
379 #define FILEDB_HIDE 1
380 #define FILEDB_UNHIDE 2
381 #define FILEDB_SHARE 3
382 #define FILEDB_UNSHARE 4
383
384 /* socket flags: */
385 #define SOCK_UNUSED 0x01 /* empty socket */
386 #define SOCK_BINARY 0x02 /* do not buffer input */
387 #define SOCK_LISTEN 0x04 /* listening port */
388 #define SOCK_CONNECT 0x08 /* connection attempt */
389 #define SOCK_NONSOCK 0x10 /* used for file i/o on debug */
390 #define SOCK_STRONGCONN 0x20 /* don't report success until sure */
391 #define SOCK_EOFD 0x40 /* it EOF'd recently during a write */
392
393 /* fake idx's for dprintf - these should be ridiculously large +ve nums */
394 #define DP_STDOUT 0x7FF1
395 #define DP_LOG 0x7FF2
396 #define DP_SERVER 0x7FF3
397 #define DP_HELP 0x7FF4
398 #define DP_STDERR 0x7FF5
399 #define DP_MODE 0x7FF6
400
401 #define NORMAL 0
402 #define QUICK 1
403
404 /* return codes for add_note */
405 #define NOTE_ERROR 0 /* error */
406 #define NOTE_OK 1 /* success */
407 #define NOTE_STORED 2 /* not online; stored */
408 #define NOTE_FULL 3 /* too many notes stored */
409 #define NOTE_TCL 4 /* tcl binding caught it */
410 #define NOTE_AWAY 5 /* away; stored */
411 #define NOTE_FWD 6 /* away; forwarded */
412
413 #define STR_PROTECT 2
414 #define STR_DIR 1
415
416 #define HELP_DCC 1
417 #define HELP_TEXT 2
418 #define HELP_IRC 16
419
420 /* it's used in so many places, let's put it here */
421 typedef int (*Function) ();
422
423 /* this is used by the net module to keep track of sockets and what's
424 * queued on them */
425 typedef struct {
426 int sock;
427 char flags;
428 char *inbuf;
429 char *outbuf;
430 unsigned long outbuflen; /* outbuf could be binary data */
431 } sock_list;
432
433 #endif

webmaster@eggheads.org
ViewVC Help
Powered by ViewVC 1.1.23