fixed database (increased flags field size)
[NeonServV5.git] / src / cmd_global_modcmd.c
index a5f36ad98760c1a813ed2b74fddce90206fc224c..5a5ce2ea827c279a99cb902260b1f1537803593b 100644 (file)
@@ -119,11 +119,13 @@ static int global_cmd_modcmd_flags(struct UserNode *user, struct cmd_binding *cb
     char flags[MAXLEN];
     int flagpos = 0;
     int ret = 0;
+    unsigned int visible_flags = 0;
     int i = 0;
     while(global_cmd_modcmd_show_flags[i].name) {
         if(cbind->func->flags & global_cmd_modcmd_show_flags[i].flag) {
             flagpos += sprintf(flags + flagpos, (flagpos ? " %s" : "\00314%s"), global_cmd_modcmd_show_flags[i].name);
         }
+        visible_flags |= global_cmd_modcmd_show_flags[i].flag;
         i++;
     }
     if(flagpos) 
@@ -156,9 +158,9 @@ static int global_cmd_modcmd_flags(struct UserNode *user, struct cmd_binding *cb
         else
             cbind->flags &= ~current_flag;
         if(cbind->botid == 0)
-            printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '0' AND `botid` = '%d' AND `command` = '%s'", cbind->flags, cbind->clientid, escape_string(cbind->cmd));
+            printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '0' AND `botid` = '%d' AND `command` = '%s'", (cbind->flags & visible_flags), cbind->clientid, escape_string(cbind->cmd));
         else
-            printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '%d' AND `command` = '%s'", cbind->flags, cbind->botid, escape_string(cbind->cmd));
+            printf_mysql_query("UPDATE `bot_binds` SET `flags` = '%u' WHERE `botclass` = '%d' AND `command` = '%s'", (cbind->flags & visible_flags), cbind->botid, escape_string(cbind->cmd));
         ret = 1;
     }
     i = 0;