3 * argv[0] (optional) nick mask
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);
8 struct neonserv_cmd_deopall_cache {
9 struct ClientSocket *client, *textclient;
10 struct UserNode *user;
16 static CMD_BIND(neonserv_cmd_deopall) {
17 struct neonserv_cmd_deopall_cache *cache = malloc(sizeof(*cache));
19 perror("malloc() failed");
22 cache->client = client;
23 cache->textclient = getTextBot();
26 cache->argv = calloc(argc, sizeof(char*));
28 for(i = 0; i < argc; i++) {
29 cache->argv[i] = strdup(argv[i]);
32 get_userlist(chan, neonserv_cmd_deopall_userlist_lookup, cache);
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);
39 for(i = 0; i < cache->argc; i++) {
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;
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);
62 freeModeBuffer(modeBuf);
63 reply(getTextBot(), user, "NS_DEOPALL_DONE", done_users, chan->name);