]>
jfr.im git - irc/quakenet/newserv.git/blob - splitlist/splitlist_commands.c
1 /* oper commands for the splitlist */
7 #include "../lib/irc_string.h"
8 #include "../irc/irc.h"
9 #include "../irc/irc_config.h"
10 #include "../splitlist/splitlist.h"
11 #include "../serverlist/serverlist.h"
12 #include "../control/control.h"
13 #include "../lib/version.h"
14 #include "../lib/flags.h"
18 int spcmd_splitlist(void *source
, int cargc
, char **cargv
);
19 int spcmd_splitdel(void *source
, int cargc
, char **cargv
);
20 int spcmd_splitadd(void *source
, int cargc
, char **cargv
);
23 registercontrolhelpcmd("splitlist", NO_STAFF
, 0, &spcmd_splitlist
, "Usage: splitlist\nLists servers currently split from the network.");
24 registercontrolcmd("splitdel", 10, 1, &spcmd_splitdel
);
25 registercontrolhelpcmd("splitadd", 10, 3, &spcmd_splitadd
,
26 "Usage: splitadd <servername> [+flags] [split time as unix timestamp]\n"
27 " Adds a server as split from the network.\n"
29 " +c: Client server\n"
34 " +X: Other critical service\n"
35 " If no flags are given, an attempt to figure them out based on name\n"
36 " will be made, but it's likely not a good one.");
40 deregistercontrolcmd("splitlist", &spcmd_splitlist
);
41 deregistercontrolcmd("splitdel", &spcmd_splitdel
);
42 deregistercontrolcmd("splitadd", &spcmd_splitadd
);
45 /* todo: add RELINK status */
46 int spcmd_splitlist(void *source
, int cargc
, char **cargv
) {
47 nick
*np
= (nick
*)source
;
51 if (splitlist
.cursi
== 0) {
52 controlreply(np
, "There currently aren't any registered splits.");
57 controlreply(np
, "Server Status Split for");
59 for (i
= 0; i
< splitlist
.cursi
; i
++) {
60 srv
= ((splitserver
*)splitlist
.content
)[i
];
62 controlreply(np
, "%s M.I.A. %s (%s)", srv
.name
->content
, longtoduration(getnettime() - srv
.ts
, 1), printflags(srv
.type
, servertypeflags
));
65 controlreply(np
, "--- End of splitlist");
70 int spcmd_splitdel(void *source
, int cargc
, char **cargv
) {
71 nick
*np
= (nick
*)source
;
76 controlreply(np
, "Syntax: splitdel <pattern>");
83 for (i
= splitlist
.cursi
- 1; i
>= 0; i
--) {
84 srv
= ((splitserver
*)splitlist
.content
)[i
];
86 if (match2strings(cargv
[0], srv
.name
->content
)) {
87 sp_deletesplit(srv
.name
->content
); /* inefficient .. but it doesn't matter */
93 controlwall(NO_OPERED
, NL_MISC
, "%s/%s used SPLITDEL on %s", np
->nick
, np
->authname
, cargv
[0]);
94 controlreply(np
, "%d %s deleted.", count
, count
!= 1 ? "splits" : "split");
99 static int doessplitalreadyexist(const char *servername
) {
103 for (i
= 0; i
< splitlist
.cursi
; i
++) {
104 srv
= ((splitserver
*)splitlist
.content
)[i
];
106 if (!strcasecmp(srv
.name
->content
, servername
))
113 int spcmd_splitadd(void *source
, int cargc
, char **cargv
) {
114 nick
*np
= (nick
*)source
;
115 unsigned long long num
;
117 flag_t servertype
= 0;
119 size_t servernamelen
;
124 controlreply(np
, "Usage: splitadd <servername> [+flags] [split time as unix timestamp]");
128 servername
= cargv
[0];
129 servernamelen
= strlen(servername
);
131 if (findserver(servername
) != -1) {
132 controlreply(np
, "Server %s is linked right now, refusing to add split.",
137 if (doessplitalreadyexist(servername
)) {
138 controlreply(np
, "There is a split for %s already.", servername
);
142 if (servernamelen
> SERVERLEN
) {
143 controlreply(np
, "Server name %s is too long (max: %d characters)",
144 servername
, SERVERLEN
);
150 if (setflags(&servertype
, (flag_t
)-1, cargv
[1], servertypeflags
,
151 REJECT_UNKNOWN
) != REJECT_NONE
) {
152 controlreply(np
, "Flag string %s contained invalid flags.", cargv
[1]);
156 /* Set up a fake server for getservertype. */
157 memset(&fake
, 0, sizeof(fake
));
159 fake
.name
= getsstring(servername
, servernamelen
);
160 servertype
= getservertype(&fake
);
161 freesstring(fake
.name
);
164 /* Handle timestamp */
166 splittime
= getnettime();
169 num
= strtoull(cargv
[2], &end
, 10);
170 if (errno
== ERANGE
) {
171 controlreply(np
, "%s is out of range for a timestamp.", cargv
[2]);
175 /* Truncation may happen here.
176 * However, there's no way to get the max time_t value, so we'll just try to
177 * find out after the fact.
179 splittime
= (time_t)num
;
181 if ((unsigned long long)splittime
< num
) {
182 controlreply(np
, "Tried to use %llu as split time value, but it's too "
183 "large for the system to handle", num
);
188 sp_addsplit(servername
, splittime
, servertype
);
189 controlreply(np
, "Added split for %s (%s ago) with flags %s.",
190 servername
, longtoduration(getnettime() - splittime
, 1),
191 printflags(servertype
, servertypeflags
));