* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA
*
- * $Id: m_join.c 3494 2007-05-27 13:07:27Z jilles $
*/
#include "stdinc.h"
#include "chmode.h"
static int m_join(struct Client *, struct Client *, int, const char **);
+static int me_svsjoin(struct Client *, struct Client *, int, const char **);
static int ms_join(struct Client *, struct Client *, int, const char **);
static int ms_sjoin(struct Client *, struct Client *, int, const char **);
{mg_unreg, {m_join, 2}, {ms_join, 2}, mg_ignore, mg_ignore, {m_join, 2}}
};
+struct Message svsjoin_msgtab = {
+ "SVSJOIN", 0, 0, 0, MFLG_SLOW,
+ {mg_ignore, mg_ignore, mg_ignore, mg_ignore, {me_svsjoin, 3}, mg_ignore}
+};
+
struct Message sjoin_msgtab = {
"SJOIN", 0, 0, 0, MFLG_SLOW,
{mg_unreg, mg_ignore, mg_ignore, {ms_sjoin, 4}, mg_ignore, mg_ignore}
};
-mapi_clist_av1 join_clist[] = { &join_msgtab, &sjoin_msgtab, NULL };
+mapi_clist_av1 join_clist[] = { &join_msgtab, &svsjoin_msgtab, &sjoin_msgtab, NULL };
DECLARE_MODULE_AV1(join, NULL, NULL, join_clist, NULL, NULL, "$Revision: 3494 $");
return 0;
}
+/*
+ * me_svsjoin - small function to allow services to forcejoin clients, mainly for ns_ajoin
+ * parv[1] = user to act on (join to a channel)
+ * parv[2] = channel
+ * This does allow opers to "forcejoin" users to channels with operserv/raw or by writing a
+ * custom module (where they can make it not log anything), but the former bitches that it's
+ * being used and the latter...Can probably be done anyway with enough hackyness if this
+ * command didn't exist so it's not all that bad.
+ */
+static int
+me_svsjoin(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+{
+ struct Client *target_p;
+
+ if(!(source_p->flags & FLAGS_SERVICE))
+ return 0;
+
+ if((target_p = find_person(parv[1])) == NULL)
+ return 0;
+
+ user_join(&me, target_p, parv[2], NULL);
+ return 0;
+}
+
/*
* ms_join
* parv[1] = channel TS
{
if(*s == '!')
{
- fl |= CHFL_OWNER;
+ fl |= CHFL_ADMIN;
s++;
}
else if(*s == '@')
if(keep_new_modes)
{
- if(fl & CHFL_OWNER)
+ if(fl & CHFL_ADMIN)
{
*ptr_uid++ = '!';
len_nick++;
/* If anyone can think of a way to do this that doesn't make babies cry
* I would love to hear it - Taros */
- if(fl & CHFL_OWNER)
+ if(fl & CHFL_ADMIN)
{
*mbuf++ = 'a';
para[pargs++] = target_p->name;
/* If anyone can think of a way to do this that doesn't make babies cry
* I would love to hear it - Taros */
- if(is_owner(msptr))
+ if(is_admin(msptr))
{
- msptr->flags &= ~CHFL_OWNER;
+ msptr->flags &= ~CHFL_ADMIN;
lpara[count++] = msptr->client_p->name;
*mbuf++ = 'a';