Only do automode when a user is identified, also do automode on an IRCv3
ACCOUNT command
This commit is contained in:
parent
25ef1965fd
commit
c8309d96ea
2 changed files with 13 additions and 6 deletions
|
@ -26,6 +26,8 @@ class User(object):
|
||||||
def get_id(self):
|
def get_id(self):
|
||||||
return (self.identified_account_id_override or
|
return (self.identified_account_id_override or
|
||||||
self.identified_account_id or self._id)
|
self.identified_account_id or self._id)
|
||||||
|
def get_identified_account(self):
|
||||||
|
return (self.identified_account_override or self.identified_account)
|
||||||
|
|
||||||
def set_nickname(self, nickname):
|
def set_nickname(self, nickname):
|
||||||
self.nickname = nickname
|
self.nickname = nickname
|
||||||
|
|
|
@ -27,13 +27,18 @@ class Module(object):
|
||||||
"help": "Disable/Enable automode",
|
"help": "Disable/Enable automode",
|
||||||
"validate": Utils.bool_or_none})
|
"validate": Utils.bool_or_none})
|
||||||
|
|
||||||
def on_join(self, event):
|
def _check_modes(self, channel, user):
|
||||||
if event["channel"].get_setting("automode", False):
|
identified_account = user.get_identified_account()
|
||||||
modes = event["channel"].get_user_setting(event["user"].get_id(),
|
if identified_account and channel.get_setting("automode", False):
|
||||||
"automodes", [])
|
modes = channel.get_user_setting(user.get_id(), "automodes", [])
|
||||||
if modes:
|
if modes:
|
||||||
event["channel"].send_mode("+%s" % "".join(modes),
|
channel.send_mode("+%s" % "".join(modes),
|
||||||
" ".join([event["user"].nickname for mode in modes]))
|
" ".join([user.nickname for mode in modes]))
|
||||||
|
def on_join(self, event):
|
||||||
|
self._check_modes(event["channel"], event["user"])
|
||||||
|
def on_account(self, event):
|
||||||
|
for channel in event["user"].channels:
|
||||||
|
self._check_modes(channel, event["user"])
|
||||||
|
|
||||||
def _add_mode(self, event, mode, mode_name):
|
def _add_mode(self, event, mode, mode_name):
|
||||||
target_user = event["server"].get_user(event["args_split"][0])
|
target_user = event["server"].get_user(event["args_split"][0])
|
||||||
|
|
Loading…
Reference in a new issue