]> jfr.im git - irc/rqf/shadowircd.git/blobdiff - extensions/m_ojoin.c
Send numeric 735 on MLOCK policy-restricted mode changes that are ignored.
[irc/rqf/shadowircd.git] / extensions / m_ojoin.c
index 53ed832ff6d14b330aa838a6636644655d7d3036..a58c08309e3a6495797ebc89b23f235db43fa1ac 100644 (file)
@@ -16,7 +16,6 @@
  *   along with this program; if not, write to the Free Software
  *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  *
- *   $Id: m_ojoin.c 3554 2007-08-10 22:31:14Z jilles $
  */
 
 #include "stdinc.h"
@@ -30,7 +29,7 @@
 #include "s_newconf.h" 
 #include "send.h"
 #include "whowas.h"
-#include "irc_string.h"
+#include "match.h"
 #include "hash.h" 
 #include "msg.h"
 #include "parse.h"
@@ -50,7 +49,6 @@ DECLARE_MODULE_AV1(ojoin, NULL, NULL, ojoin_clist, NULL, NULL, "$Revision: 3554
 
 /*
 ** mo_ojoin
-**      parv[0] = sender prefix
 **      parv[1] = channel
 */
 static int
@@ -66,7 +64,7 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
                return 0;
        }
 
-       if(*parv[1] == '@' || *parv[1] == '%' || *parv[1] == '+')
+       if(*parv[1] == '@' || *parv[1] == '%' || *parv[1] == '+' || *parv[1] == '!')
        {
                parv[1]++;
                move_me = 1;
@@ -99,15 +97,25 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
                        me.name, parv[1],
                        source_p->name, source_p->username, source_p->host);
 
-       if(*parv[1] == '@')
+       if(*parv[1] == '!' && ConfigChannel.use_admin)
+       {
+               add_user_to_channel(chptr, source_p, CHFL_ADMIN);
+               sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
+                             ":%s SJOIN %ld %s + :!%s",
+                             me.id, (long) chptr->channelts, chptr->chname, source_p->id);
+               sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s JOIN %s",
+                                    source_p->name,
+                                    source_p->username, source_p->host, chptr->chname);
+               sendto_channel_local(ALL_MEMBERS, chptr, ":%s MODE %s +a %s",
+                                    me.name, chptr->chname, source_p->name);
+
+       }
+       else if(*parv[1] == '@')
        {
                add_user_to_channel(chptr, source_p, CHFL_CHANOP);
                sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
                              ":%s SJOIN %ld %s + :@%s",
                              me.id, (long) chptr->channelts, chptr->chname, source_p->id);
-               sendto_server(client_p, chptr, NOCAPS, CAP_TS6,
-                             ":%s SJOIN %ld %s + :@%s",
-                             me.name, (long) chptr->channelts, chptr->chname, source_p->name);
                sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s JOIN %s",
                                     source_p->name,
                                     source_p->username, source_p->host, chptr->chname);
@@ -115,15 +123,24 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
                                     me.name, chptr->chname, source_p->name);
 
        }
+       else if(*parv[1] == '%' && ConfigChannel.use_halfop)
+       {
+               add_user_to_channel(chptr, source_p, CHFL_HALFOP);
+               sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
+                             ":%s SJOIN %ld %s + :%s%s",
+                             me.id, (long) chptr->channelts, chptr->chname, "%", source_p->id);
+               sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s JOIN %s",
+                                    source_p->name,
+                                    source_p->username, source_p->host, chptr->chname);
+               sendto_channel_local(ALL_MEMBERS, chptr, ":%s MODE %s +h %s",
+                                    me.name, chptr->chname, source_p->name);
+       }
        else if(*parv[1] == '+')
        {
                add_user_to_channel(chptr, source_p, CHFL_VOICE);
                sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
                              ":%s SJOIN %ld %s + :+%s",
                              me.id, (long) chptr->channelts, chptr->chname, source_p->id);
-               sendto_server(client_p, chptr, NOCAPS, CAP_TS6,
-                             ":%s SJOIN %ld %s + :+%s",
-                             me.name, (long) chptr->channelts, chptr->chname, source_p->name);
                sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s JOIN %s",
                                     source_p->name,
                                     source_p->username, source_p->host, chptr->chname);
@@ -136,9 +153,6 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
                sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
                              ":%s JOIN %ld %s +",
                              source_p->id, (long) chptr->channelts, chptr->chname);
-               sendto_server(client_p, chptr, NOCAPS, CAP_TS6,
-                             ":%s SJOIN %ld %s + :%s",
-                             me.name, (long) chptr->channelts, chptr->chname, source_p->name);
                sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s JOIN %s",
                                     source_p->name,
                                     source_p->username, source_p->host, chptr->chname);