dfd6eef2352ab20b3bbeca0d7cc221ec499ae725
[NeonServV5.git] / cmd_neonserv_opall.c
1
2 /*
3 * argv[0]    "force"
4 * argv[1]    (optional) nick mask
5 */
6 static USERLIST_CALLBACK(neonserv_cmd_opall_userlist_lookup);
7 static void neonserv_cmd_opall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char *nickmask);
8
9 struct neonserv_cmd_opall_cache {
10     struct ClientSocket *client, *textclient;
11     struct UserNode *user;
12     struct Event *event;
13     char *nickmask;
14 };
15
16 static CMD_BIND(neonserv_cmd_opall) {
17     if(!argc || strcmp(argv[0], "FORCE")) {
18         reply(getTextBot(), user, "NS_OPALL_SECURITY", chan->name);
19         return;
20     }
21     struct neonserv_cmd_opall_cache *cache = malloc(sizeof(*cache));
22     if (!cache) {
23         perror("malloc() failed");
24         return;
25     }
26     cache->client = client;
27     cache->textclient = getTextBot();
28     cache->user = user;
29     cache->event = event;
30     if(argc > 1) {
31         cache->nickmask = strdup(argv[1]);
32     } else
33         cache->nickmask = NULL;
34     get_userlist_with_invisible(chan, neonserv_cmd_opall_userlist_lookup, cache);
35 }
36
37 static USERLIST_CALLBACK(neonserv_cmd_opall_userlist_lookup) {
38     struct neonserv_cmd_opall_cache *cache = data;
39     neonserv_cmd_opall_async1(cache->client, cache->textclient, cache->user, chan, cache->event, cache->nickmask);
40     if(cache->nickmask)
41         free(cache->nickmask);
42     free(cache);
43 }
44
45 static void neonserv_cmd_opall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char *nickmask) {
46     int done_users = 0;
47     struct ChanUser *chanuser;
48     struct ModeBuffer *modeBuf;
49     modeBuf = initModeBuffer(client, chan);
50     for(chanuser = getChannelUsers(chan, NULL); chanuser; chanuser = getChannelUsers(chan, chanuser)) {
51         if(nickmask && match(nickmask, chanuser->user->nick)) continue;
52         if(chanuser->flags & CHANUSERFLAG_OPPED) continue;
53         modeBufferOp(modeBuf, chanuser->user->nick);
54         done_users++;
55     }
56     freeModeBuffer(modeBuf);
57     reply(textclient, user, "NS_OPALL_DONE", done_users, chan->name);
58     if(done_users)
59         logEvent(event);
60 }