]> jfr.im git - irc/quakenet/newserv.git/blob - control/control.h
CHANSERV: lastactive is now only updated for +o and above joins (changes how often...
[irc/quakenet/newserv.git] / control / control.h
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
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 *, ...);
13 typedef int (*ControlPermitted)(flag_t, nick *);
14
15 extern ControlMsg controlreply;
16 extern ControlWall controlwall;
17 extern ControlPermitted controlpermitted;
18
19 extern nick *mynick;
20
21 extern CommandTree *controlcmds;
22
23 struct specialsched {
24 sstring *modulename;
25 void *schedule;
26 };
27
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);
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)));
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);
45 void controlnswall(int noticelevel, char *format, ...) __attribute__ ((format (printf, 2, 3)));
46 char *controlid(nick *);
47
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 */
59 #define __NO_RELAY 0x200 /* +Y */
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
68 #define NOD_RELAY __NO_RELAY | NOD_ACCOUNT
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 */
82 #define NO_RELAY NO_OPERED | NOD_RELAY /* must be authed to Q, /opered, and have the relay level on bot */
83
84 #define NO_ALL_FLAGS __NO_STAFF | __NO_TRUST | __NO_OPER | __NO_SEC | __NO_DEVELOPER | __NO_RELAY
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... */
90 #define NL_KICKKILLS 0x0004 /* KICK/KILL command */
91 #define NL_MISC 0x0008 /* misc commands (resync, etc) */
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 */
102
103 #endif