summaryrefslogtreecommitdiff
path: root/sleekxmpp/plugins/xep_0013
diff options
context:
space:
mode:
Diffstat (limited to 'sleekxmpp/plugins/xep_0013')
-rw-r--r--sleekxmpp/plugins/xep_0013/__init__.py15
-rw-r--r--sleekxmpp/plugins/xep_0013/offline.py134
-rw-r--r--sleekxmpp/plugins/xep_0013/stanza.py53
3 files changed, 0 insertions, 202 deletions
diff --git a/sleekxmpp/plugins/xep_0013/__init__.py b/sleekxmpp/plugins/xep_0013/__init__.py
deleted file mode 100644
index ad400949..00000000
--- a/sleekxmpp/plugins/xep_0013/__init__.py
+++ /dev/null
@@ -1,15 +0,0 @@
-"""
- SleekXMPP: The Sleek XMPP Library
- Copyright (C) 2012 Nathanael C. Fritz, Lance J.T. Stout
- This file is part of SleekXMPP.
-
- See the file LICENSE for copying permissio
-"""
-
-from sleekxmpp.plugins.base import register_plugin
-
-from sleekxmpp.plugins.xep_0013.stanza import Offline
-from sleekxmpp.plugins.xep_0013.offline import XEP_0013
-
-
-register_plugin(XEP_0013)
diff --git a/sleekxmpp/plugins/xep_0013/offline.py b/sleekxmpp/plugins/xep_0013/offline.py
deleted file mode 100644
index a0d992a7..00000000
--- a/sleekxmpp/plugins/xep_0013/offline.py
+++ /dev/null
@@ -1,134 +0,0 @@
-"""
- SleekXMPP: The Sleek XMPP Library
- Copyright (C) 2012 Nathanael C. Fritz, Lance J.T. Stout
- This file is part of SleekXMPP.
-
- See the file LICENSE for copying permissio
-"""
-
-import logging
-
-import sleekxmpp
-from sleekxmpp.stanza import Message, Iq
-from sleekxmpp.exceptions import XMPPError
-from sleekxmpp.xmlstream.handler import Collector
-from sleekxmpp.xmlstream.matcher import StanzaPath
-from sleekxmpp.xmlstream import register_stanza_plugin
-from sleekxmpp.plugins import BasePlugin
-from sleekxmpp.plugins.xep_0013 import stanza
-
-
-log = logging.getLogger(__name__)
-
-
-class XEP_0013(BasePlugin):
-
- """
- XEP-0013 Flexible Offline Message Retrieval
- """
-
- name = 'xep_0013'
- description = 'XEP-0013: Flexible Offline Message Retrieval'
- dependencies = set(['xep_0030'])
- stanza = stanza
-
- def plugin_init(self):
- register_stanza_plugin(Iq, stanza.Offline)
- register_stanza_plugin(Message, stanza.Offline)
-
- def get_count(self, **kwargs):
- return self.xmpp['xep_0030'].get_info(
- node='http://jabber.org/protocol/offline',
- local=False,
- **kwargs)
-
- def get_headers(self, **kwargs):
- return self.xmpp['xep_0030'].get_items(
- node='http://jabber.org/protocol/offline',
- local=False,
- **kwargs)
-
- def view(self, nodes, ifrom=None, block=True, timeout=None, callback=None):
- if not isinstance(nodes, (list, set)):
- nodes = [nodes]
-
- iq = self.xmpp.Iq()
- iq['type'] = 'get'
- iq['from'] = ifrom
- offline = iq['offline']
- for node in nodes:
- item = stanza.Item()
- item['node'] = node
- item['action'] = 'view'
- offline.append(item)
-
- collector = Collector(
- 'Offline_Results_%s' % iq['id'],
- StanzaPath('message/offline'))
- self.xmpp.register_handler(collector)
-
- if not block and callback is not None:
- def wrapped_cb(iq):
- results = collector.stop()
- if iq['type'] == 'result':
- iq['offline']['results'] = results
- callback(iq)
- return iq.send(block=block, timeout=timeout, callback=wrapped_cb)
- else:
- try:
- resp = iq.send(block=block, timeout=timeout, callback=callback)
- resp['offline']['results'] = collector.stop()
- return resp
- except XMPPError as e:
- collector.stop()
- raise e
-
- def remove(self, nodes, ifrom=None, block=True, timeout=None, callback=None):
- if not isinstance(nodes, (list, set)):
- nodes = [nodes]
-
- iq = self.xmpp.Iq()
- iq['type'] = 'set'
- iq['from'] = ifrom
- offline = iq['offline']
- for node in nodes:
- item = stanza.Item()
- item['node'] = node
- item['action'] = 'remove'
- offline.append(item)
-
- return iq.send(block=block, timeout=timeout, callback=callback)
-
- def fetch(self, ifrom=None, block=True, timeout=None, callback=None):
- iq = self.xmpp.Iq()
- iq['type'] = 'set'
- iq['from'] = ifrom
- iq['offline']['fetch'] = True
-
- collector = Collector(
- 'Offline_Results_%s' % iq['id'],
- StanzaPath('message/offline'))
- self.xmpp.register_handler(collector)
-
- if not block and callback is not None:
- def wrapped_cb(iq):
- results = collector.stop()
- if iq['type'] == 'result':
- iq['offline']['results'] = results
- callback(iq)
- return iq.send(block=block, timeout=timeout, callback=wrapped_cb)
- else:
- try:
- resp = iq.send(block=block, timeout=timeout, callback=callback)
- resp['offline']['results'] = collector.stop()
- return resp
- except XMPPError as e:
- collector.stop()
- raise e
-
- def purge(self, ifrom=None, block=True, timeout=None, callback=None):
- iq = self.xmpp.Iq()
- iq['type'] = 'set'
- iq['from'] = ifrom
- iq['offline']['purge'] = True
- return iq.send(block=block, timeout=timeout, callback=callback)
diff --git a/sleekxmpp/plugins/xep_0013/stanza.py b/sleekxmpp/plugins/xep_0013/stanza.py
deleted file mode 100644
index c9c69786..00000000
--- a/sleekxmpp/plugins/xep_0013/stanza.py
+++ /dev/null
@@ -1,53 +0,0 @@
-"""
- SleekXMPP: The Sleek XMPP Library
- Copyright (C) 2012 Nathanael C. Fritz, Lance J.T. Stout
- This file is part of SleekXMPP.
-
- See the file LICENSE for copying permissio
-"""
-
-from sleekxmpp.jid import JID
-from sleekxmpp.xmlstream import ElementBase, register_stanza_plugin
-
-
-class Offline(ElementBase):
- name = 'offline'
- namespace = 'http://jabber.org/protocol/offline'
- plugin_attrib = 'offline'
- interfaces = set(['fetch', 'purge', 'results'])
- bool_interfaces = interfaces
-
- def setup(self, xml=None):
- ElementBase.setup(self, xml)
- self._results = []
-
- # The results interface is meant only as an easy
- # way to access the set of collected message responses
- # from the query.
-
- def get_results(self):
- return self._results
-
- def set_results(self, values):
- self._results = values
-
- def del_results(self):
- self._results = []
-
-
-class Item(ElementBase):
- name = 'item'
- namespace = 'http://jabber.org/protocol/offline'
- plugin_attrib = 'item'
- interfaces = set(['action', 'node', 'jid'])
-
- actions = set(['view', 'remove'])
-
- def get_jid(self):
- return JID(self._get_attr('jid'))
-
- def set_jid(self, value):
- self._set_attr('jid', str(value))
-
-
-register_stanza_plugin(Offline, Item, iterable=True)