]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/cmd_topic.cpp
Removal of ancient TRUE/FALSE #defines (C-ish stuff)
[user/henk/code/inspircd.git] / src / cmd_topic.cpp
index 48f6b7b7e1b2af1747b9f39518ae10a92c8ba4d7..b8c60240dc5ade2abe2a1ee55c2f8e4438209e33 100644 (file)
@@ -57,7 +57,6 @@ extern std::vector<ircd_module*> factory;
 extern time_t TIME;
 extern user_hash clientlist;
 extern chan_hash chanlist;
-extern whowas_hash whowas;
 extern std::vector<userrec*> all_opers;
 extern std::vector<userrec*> local_users;
 extern userrec* fd_ref_table[MAX_DESCRIPTORS];
@@ -68,80 +67,72 @@ void cmd_topic::Handle (char **parameters, int pcnt, userrec *user)
 
        if (pcnt == 1)
        {
-               if (strlen(parameters[0]) <= CHANMAX)
+               Ptr = FindChan(parameters[0]);
+               if (Ptr)
                {
-                       Ptr = FindChan(parameters[0]);
-                       if (Ptr)
+                       if ((Ptr->modes[CM_SECRET]) && (!Ptr->HasUser(user)))
                        {
-                               if (((Ptr) && (!has_channel(user,Ptr))) && (Ptr->binarymodes & CM_SECRET))
-                               {
-                                       WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, Ptr->name);
-                                       return;
-                               }
-                               if (Ptr->topicset)
-                               {
-                                       WriteServ(user->fd,"332 %s %s :%s", user->nick, Ptr->name, Ptr->topic);
-                                       WriteServ(user->fd,"333 %s %s %s %d", user->nick, Ptr->name, Ptr->setby, Ptr->topicset);
-                               }
-                               else
-                               {
-                                       WriteServ(user->fd,"331 %s %s :No topic is set.", user->nick, Ptr->name);
-                               }
+                               WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, Ptr->name);
+                               return;
+                       }
+                       if (Ptr->topicset)
+                       {
+                               WriteServ(user->fd,"332 %s %s :%s", user->nick, Ptr->name, Ptr->topic);
+                               WriteServ(user->fd,"333 %s %s %s %d", user->nick, Ptr->name, Ptr->setby, Ptr->topicset);
                        }
                        else
                        {
-                               WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, parameters[0]);
+                               WriteServ(user->fd,"331 %s %s :No topic is set.", user->nick, Ptr->name);
                        }
                }
+               else
+               {
+                       WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, parameters[0]);
+               }
                return;
        }
        else if (pcnt>1)
        {
-               if (strlen(parameters[0]) <= CHANMAX)
+               Ptr = FindChan(parameters[0]);
+               if (Ptr)
                {
-                       Ptr = FindChan(parameters[0]);
-                       if (Ptr)
+                       if (IS_LOCAL(user))
                        {
-                               if ((Ptr) && (!has_channel(user,Ptr)))
+                               if (!Ptr->HasUser(user))
                                {
                                        WriteServ(user->fd,"442 %s %s :You're not on that channel!",user->nick, Ptr->name);
                                        return;
                                }
-                               if ((Ptr->binarymodes & CM_TOPICLOCK) && (cstatus(user,Ptr)<STATUS_HOP))
+                               if ((Ptr->modes[CM_TOPICLOCK]) && (cstatus(user,Ptr)<STATUS_HOP))
                                {
                                        WriteServ(user->fd,"482 %s %s :You must be at least a half-operator to change modes on this channel", user->nick, Ptr->name);
                                        return;
                                }
+                       }
+                       char topic[MAXTOPIC];
+                       strlcpy(topic,parameters[1],MAXTOPIC-1);
 
-                               char topic[MAXBUF];
-                               strlcpy(topic,parameters[1],MAXBUF);
-                               if (strlen(topic)>MAXTOPIC)
-                               {
-                                       topic[MAXTOPIC] = '\0';
-                               }
-
-                                if (user->fd > -1)
-                                {
-                                        int MOD_RESULT = 0;
-                                        FOREACH_RESULT(I_OnLocalTopicChange,OnLocalTopicChange(user,Ptr,topic));
-                                        if (MOD_RESULT)
-                                                return;
-                                }
+                        if (IS_LOCAL(user))
+                        {
+                                int MOD_RESULT = 0;
+                                FOREACH_RESULT(I_OnLocalTopicChange,OnLocalTopicChange(user,Ptr,topic));
+                                if (MOD_RESULT)
+                                        return;
+                        }
 
-                               strlcpy(Ptr->topic,topic,MAXTOPIC);
-                               strlcpy(Ptr->setby,user->nick,NICKMAX);
-                               Ptr->topicset = TIME;
-                               WriteChannel(Ptr,user,"TOPIC %s :%s",Ptr->name, Ptr->topic);
-                               if (user->fd > -1)
-                               {
-                                       FOREACH_MOD(I_OnPostLocalTopicChange,OnPostLocalTopicChange(user,Ptr,topic));
-                               }
-                       }
-                       else
+                       strlcpy(Ptr->topic,topic,MAXTOPIC-1);
+                       strlcpy(Ptr->setby,user->nick,NICKMAX-1);
+                       Ptr->topicset = TIME;
+                       WriteChannel(Ptr,user,"TOPIC %s :%s",Ptr->name, Ptr->topic);
+                       if (IS_LOCAL(user))
                        {
-                               WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, parameters[0]);
+                               FOREACH_MOD(I_OnPostLocalTopicChange,OnPostLocalTopicChange(user,Ptr,topic));
                        }
                }
+               else
+               {
+                       WriteServ(user->fd,"401 %s %s :No such nick/channel",user->nick, parameters[0]);
+               }
        }
 }