Mercurial > libervia-backend
diff plugins/plugin_xep_0100.py @ 25:53e921c8a357
new plugin: gateways plugin, and first implementation of findGateways
- test menu in Wix
- new actionResultExt method, for sending dictionary of dictionaries
- new getNextId method, for accessing sat ids from plugins.
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 04 Dec 2009 08:47:44 +0100 |
parents | |
children | d6b613764dd7 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/plugins/plugin_xep_0100.py Fri Dec 04 08:47:44 2009 +0100 @@ -0,0 +1,86 @@ +#!/usr/bin/python +# -*- coding: utf-8 -*- + +""" +SAT plugin for managing gateways (xep-0100) +Copyright (C) 2009 Jérôme Poisson (goffi@goffi.org) + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 3 of the License, or +(at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program. If not, see <http://www.gnu.org/licenses/>. +""" + +from logging import debug, info, error +from twisted.internet import protocol +from twisted.words.protocols.jabber import client, jid, xmlstream, error +import pdb + +from wokkel import disco, iwokkel + +PLUGIN_INFO = { +"name": "Gateways Plugin", +"import_name": "XEP_0100", +"type": "XEP", +"dependencies": [], +"main": "XEP_0100", +"description": """Implementation of Gateways protocol""" +} + +class XEP_0100(): + + def __init__(self, host): + info("Gateways plugin initialization") + self.host = host + self.__gateways = {} #dict used to construct the answer to findGateways. Key = target jid + host.bridge.addMethod("findGateways", ".communication", in_sign='s', out_sign='s', method=self.findGateways) + + def discoInfo(self, disco, entity, request_id): + """Find disco infos about entity, to check if it is a gateway""" + + for identity in disco.identities: + if identity[0] == 'gateway': + print ("Found gateway (%s): %s" % (entity, disco.identities[identity])) + self.__gateways[request_id][entity.full()] = { + 'name':disco.identities[identity], + 'type':identity[1] + } + + self.__gateways[request_id]['__handled_items']+=1 + + if self.__gateways[request_id]['__total_items'] == self.__gateways[request_id]['__handled_items']: + debug ("All items checked for id [%s]" % str(request_id)) + + del self.__gateways[request_id]['__total_items'] + del self.__gateways[request_id]['__handled_items'] + self.host.actionResultExt(request_id,"DICT_DICT",self.__gateways[request_id]) + + def discoItems(self, disco, request_id): + """Look for items with disco protocol, and ask infos for each one""" + + if len(disco._items) == 0: + debug ("No gateway found") + self.host.actionResultExt(request_id,"DICT_DICT",{}) + return + + self.__gateways[request_id] = {'__total_items':len(disco._items), '__handled_items':0} + for item in disco._items: + debug ("item found: %s", item.name) + self.host.disco.requestInfo(item.entity).addCallback(self.discoInfo, entity=item.entity, request_id=request_id) + + def findGateways(self, target): + """Find gateways in the target JID, using discovery protocol + Return an id used for retrieving the list of gateways + """ + debug ("find gateways (target = %s)" % target) + request_id = self.host.get_next_id() + self.host.disco.requestItems(jid.JID(target)).addCallback(self.discoItems, request_id=request_id) + return request_id