diff options
Diffstat (limited to 'modules/line_handler/user.py')
| -rw-r--r-- | modules/line_handler/user.py | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/modules/line_handler/user.py b/modules/line_handler/user.py new file mode 100644 index 00000000..f9f14af6 --- /dev/null +++ b/modules/line_handler/user.py @@ -0,0 +1,89 @@ +from src import utils + +def handle_311(event): + nickname = event["args"][1] + if event["server"].is_own_nickname(nickname): + target = event["server"] + else: + target = event["server"].get_user(nickname) + target.username = event["args"][2] + target.hostname = event["args"][3] + target.realname = event["args"][4] + +def quit(events, event): + nickname = None + if event["direction"] == utils.Direction.RECV: + nickname = event["prefix"].nickname + reason = event["args"].get(0) + + if event["direction"] == utils.Direction.RECV: + nickname = event["prefix"].nickname + if (not event["server"].is_own_nickname(nickname) and + not event["prefix"].hostmask == "*"): + user = event["server"].get_user(nickname) + event["server"].remove_user(user) + events.on("received.quit").call(reason=reason, user=user, + server=event["server"]) + else: + event["server"].disconnect() + else: + events.on("send.quit").call(reason=reason, server=event["server"]) + +def nick(events, event): + new_nickname = event["args"].get(0) + if not event["server"].is_own_nickname(event["prefix"].nickname): + user = event["server"].get_user(event["prefix"].nickname) + old_nickname = user.nickname + user.set_nickname(new_nickname) + event["server"].change_user_nickname(old_nickname, new_nickname) + + events.on("received.nick").call(new_nickname=new_nickname, + old_nickname=old_nickname, user=user, server=event["server"]) + else: + old_nickname = event["server"].nickname + event["server"].set_own_nickname(new_nickname) + + events.on("self.nick").call(server=event["server"], + new_nickname=new_nickname, old_nickname=old_nickname) + +def away(events, event): + user = event["server"].get_user(event["prefix"].nickname) + message = event["args"].get(0) + if message: + user.away = True + events.on("received.away.on").call(user=user, server=event["server"], + message=message) + else: + user.away = False + events.on("received.away.off").call(user=user, server=event["server"]) + +def chghost(event): + nickname = event["prefix"].nickname + username = event["args"][0] + hostname = event["args"][1] + + if not event["server"].is_own_nickname(nickname): + target = event["server"].get_user(nickname) + else: + target = event["server"] + target.username = username + target.hostname = hostname + +def setname(event): + user = event["server"].get_user(event["prefix"].nickname) + user.realname = event["args"][0] + +def account(events, event): + user = event["server"].get_user(event["prefix"].nickname) + + if not event["args"][0] == "*": + user.identified_account = event["args"][0] + user.identified_account_id = event["server"].get_user( + event["args"][0]).get_id() + events.on("received.account.login").call(user=user, + server=event["server"], account=event["args"][0]) + else: + user.identified_account = None + user.identified_account_id = None + events.on("received.account.logout").call(user=user, + server=event["server"]) |
