Backed out changeset 65db6ca26281

This commit is contained in:
JD Horelick 2010-02-25 15:11:43 -05:00
parent 44a8fbc29e
commit 47fab428b1
9 changed files with 14 additions and 71 deletions

View File

@ -13,7 +13,6 @@ Usermodes: (* designates that the umode is oper only)
* +l - Can see oper locops (local wallops). * +l - Can see oper locops (local wallops).
* +s - Can see server notices (see /quote help snomask). * +s - Can see server notices (see /quote help snomask).
* +z - Can see operwalls. * +z - Can see operwalls.
* +p - Override -- implicit operator access in all channels.
+B - Marks you as a bot in /whois. +B - Marks you as a bot in /whois.
+C - Prevents you from receiving CTCPs other than ACTION. +C - Prevents you from receiving CTCPs other than ACTION.
+D - Deaf - ignores all channel messages. +D - Deaf - ignores all channel messages.

View File

@ -88,7 +88,6 @@ struct membership
unsigned int flags; unsigned int flags;
unsigned long bants; unsigned long bants;
unsigned long override_ts;
}; };
#define BANLEN 195 #define BANLEN 195
@ -115,7 +114,6 @@ struct ChModeChange
int caps; int caps;
int nocaps; int nocaps;
int mems; int mems;
int override;
struct Client *client; struct Client *client;
}; };
@ -173,7 +171,6 @@ typedef int (*ExtbanFunc)(const char *data, struct Client *client_p,
#define MODE_FREEINVITE 0x0800 /* allow free use of /invite */ #define MODE_FREEINVITE 0x0800 /* allow free use of /invite */
#define MODE_FREETARGET 0x1000 /* can be forwarded to without authorization */ #define MODE_FREETARGET 0x1000 /* can be forwarded to without authorization */
#define MODE_DISFORWARD 0x2000 /* disable channel forwarding */ #define MODE_DISFORWARD 0x2000 /* disable channel forwarding */
#define MODE_NOOPERKICK 0x4000 /* disallow kicking opers aka immune */
#define MODE_NOCTCP 0x8000 /* Block CTCPs directed to this channel */ #define MODE_NOCTCP 0x8000 /* Block CTCPs directed to this channel */
#define MODE_NONOTICE 0x16000 /* Block notices directed to this channel */ #define MODE_NONOTICE 0x16000 /* Block notices directed to this channel */
#define MODE_NOACTION 0x32000 /* Block CTCP ACTION directed to this channel */ #define MODE_NOACTION 0x32000 /* Block CTCP ACTION directed to this channel */
@ -196,8 +193,6 @@ typedef int (*ExtbanFunc)(const char *data, struct Client *client_p,
/* channel visible */ /* channel visible */
#define ShowChannel(v,c) (PubChannel(c) || IsMember((v),(c))) #define ShowChannel(v,c) (PubChannel(c) || IsMember((v),(c)))
/* user visible in channel */
#define ShowInChannel(v,t,c) ((PubChannel(c) && !IsInvisible(t)) || IsMember((v),(c)))
#define IsMember(who, chan) ((who && who->user && \ #define IsMember(who, chan) ((who && who->user && \
find_channel_membership(chan, who)) ? 1 : 0) find_channel_membership(chan, who)) ? 1 : 0)

View File

@ -48,9 +48,6 @@ extern void chm_simple(struct Client *source_p, struct Channel *chptr,
extern void chm_ban(struct Client *source_p, struct Channel *chptr, extern void chm_ban(struct Client *source_p, struct Channel *chptr,
int alevel, int parc, int *parn, int alevel, int parc, int *parn,
const char **parv, int *errors, int dir, char c, long mode_type); const char **parv, int *errors, int dir, char c, long mode_type);
extern void chm_hidden(struct Client *source_p, struct Channel *chptr,
int alevel, int parc, int *parn,
const char **parv, int *errors, int dir, char c, long mode_type);
extern void chm_staff(struct Client *source_p, struct Channel *chptr, extern void chm_staff(struct Client *source_p, struct Channel *chptr,
int alevel, int parc, int *parn, int alevel, int parc, int *parn,
const char **parv, int *errors, int dir, char c, long mode_type); const char **parv, int *errors, int dir, char c, long mode_type);

View File

@ -281,8 +281,6 @@ struct LocalUser
struct ev_entry *event; /* used for associated events */ struct ev_entry *event; /* used for associated events */
struct PrivilegeSet *privset; /* privset... */ struct PrivilegeSet *privset; /* privset... */
struct rb_event_t *override_timeout_event;
}; };
struct PreClient struct PreClient
@ -432,17 +430,6 @@ struct ListClient
#define UMODE_ADMIN 0x2000 /* Admin on server */ #define UMODE_ADMIN 0x2000 /* Admin on server */
#define UMODE_SSLCLIENT 0x4000 /* using SSL */ #define UMODE_SSLCLIENT 0x4000 /* using SSL */
/* oper-controlled privledge umodes. */
#define UMODE_OVERRIDE 0x20000
/* umode/oper mode macros */
#define IsOper(x) ((x)->umodes & UMODE_OPER)
#define IsAdmin(x) ((x)->umodes & UMODE_ADMIN)
#define IsHelper(x) ((x)->umodes & UMODE_HELPER)
#define IsAnyOper(x) ((x)->umodes & (UMODE_OPER|UMODE_HELPER))
#define IsOverride(x) ((x)->umodes & UMODE_OVERRIDE)
/* overflow flags */ /* overflow flags */
/* EARLIER FLAGS ARE IN s_newconf.h */ /* EARLIER FLAGS ARE IN s_newconf.h */
#define FLAGS2_EXEMPTRESV 0x00400000 #define FLAGS2_EXEMPTRESV 0x00400000

View File

@ -164,7 +164,6 @@ extern void cluster_generic(struct Client *, const char *, int cltype,
#define IsOperSpy(x) (HasPrivilege((x), "oper:spy")) #define IsOperSpy(x) (HasPrivilege((x), "oper:spy"))
#define IsOperInvis(x) (HasPrivilege((x), "oper:hidden")) #define IsOperInvis(x) (HasPrivilege((x), "oper:hidden"))
#define IsOperRemoteBan(x) (HasPrivilege((x), "oper:remoteban")) #define IsOperRemoteBan(x) (HasPrivilege((x), "oper:remoteban"))
#define IsOperOverride(x) HasPrivilege(x, "oper:override")
#define IsOperMassNotice(x) (HasPrivilege((x), "oper:mass_notice")) #define IsOperMassNotice(x) (HasPrivilege((x), "oper:mass_notice"))
extern struct oper_conf *make_oper_conf(void); extern struct oper_conf *make_oper_conf(void);
@ -176,20 +175,6 @@ extern struct oper_conf *find_oper_conf(const char *username, const char *host,
extern const char *get_oper_privs(int flags); extern const char *get_oper_privs(int flags);
struct mode_table
{
const char *name;
int mode;
};
struct oper_flags
{
int flag;
const char *name;
char has;
char hasnt;
};
struct server_conf struct server_conf
{ {
char *name; char *name;

View File

@ -53,6 +53,13 @@ mapi_clist_av1 privs_clist[] = {
NULL NULL
}; };
/* XXX this is a copy, not so nice */
struct mode_table
{
const char *name;
int mode;
};
/* there is no such table like this anywhere else */ /* there is no such table like this anywhere else */
static struct mode_table auth_client_table[] = { static struct mode_table auth_client_table[] = {
{"resv_exempt", FLAGS2_EXEMPTRESV }, {"resv_exempt", FLAGS2_EXEMPTRESV },

View File

@ -232,12 +232,6 @@ free_local_client(struct Client *client_p)
} }
rb_free(client_p->localClient->auth_user); rb_free(client_p->localClient->auth_user);
if(client_p->localClient->override_timeout_event)
{
rb_event_delete(client_p->localClient->override_timeout_event);
}
rb_free(client_p->localClient->challenge); rb_free(client_p->localClient->challenge);
rb_free(client_p->localClient->fullcaps); rb_free(client_p->localClient->fullcaps);
rb_free(client_p->localClient->opername); rb_free(client_p->localClient->opername);

View File

@ -286,6 +286,12 @@ conf_set_modules_path(void *data)
#endif #endif
} }
struct mode_table
{
const char *name;
int mode;
};
/* *INDENT-OFF* */ /* *INDENT-OFF* */
static struct mode_table umode_table[] = { static struct mode_table umode_table[] = {
{"callerid", UMODE_CALLERID }, {"callerid", UMODE_CALLERID },
@ -297,7 +303,6 @@ static struct mode_table umode_table[] = {
{"servnotice", UMODE_SERVNOTICE}, {"servnotice", UMODE_SERVNOTICE},
{"wallop", UMODE_WALLOP }, {"wallop", UMODE_WALLOP },
{"operwall", UMODE_OPERWALL }, {"operwall", UMODE_OPERWALL },
{"override", UMODE_OVERRIDE },
{"noctcp", UMODE_NOCTCP }, {"noctcp", UMODE_NOCTCP },
{"noinvite", UMODE_NOINVITE }, {"noinvite", UMODE_NOINVITE },
{"bot", UMODE_BOT }, {"bot", UMODE_BOT },

View File

@ -109,7 +109,7 @@ int user_modes[256] = {
0, /* m */ 0, /* m */
0, /* n */ 0, /* n */
UMODE_OPER, /* o */ UMODE_OPER, /* o */
UMODE_OVERRIDE, /* p */ 0, /* p */
0, /* q */ 0, /* q */
0, /* r */ 0, /* r */
UMODE_SERVNOTICE, /* s */ UMODE_SERVNOTICE, /* s */
@ -881,15 +881,6 @@ report_and_set_user_flags(struct Client *source_p, struct ConfItem *aconf)
} }
} }
static void
expire_umode_p(void *data)
{
struct Client *source_p = data;
char *parv[4] = {source_p->name, source_p->name, "-p", NULL};
source_p->localClient->override_timeout_event = NULL;
user_mode(source_p, source_p, 3, parv);
}
static void static void
show_other_user_mode(struct Client *source_p, struct Client *target_p) show_other_user_mode(struct Client *source_p, struct Client *target_p)
{ {
@ -1147,12 +1138,6 @@ user_mode(struct Client *client_p, struct Client *source_p, int parc, const char
source_p->umodes &= ~UMODE_ADMIN; source_p->umodes &= ~UMODE_ADMIN;
} }
if(MyConnect(source_p) && (source_p->umodes & UMODE_OVERRIDE) && (!IsOperOverride(source_p)))
{
sendto_one_notice(source_p, ":*** You need oper and the override flag for +p");
source_p->umodes &= ~UMODE_OVERRIDE;
}
/* let modules providing usermodes know that we've changed our usermode --nenolod */ /* let modules providing usermodes know that we've changed our usermode --nenolod */
hdata.client = source_p; hdata.client = source_p;
hdata.oldumodes = setflags; hdata.oldumodes = setflags;
@ -1172,17 +1157,6 @@ user_mode(struct Client *client_p, struct Client *source_p, int parc, const char
sendto_one_numeric(source_p, RPL_SNOMASK, form_str(RPL_SNOMASK), sendto_one_numeric(source_p, RPL_SNOMASK, form_str(RPL_SNOMASK),
construct_snobuf(source_p->snomask)); construct_snobuf(source_p->snomask));
if(ConfigFileEntry.expire_override_time && MyClient(source_p) && (source_p->umodes & ~setflags) & UMODE_OVERRIDE)
{
source_p->localClient->override_timeout_event =
rb_event_addonce("expire_override", expire_umode_p, source_p, ConfigFileEntry.expire_override_time);
}
else if(MyClient(source_p) && source_p->localClient->override_timeout_event && (setflags & ~source_p->umodes) & UMODE_OVERRIDE)
{
rb_event_delete(source_p->localClient->override_timeout_event);
source_p->localClient->override_timeout_event = NULL;
}
return (0); return (0);
} }