]> jfr.im git - irc/rqf/shadowircd.git/blobdiff - extensions/m_ojoin.c
Add extensions/m_oaccept , a module to allow opers to bypass +gGR with a command.
[irc/rqf/shadowircd.git] / extensions / m_ojoin.c
index f07ea475ceaa09f92f98dd09606d6400047af89d..239cd447ca5ccd5836a22502f3029054a3292baa 100644 (file)
  *   along with this program; if not, write to the Free Software
  *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  *
- *   $Id: m_ojoin.c 3297 2007-03-28 14:49:48Z jilles $
+ *   $Id: m_ojoin.c 3554 2007-08-10 22:31:14Z jilles $
  */
 
 #include "stdinc.h"
-#include "tools.h"
-#include "patricia.h"
 #include "channel.h"
-#include "client.h"
+#include "client.h" 
 #include "ircd.h"
 #include "numeric.h"
-#include "s_log.h"
+#include "logger.h"
 #include "s_serv.h"
 #include "s_conf.h"
-#include "s_newconf.h"
+#include "s_newconf.h" 
 #include "send.h"
 #include "whowas.h"
-#include "irc_string.h"
-#include "hash.h"
+#include "match.h"
+#include "hash.h" 
 #include "msg.h"
 #include "parse.h"
 #include "modules.h"
 
-
 static int mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
 
 
@@ -49,11 +46,10 @@ struct Message ojoin_msgtab = {
 
 mapi_clist_av1 ojoin_clist[] = { &ojoin_msgtab, NULL };
 
-DECLARE_MODULE_AV1(ojoin, NULL, NULL, ojoin_clist, NULL, NULL, "$Revision: 3297 $");
+DECLARE_MODULE_AV1(ojoin, NULL, NULL, ojoin_clist, NULL, NULL, "$Revision: 3554 $");
 
 /*
 ** mo_ojoin
-**      parv[0] = sender prefix
 **      parv[1] = channel
 */
 static int
@@ -105,9 +101,9 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
        if(*parv[1] == '@')
        {
                add_user_to_channel(chptr, source_p, CHFL_CHANOP);
-               sendto_server(client_p, chptr, NOCAPS, NOCAPS,
+               sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
                              ":%s SJOIN %ld %s + :@%s",
-                             me.name, (long) chptr->channelts, chptr->chname, source_p->name);
+                             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);
@@ -118,9 +114,9 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
        else if(*parv[1] == '+')
        {
                add_user_to_channel(chptr, source_p, CHFL_VOICE);
-               sendto_server(client_p, chptr, NOCAPS, NOCAPS,
+               sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
                              ":%s SJOIN %ld %s + :+%s",
-                             me.name, (long) chptr->channelts, chptr->chname, source_p->name);
+                             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);
@@ -130,9 +126,9 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
        else
        {
                add_user_to_channel(chptr, source_p, CHFL_PEON);
-               sendto_server(client_p, chptr, NOCAPS, NOCAPS,
-                             ":%s SJOIN %ld %s + :%s",
-                             me.name, (long) chptr->channelts, chptr->chname, source_p->name);
+               sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
+                             ":%s JOIN %ld %s +",
+                             source_p->id, (long) chptr->channelts, chptr->chname);
                sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s JOIN %s",
                                     source_p->name,
                                     source_p->username, source_p->host, chptr->chname);
@@ -147,7 +143,7 @@ mo_ojoin(struct Client *client_p, struct Client *source_p, int parc, const char
                           source_p->name, chptr->chname, chptr->topic_info, chptr->topic_time);
        }
 
-       source_p->localClient->last_join_time = CurrentTime;
+       source_p->localClient->last_join_time = rb_current_time();
        channel_member_names(chptr, source_p, 1);
 
        return 0;