4 * argv[1] (optional) nick mask
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, char *nickmask);
9 struct neonserv_cmd_opall_cache {
10 struct ClientSocket *client, *textclient;
11 struct UserNode *user;
15 static CMD_BIND(neonserv_cmd_opall) {
16 if(!argc || strcmp(argv[0], "FORCE")) {
17 reply(getTextBot(), user, "NS_OPALL_SECURITY", chan->name);
20 struct neonserv_cmd_opall_cache *cache = malloc(sizeof(*cache));
22 perror("malloc() failed");
25 cache->client = client;
26 cache->textclient = getTextBot();
29 cache->nickmask = strdup(argv[1]);
31 cache->nickmask = NULL;
32 get_userlist_with_invisible(chan, neonserv_cmd_opall_userlist_lookup, cache);
35 static USERLIST_CALLBACK(neonserv_cmd_opall_userlist_lookup) {
36 struct neonserv_cmd_opall_cache *cache = data;
37 neonserv_cmd_opall_async1(cache->client, cache->textclient, cache->user, chan, cache->nickmask);
39 free(cache->nickmask);
43 static void neonserv_cmd_opall_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, char *nickmask) {
45 struct ChanUser *chanuser;
46 struct ModeBuffer *modeBuf;
47 modeBuf = initModeBuffer(client, chan);
48 for(chanuser = getChannelUsers(chan, NULL); chanuser; chanuser = getChannelUsers(chan, chanuser)) {
49 if(nickmask && match(nickmask, chanuser->user->nick)) continue;
50 if(chanuser->flags & CHANUSERFLAG_OPPED) continue;
51 modeBufferOp(modeBuf, chanuser->user->nick);
54 freeModeBuffer(modeBuf);
55 reply(textclient, user, "NS_OPALL_DONE", done_users, chan->name);