aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--plugin.py32
-rw-r--r--server.py4
2 files changed, 35 insertions, 1 deletions
diff --git a/plugin.py b/plugin.py
new file mode 100644
index 0000000..a88d244
--- /dev/null
+++ b/plugin.py
@@ -0,0 +1,32 @@
+from sleekxmpp.xmlstream.stanzabase import ElementBase, registerStanzaPlugin
+from sleekxmpp.plugins import base
+from sleekxmpp.xmlstream.handler.callback import Callback
+from sleekxmpp.xmlstream.matcher.xpath import MatchXPath
+from sleekxmpp.stanza.iq import Iq
+import logging
+
+class AliasQuery(ElementBase) :
+ namespace = 'alias:query'
+ name = 'query'
+ plugin_attrib = 'query'
+ interfaces = set(('node', 'type', 'items','object'))
+ sub_interfaces = set(('items'))
+
+
+class AliasPlugin(base.base_plugin) :
+
+ def plugin_init(self) :
+ self.description = 'Plugin to handle alias queries'
+ registerStanzaPlugin(Iq, AliasQuery)
+
+ self.xmpp.registerHandler(
+ Callback('Alias queries',
+ MatchXPath('{%s}iq/{%s}query' % (self.xmpp.default_ns,
+ AliasQuery.namespace)),
+ self.handle_alias_query))
+
+ def handle_alias_query(self, iq) :
+ iq.reply().send()
+
+
+
diff --git a/server.py b/server.py
index a19bb1e..1ecf779 100644
--- a/server.py
+++ b/server.py
@@ -8,6 +8,7 @@ class ObjectComponent(ComponentXMPP):
def __init__(self, jid, secret, server, port, root):
ComponentXMPP.__init__(self, jid, secret, server, port)
+ self.register_plugin("AliasPlugin", module = "plugin" )
self.add_event_handler("session_start", self.start)
self.add_event_handler("presence_probe", self.presenceProbe)
self.add_event_handler("message", self.message)
@@ -22,6 +23,7 @@ class ObjectComponent(ComponentXMPP):
for user in self.userHandler.getUserList() :
self.sendPresence(pto = user, ptype = "unavailable")
XMLStream.disconnect(self, reconnect)
+ logging.info('Component %s disconnected' % self.boundjid.bare)
def message(self, msg):
msg.reply("Thanks for sending\n%(body)s" % msg).send()
@@ -64,7 +66,7 @@ if __name__ == '__main__' :
component = ObjectComponent(args.name, args.secret, args.host, args.port, args.root)
if component.connect() :
- print 'Component', args.name, 'connected to', args.host + ':' + str(args.port)
+ logging.info('Component %s connected' % args.name )
component.process(False)
else :
print "Couldn't connect"