NeonHelp: reinvite active requests when resetting the invite list
authorpk910 <philipp@zoelle1.de>
Fri, 3 Aug 2012 08:18:26 +0000 (10:18 +0200)
committerpk910 <philipp@zoelle1.de>
Fri, 3 Aug 2012 08:18:26 +0000 (10:18 +0200)
src/modules/NeonHelp.mod/bot_NeonHelp.c
src/modules/NeonHelp.mod/bot_NeonHelp.h
src/modules/NeonHelp.mod/cmd_neonhelp_delete.c

index 1b7fefa9a3a41edcf96a483232f2fbe26f11eff6..9e3ba72dc3077236b7ab7ef901deee20935cdc99 100644 (file)
@@ -421,6 +421,17 @@ void neonhelp_destroy_support_request(struct ClientSocket *client, struct NeonHe
     free(helpnode);
 }
 
+void neonhelp_invite_active_requests(struct ClientSocket *client, struct ChanNode *support, struct ChanNode *public, struct UserNode *ignore_user) {
+    struct NeonHelpNode *helpnode;
+    if(public && client->flags & SOCKET_HAVE_HELPNODE) {
+        for(helpnode = client->botclass_helpnode; helpnode; helpnode = helpnode->next) {
+            if(helpnode->status == 1 && helpnode->user != ignore_user && !isUserOnChan(helpnode->user, support)) {
+                putsock(client, "INVITE %s %s", helpnode->user->nick, support->name);
+            }
+        }
+    }
+}
+
 static void neonhelp_event_kick(struct UserNode *user, struct ChanUser *target, char *reason) {
     struct ClientSocket *client;
     MYSQL_RES *res;
@@ -451,6 +462,7 @@ static void neonhelp_event_kick(struct UserNode *user, struct ChanUser *target,
                     putsock(client, "MODE %s -i", support->name); //clear invite list
                     if(isModeSet(support->modes, 'i'))
                         putsock(client, "MODE %s +i", support->name);
+                    neonhelp_invite_active_requests(client, support, public, target->user);
                 }
                 //free the user's support request
                 if(prev_helpnode)
@@ -493,6 +505,7 @@ static void neonhelp_event_part(struct ChanUser *target, char *reason) {
                     putsock(client, "MODE %s -i", support->name); //clear invite list
                     if(isModeSet(support->modes, 'i'))
                         putsock(client, "MODE %s +i", support->name);
+                    neonhelp_invite_active_requests(client, support, public, target->user);
                 }
                 //free the user's support request
                 if(prev_helpnode)
index e28a2deb6c3c8371a466efecbd528549e5fbf825..5af9d15df137d0785cfb87700b99bd73ad25c4fa 100644 (file)
@@ -48,5 +48,6 @@ void loop_NeonHelp();
 void free_NeonHelp(int type);
 
 void neonhelp_destroy_support_request(struct ClientSocket *client, struct NeonHelpNode *helpnode, int do_reply);
+void neonhelp_invite_active_requests(struct ClientSocket *client, struct ChanNode *support, struct ChanNode *public, struct UserNode *ignore_user);
 
 #endif
\ No newline at end of file
index 2cf57a478d8a139a9c1662813504fb4c8ab869f5..a034ec8cdab44b03c1c8289f1e85d0b0fa987ac8 100644 (file)
@@ -84,6 +84,7 @@ CMD_BIND(neonhelp_cmd_delete) {
             putsock(client, "MODE %s -i", support->name); //clear invite list
             if(isModeSet(support->modes, 'i'))
                 putsock(client, "MODE %s +i", support->name);
+            neonhelp_invite_active_requests(client, support, public, helpnode->user);
         }
     }
     if(prev_helpnode)