aboutsummaryrefslogtreecommitdiff
path: root/modules/seen.py
blob: 0a2be3eced655a8b357032041612070591bb16f8 (about) (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
import time
import Utils


class Module(object):
    def __init__(self, bot):
        bot.events.on("received").on("message").on("channel"
                                                   ).hook(self.channel_message)
        bot.events.on("received").on("command").on("seen").hook(
            self.seen, min_args=1,
            help="Find out when a user was last seen",
            usage="<username>")

    def channel_message(self, event):
        seen_seconds = time.time()
        event["user"].set_setting("seen", seen_seconds)

    def seen(self, event):
        seen_seconds = event["server"].get_user(event["args_split"][0]
                                                ).get_setting("seen")
        if seen_seconds:
            since = Utils.to_pretty_time(time.time() - seen_seconds,
                                         max_units=2)
            event["stdout"].write("%s was last seen %s ago" % (
                event["args_split"][0], since))
        else:
            event["stderr"].write("I have never seen %s before." % (
                event["args_split"][0]))