aboutsummaryrefslogtreecommitdiffstats
path: root/server/server.py
blob: d78552d13c60ff1ea73f8fbd8d588988af760e33 (plain)
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#!/usr/bin/python2
import logging
from argparse import ArgumentParser

from sleekxmpp.componentxmpp import ComponentXMPP
from sleekxmpp.xmlstream.xmlstream import XMLStream

from user import UserHandler
from config import filename, config

class ObjectComponent(ComponentXMPP):

    def __init__(self, jid, secret, server, port, root):
        ComponentXMPP.__init__(self, jid, secret, server, port)
        self.register_plugin('xep_0030')
        self.register_plugin("AliasPlugin", module = "plugin")
        self.add_event_handler("session_start", self.start)
        self.add_event_handler("presence_probe", self.presence_probe)
        self.add_event_handler("message", self.message)
        self.add_event_handler("changed_subscription", self.presence_subscription)
        self.userHandler = UserHandler(root)

    def start(self, event):
        for user in self.userHandler.get_user_list():
            self.send_presence(pto = user)

    def disconnect(self, reconnect = False):
        for user in self.userHandler.get_user_list():
            self.send_presence(pto = user, ptype = "unavailable")
        XMLStream.disconnect(self, reconnect)
        logging.info('Component {} disconnected'.format(self.boundjid.bare))

    def message(self, msg):
        msg.reply("Thanks for sending\n{[body]}".format(msg)).send()

    def presence_subscription(self, subscription):
        if subscription["type"] == "subscribe":
            userJID = subscription["from"].full
            self.userHandler.register(userJID)
            subscription.reply().send()
            self.send_presence(pto = userJID)
            self.send_presence_subscription(pto = userJID, ptype = "subscribe")
        if subscription["type"] == "unsubscribe":
            userJID = subscription["from"].full
            self.userHandler.unregister(userJID)

    def presence_probe(self, event):
        self.send_presence(pto = event["from"].full)


if __name__ == '__main__':
    commandline = ArgumentParser(description = 'Connect the alias \
                                component to a given server')
    commandline.add_argument('-p', '--port',
                             help = 'Port to connect to',
                             type = int)
    commandline.add_argument('-s', '--secret',
                             help = 'password')
    commandline.add_argument('-n', '--name',
                             help = 'Name the component will have')
    commandline.add_argument('-r', '--root',
                             help = 'Root directory of the user files')
    commandline.add_argument('-c', '--config',
                             help = 'Name of the config file to use')
    commandline.add_argument('-d', '--debug',
                             help = 'Set log level to DEBUG',
                             action = 'store_const',
                             const = logging.DEBUG,
                             default = logging.INFO)
    commandline.add_argument('-o', '--host',
                             help = 'Host to connect to')

    args = commandline.parse_args()

    if args.config is None:
        logging.basicConfig(level = args.debug)
        config.name = args.name
        config.port = args.port
        config.secret = args.secret
        config.root = args.root
        config.host = args.host
    else:
        filename = args.config
        logging.basicConfig(level = args.debug)
        config.read(filename)

    component = ObjectComponent(config.name, config.secret,
                                config.host, config.port,
                                config.root)

    if component.connect():
        logging.info('Component {} connected'.format(component.boundjid))
        component.process(False)
    else :
        print "Couldn't connect"