7f04595d59efbea1ae3f38f638a7a10ba0688878
[NeonServV5.git] / cmd_neonserv_deopall.c
1
2 /*
3 * argv[0]    (optional) nick mask
4 */
5 static USERLIST_CALLBACK(neonserv_cmd_deopall_userlist_lookup);
6 static void neonserv_cmd_deopall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char **argv, int argc);
7
8 struct neonserv_cmd_deopall_cache {
9     struct ClientSocket *client, *textclient;
10     struct UserNode *user;
11     struct Event *event;
12     char **argv;
13     int argc;
14 };
15
16 static CMD_BIND(neonserv_cmd_deopall) {
17     struct neonserv_cmd_deopall_cache *cache = malloc(sizeof(*cache));
18     if (!cache) {
19         perror("malloc() failed");
20         return;
21     }
22     cache->client = client;
23     cache->textclient = getTextBot();
24     cache->user = user;
25     cache->event = event;
26     cache->argv = calloc(argc, sizeof(char*));
27     int i;
28     for(i = 0; i < argc; i++) {
29         cache->argv[i] = strdup(argv[i]);
30     }
31     cache->argc = argc;
32     get_userlist(chan, neonserv_cmd_deopall_userlist_lookup, cache);
33 }
34
35 static USERLIST_CALLBACK(neonserv_cmd_deopall_userlist_lookup) {
36     struct neonserv_cmd_deopall_cache *cache = data;
37     neonserv_cmd_deopall_async1(cache->client, cache->textclient, cache->user, chan, cache->event, cache->argv, cache->argc);
38     int i;
39     for(i = 0; i < cache->argc; i++) {
40         free(cache->argv[i]);
41     }
42     free(cache);
43 }
44
45 static void neonserv_cmd_deopall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char **argv, int argc) {
46     int issuer_access, victim_access, done_users = 0;
47     char *nickmask = NULL;
48     struct ChanUser *chanuser;
49     struct ModeBuffer *modeBuf;
50     if(argc > 0)
51         nickmask = argv[0];
52     modeBuf = initModeBuffer(client, chan);
53     issuer_access = getChannelAccess(user, chan, 0);
54     for(chanuser = getChannelUsers(chan, NULL); chanuser; chanuser = getChannelUsers(chan, chanuser)) {
55         if(nickmask && match(nickmask, chanuser->user->nick)) continue;
56         victim_access = getChannelAccess(user, chan, 0);
57         if(victim_access >= issuer_access) continue;
58         if(!(chanuser->flags & CHANUSERFLAG_OPPED)) continue;
59         modeBufferDeop(modeBuf, chanuser->user->nick);
60         done_users++;
61     }
62     freeModeBuffer(modeBuf);
63     reply(getTextBot(), user, "NS_DEOPALL_DONE", done_users, chan->name);
64     if(done_users)
65         logEvent(event);
66 }