]>
Commit | Line | Data |
---|---|---|
c86edd1d Q |
1 | |
2 | #ifndef __CONTROL_H | |
3 | #define __CONTROL_H | |
4 | ||
5 | #include "../parser/parser.h" | |
6 | #include "../nick/nick.h" | |
7 | #include "../channel/channel.h" | |
8 | ||
38cee035 CP |
9 | #define registercontrolcmd(a, b, c, d) registercontrolhelpcmd(a, b, c, d, NULL) |
10 | ||
11 | typedef void (*ControlMsg)(nick *, char *, ... ); | |
12 | typedef void (*ControlWall)(flag_t, flag_t, char *, ...); | |
6ebc9d2f | 13 | typedef int (*ControlPermitted)(flag_t, nick *); |
38cee035 CP |
14 | |
15 | extern ControlMsg controlreply; | |
16 | extern ControlWall controlwall; | |
6ebc9d2f | 17 | extern ControlPermitted controlpermitted; |
38cee035 CP |
18 | |
19 | extern nick *mynick; | |
20 | ||
21 | extern CommandTree *controlcmds; | |
22 | ||
23 | struct specialsched { | |
24 | sstring *modulename; | |
25 | void *schedule; | |
1085be4b | 26 | }; |
38cee035 | 27 | |
6ebc9d2f P |
28 | typedef void (*CommandHelp)(nick *, Command *); |
29 | typedef struct cmdhelp { | |
30 | char *helpstr; | |
31 | CommandHelp helpcmd; | |
32 | } cmdhelp; | |
33 | ||
34 | void registercontrolhelpcmd(const char *name, int level, int maxparams, CommandHandler handler, char *help); | |
35 | void registercontrolhelpfunccmd(const char *name, int level, int maxparams, CommandHandler handler, CommandHelp helpcmd); | |
36 | int deregistercontrolcmd(const char *name, CommandHandler handler); | |
5a0247f1 P |
37 | void controlmessage(nick *target, char *message, ... ) __attribute__ ((format (printf, 2, 3))); |
38 | void controlchanmsg(channel *cp, char *message, ...) __attribute__ ((format (printf, 2, 3))); | |
39 | void controlnotice(nick *target, char *message, ...) __attribute__ ((format (printf, 2, 3))); | |
6ebc9d2f P |
40 | int controlshowcommands(void *sender, int cargc, char **cargv); |
41 | int controlrmmod(void *sender, int cargc, char **cargv); | |
42 | void controlspecialrmmod(void *arg); | |
43 | void controlspecialreloadmod(void *arg); | |
44 | void controlhelp(nick *np, Command *cmd); | |
5a0247f1 | 45 | void controlnswall(int noticelevel, char *format, ...) __attribute__ ((format (printf, 2, 3))); |
c6b287fd | 46 | char *controlid(nick *); |
6ebc9d2f | 47 | |
38cee035 CP |
48 | /* NEVER USE THE FOLLOWING IN COMMANDS, you'll end up missing bits off and users'll end up being able to gline people */ |
49 | #define __NO_ANYONE 0x000 | |
50 | #define __NO_AUTHED 0x001 /* must be authed with the network, don't know what use this is really */ | |
51 | #define __NO_OPERED 0x002 /* just means that they MUST be /oper'ed, for hello -- part of LEGACY */ | |
52 | #define __NO_ACCOUNT 0x004 /* for hello, must have a user account */ | |
53 | #define __NO_LEGACY 0x008 /* reserved for old newserv commands, their level is 10 */ | |
54 | #define __NO_STAFF 0x010 /* +s */ | |
55 | #define __NO_TRUST 0x020 /* +t */ | |
56 | #define __NO_OPER 0x040 /* +O */ | |
57 | #define __NO_SEC 0x080 /* +w */ | |
58 | #define __NO_DEVELOPER 0x100 /* +d */ | |
3f5ead93 | 59 | #define __NO_RELAY 0x200 /* +Y */ |
38cee035 CP |
60 | |
61 | /* These are dangerous, they don't include requiring /OPER or STAFF status, be careful */ | |
62 | #define NOD_ACCOUNT __NO_ACCOUNT | NO_AUTHED /* must contain authed else account won't be checked */ | |
63 | #define NOD_STAFF __NO_STAFF | NOD_ACCOUNT | |
64 | #define NOD_TRUST __NO_TRUST | NOD_ACCOUNT | |
65 | #define NOD_OPER __NO_OPER | NOD_ACCOUNT | |
66 | #define NOD_SEC __NO_SEC | NOD_ACCOUNT | |
67 | #define NOD_DEVELOPER __NO_DEVELOPER | NOD_ACCOUNT | |
3f5ead93 | 68 | #define NOD_RELAY __NO_RELAY | NOD_ACCOUNT |
38cee035 CP |
69 | |
70 | /* These ones are safe to use */ | |
71 | #define NO_ANYONE __NO_ANYONE /* don't have to be authed to Q, or us, or opered or anything */ | |
72 | #define NO_AUTHED __NO_AUTHED /* must be authed to Q */ | |
73 | #define NO_ACCOUNT NOD_ACCOUNT /* must have an account on the bot */ | |
74 | #define NO_OPERED __NO_OPERED /* must be /opered */ | |
75 | #define NO_STAFF NOD_STAFF /* must be authed to Q and have staff level on bot */ | |
76 | #define NO_OPER NO_OPERED | NOD_OPER /* must be authed to Q, /opered, and have oper level on bot */ | |
77 | #define NO_DEVELOPER NO_OPERED | NOD_DEVELOPER /* must be authed to Q, /opered, and have dev level on bot */ | |
78 | #define NO_TRUST_STAFF NO_STAFF | NOD_TRUST /* must be authed to Q, and have staff and trust level on bot */ | |
79 | #define NO_TRUST_OPER NO_OPER | NOD_TRUST /* must be authed to Q, /opered, and have trust and oper levels on bot */ | |
80 | #define NO_SEC_STAFF NO_STAFF | NOD_SEC /* must be authed to Q, and have staff and sec level on bot */ | |
81 | #define NO_SEC_OPER NO_OPER | NOD_SEC /* must be authed to Q, /opered, and have sec and oper levels on bot */ | |
3f5ead93 | 82 | #define NO_RELAY NO_OPERED | NOD_RELAY /* must be authed to Q, /opered, and have the relay level on bot */ |
38cee035 | 83 | |
3f5ead93 | 84 | #define NO_ALL_FLAGS __NO_STAFF | __NO_TRUST | __NO_OPER | __NO_SEC | __NO_DEVELOPER | __NO_RELAY |
38cee035 CP |
85 | #define NO_OPER_FLAGS __NO_STAFF |
86 | #define NO_DEV_FLAGS NO_ALL_FLAGS | |
87 | ||
88 | #define NL_MANAGEMENT 0x0001 /* hello, password, userflags, noticeflags */ | |
89 | #define NL_TRUSTS 0x0002 /* trust stuff... */ | |
e609eb1f CP |
90 | #define NL_KICKKILLS 0x0004 /* KICK/KILL command */ |
91 | #define NL_MISC 0x0008 /* misc commands (resync, etc) */ | |
38cee035 CP |
92 | #define NL_GLINES 0x0010 /* GLINE commands */ |
93 | #define NL_HITS 0x0020 /* Where a gline or kill is set automatically by the bot */ | |
94 | #define NL_CLONING 0x0040 /* Clone detection */ | |
95 | #define NL_CLEARCHAN 0x0080 /* When someone clearchans */ | |
96 | #define NL_FAKEUSERS 0x0100 /* Fakeuser addition */ | |
97 | #define NL_BROADCASTS 0x0200 /* Broadcast/mbroadcast/sbroadcast */ | |
98 | #define NL_OPERATIONS 0x0400 /* insmod/rmmod/etc */ | |
99 | #define NL_OPERING 0x0800 /* when someone opers */ | |
100 | #define NL_NOTICES 0x1000 /* turn off to receive privmsgs instead of notices */ | |
101 | #define NL_ALL_COMMANDS 0x2000 /* every single command sent */ | |
c86edd1d Q |
102 | |
103 | #endif |