target_p->name, buf);
}
+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);
+}
+
/*
* user_mode - set get current users mode
*
Count.oper--;
+ /* Do we need to propegate these? I'm not 100% sure
+ * so we should test it when we have a testnet */
+ user_metadata_delete(source_p, "OPERSTRING", 1);
+ user_metadata_delete(source_p, "SWHOIS", 1);
+
if(MyConnect(source_p))
{
source_p->umodes &= ~ConfigFileEntry.oper_only_umodes;
sendto_one_numeric(source_p, RPL_SNOMASK, form_str(RPL_SNOMASK),
construct_snobuf(source_p->snomask));
+ /* If we're setting +p, expire it, but only from local clients */
+ 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);
}
else
source_p->umodes |= DEFAULT_OPER_UMODES;
+ if(oper_p->swhois)
+ user_metadata_add(source_p, "SWHOIS", oper_p->swhois, 1);
+
+ if(oper_p->operstring)
+ user_metadata_add(source_p, "OPERSTRING", oper_p->operstring, 1);
+
if(oper_p->vhost || !EmptyString(ConfigFileEntry.default_operhost))
{
if(oper_p->vhost)