Mercurial > libervia-backend
annotate src/plugins/plugin_xep_0049.py @ 991:05e02f8b7eb4
core: logging refactoring, first step:
- added a core.log module
- 3 backends can be used: basic, standard (python's logging module) or twisted
- colors can be used
- the module has been made to be used by frontends, it should work in exotic environments like pyjamas
- logging basic configuration is now made in sat.tac
- core.log configuration is inspired from python standard logging, and use it when possible
- getLogger should be used the same way as for standard logging
author | Goffi <goffi@goffi.org> |
---|---|
date | Sat, 19 Apr 2014 00:02:38 +0200 |
parents | 93359853e4bc |
children | 301b342c697a |
rev | line source |
---|---|
980 | 1 #!/usr/bin/python |
2 # -*- coding: utf-8 -*- | |
3 | |
4 # SAT plugin for managing xep-0049 | |
5 # Copyright (C) 2009, 2010, 2011, 2012, 2013, 2014 Jérôme Poisson (goffi@goffi.org) | |
6 | |
7 # This program is free software: you can redistribute it and/or modify | |
8 # it under the terms of the GNU Affero General Public License as published by | |
9 # the Free Software Foundation, either version 3 of the License, or | |
10 # (at your option) any later version. | |
11 | |
12 # This program is distributed in the hope that it will be useful, | |
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 # GNU Affero General Public License for more details. | |
16 | |
17 # You should have received a copy of the GNU Affero General Public License | |
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. | |
19 | |
20 from sat.core.i18n import _ | |
21 from logging import debug, info, error, warning | |
22 from wokkel import compat | |
23 from twisted.words.xish import domish | |
24 | |
25 | |
26 | |
27 PLUGIN_INFO = { | |
28 "name": "XEP-0049 Plugin", | |
29 "import_name": "XEP-0049", | |
30 "type": "XEP", | |
31 "protocols": ["XEP-0049"], | |
32 "dependencies": [], | |
33 "main": "XEP_0049", | |
34 "handler": "no", | |
35 "description": _("""Implementation of private XML storage""") | |
36 } | |
37 | |
38 | |
39 class XEP_0049(object): | |
40 NS_PRIVATE = 'jabber:iq:private' | |
41 | |
42 def __init__(self, host): | |
43 info(_("Plugin XEP-0049 initialization")) | |
44 self.host = host | |
45 | |
46 def privateXMLStore(self, element, profile_key): | |
47 """Store private data | |
48 @param element: domish.Element to store (must have a namespace) | |
49 @param profile_key: %(doc_profile_key)s | |
50 | |
51 """ | |
52 assert isinstance(element, domish.Element) | |
53 client = self.host.getClient(profile_key) | |
989
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
54 # XXX: feature announcement in disco#info is not mandatory in XEP-0049, so we have to try to use private XML, and react according to the answer |
980 | 55 iq_elt = compat.IQ(client.xmlstream) |
56 query_elt = iq_elt.addElement('query', XEP_0049.NS_PRIVATE) | |
57 query_elt.addChild(element) | |
989
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
58 return iq_elt.send() |
980 | 59 |
60 def privateXMLGet(self, node_name, namespace, profile_key): | |
61 """Store private data | |
62 @param node_name: name of the node to get | |
63 @param namespace: namespace of the node to get | |
64 @param profile_key: %(doc_profile_key)s | |
65 @return (domish.Element): a deferred which fire the stored data | |
66 | |
67 """ | |
68 client = self.host.getClient(profile_key) | |
989
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
69 # XXX: see privateXMLStore note about feature checking |
980 | 70 iq_elt = compat.IQ(client.xmlstream, 'get') |
71 query_elt = iq_elt.addElement('query', XEP_0049.NS_PRIVATE) | |
72 query_elt.addElement(node_name, namespace) | |
989
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
73 def getCb(answer_iq_elt): |
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
74 answer_query_elt = answer_iq_elt.elements(XEP_0049.NS_PRIVATE, 'query').next() |
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
75 return answer_query_elt.firstChildElement() |
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
76 d = iq_elt.send() |
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
77 d.addCallback(getCb) |
93359853e4bc
plugins XEP-0048, XEP-0049: feature is not checked anymore before using private XML storage, as feature announcement is not mandatory in XEP-0049
Goffi <goffi@goffi.org>
parents:
980
diff
changeset
|
78 return d |
980 | 79 |