summaryrefslogtreecommitdiff
path: root/sleekxmpp/plugins/xep_0033
diff options
context:
space:
mode:
Diffstat (limited to 'sleekxmpp/plugins/xep_0033')
-rw-r--r--sleekxmpp/plugins/xep_0033/__init__.py20
-rw-r--r--sleekxmpp/plugins/xep_0033/addresses.py37
-rw-r--r--sleekxmpp/plugins/xep_0033/stanza.py131
3 files changed, 0 insertions, 188 deletions
diff --git a/sleekxmpp/plugins/xep_0033/__init__.py b/sleekxmpp/plugins/xep_0033/__init__.py
deleted file mode 100644
index ba8152c4..00000000
--- a/sleekxmpp/plugins/xep_0033/__init__.py
+++ /dev/null
@@ -1,20 +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 permission.
-"""
-
-from sleekxmpp.plugins.base import register_plugin
-
-from sleekxmpp.plugins.xep_0033 import stanza
-from sleekxmpp.plugins.xep_0033.stanza import Addresses, Address
-from sleekxmpp.plugins.xep_0033.addresses import XEP_0033
-
-
-register_plugin(XEP_0033)
-
-# Retain some backwards compatibility
-xep_0033 = XEP_0033
-Addresses.addAddress = Addresses.add_address
diff --git a/sleekxmpp/plugins/xep_0033/addresses.py b/sleekxmpp/plugins/xep_0033/addresses.py
deleted file mode 100644
index 13cb7267..00000000
--- a/sleekxmpp/plugins/xep_0033/addresses.py
+++ /dev/null
@@ -1,37 +0,0 @@
-"""
- SleekXMPP: The Sleek XMPP Library
- Copyright (C) 2010 Nathanael C. Fritz, Lance J.T. Stout
- This file is part of SleekXMPP.
-
- See the file LICENSE for copying permission.
-"""
-
-import logging
-
-from sleekxmpp import Message, Presence
-from sleekxmpp.xmlstream import register_stanza_plugin
-from sleekxmpp.plugins import BasePlugin
-from sleekxmpp.plugins.xep_0033 import stanza, Addresses
-
-
-class XEP_0033(BasePlugin):
-
- """
- XEP-0033: Extended Stanza Addressing
- """
-
- name = 'xep_0033'
- description = 'XEP-0033: Extended Stanza Addressing'
- dependencies = set(['xep_0030'])
- stanza = stanza
-
- def plugin_init(self):
- register_stanza_plugin(Message, Addresses)
- register_stanza_plugin(Presence, Addresses)
-
- def plugin_end(self):
- self.xmpp['xep_0030'].del_feature(feature=Addresses.namespace)
-
- def session_bind(self, jid):
- self.xmpp['xep_0030'].add_feature(Addresses.namespace)
-
diff --git a/sleekxmpp/plugins/xep_0033/stanza.py b/sleekxmpp/plugins/xep_0033/stanza.py
deleted file mode 100644
index 1ff9fb20..00000000
--- a/sleekxmpp/plugins/xep_0033/stanza.py
+++ /dev/null
@@ -1,131 +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 permission.
-"""
-
-from sleekxmpp.xmlstream import JID, ElementBase, ET, register_stanza_plugin
-
-
-class Addresses(ElementBase):
-
- name = 'addresses'
- namespace = 'http://jabber.org/protocol/address'
- plugin_attrib = 'addresses'
- interfaces = set()
-
- def add_address(self, atype='to', jid='', node='', uri='',
- desc='', delivered=False):
- addr = Address(parent=self)
- addr['type'] = atype
- addr['jid'] = jid
- addr['node'] = node
- addr['uri'] = uri
- addr['desc'] = desc
- addr['delivered'] = delivered
-
- return addr
-
- # Additional methods for manipulating sets of addresses
- # based on type are generated below.
-
-
-class Address(ElementBase):
-
- name = 'address'
- namespace = 'http://jabber.org/protocol/address'
- plugin_attrib = 'address'
- interfaces = set(['type', 'jid', 'node', 'uri', 'desc', 'delivered'])
-
- address_types = set(('bcc', 'cc', 'noreply', 'replyroom', 'replyto', 'to'))
-
- def get_jid(self):
- return JID(self._get_attr('jid'))
-
- def set_jid(self, value):
- self._set_attr('jid', str(value))
-
- def get_delivered(self):
- value = self._get_attr('delivered', False)
- return value and value.lower() in ('true', '1')
-
- def set_delivered(self, delivered):
- if delivered:
- self._set_attr('delivered', 'true')
- else:
- del self['delivered']
-
- def set_uri(self, uri):
- if uri:
- del self['jid']
- del self['node']
- self._set_attr('uri', uri)
- else:
- self._del_attr('uri')
-
-
-# =====================================================================
-# Auto-generate address type filters for the Addresses class.
-
-def _addr_filter(atype):
- def _type_filter(addr):
- if isinstance(addr, Address):
- if atype == 'all' or addr['type'] == atype:
- return True
- return False
- return _type_filter
-
-
-def _build_methods(atype):
-
- def get_multi(self):
- return list(filter(_addr_filter(atype), self))
-
- def set_multi(self, value):
- del self[atype]
- for addr in value:
-
- # Support assigning dictionary versions of addresses
- # instead of full Address objects.
- if not isinstance(addr, Address):
- if atype != 'all':
- addr['type'] = atype
- elif 'atype' in addr and 'type' not in addr:
- addr['type'] = addr['atype']
- addrObj = Address()
- addrObj.values = addr
- addr = addrObj
-
- self.append(addr)
-
- def del_multi(self):
- res = list(filter(_addr_filter(atype), self))
- for addr in res:
- self.iterables.remove(addr)
- self.xml.remove(addr.xml)
-
- return get_multi, set_multi, del_multi
-
-
-for atype in ('all', 'bcc', 'cc', 'noreply', 'replyroom', 'replyto', 'to'):
- get_multi, set_multi, del_multi = _build_methods(atype)
-
- Addresses.interfaces.add(atype)
- setattr(Addresses, "get_%s" % atype, get_multi)
- setattr(Addresses, "set_%s" % atype, set_multi)
- setattr(Addresses, "del_%s" % atype, del_multi)
-
- # To retain backwards compatibility:
- setattr(Addresses, "get%s" % atype.title(), get_multi)
- setattr(Addresses, "set%s" % atype.title(), set_multi)
- setattr(Addresses, "del%s" % atype.title(), del_multi)
- if atype == 'all':
- Addresses.interfaces.add('addresses')
- setattr(Addresses, "getAddresses", get_multi)
- setattr(Addresses, "setAddresses", set_multi)
- setattr(Addresses, "delAddresses", del_multi)
-
-
-register_stanza_plugin(Addresses, Address, iterable=True)