summaryrefslogtreecommitdiff
path: root/sleekxmpp/plugins/xep_0048
diff options
context:
space:
mode:
Diffstat (limited to 'sleekxmpp/plugins/xep_0048')
-rw-r--r--sleekxmpp/plugins/xep_0048/__init__.py15
-rw-r--r--sleekxmpp/plugins/xep_0048/bookmarks.py76
-rw-r--r--sleekxmpp/plugins/xep_0048/stanza.py65
3 files changed, 0 insertions, 156 deletions
diff --git a/sleekxmpp/plugins/xep_0048/__init__.py b/sleekxmpp/plugins/xep_0048/__init__.py
deleted file mode 100644
index 2c98d061..00000000
--- a/sleekxmpp/plugins/xep_0048/__init__.py
+++ /dev/null
@@ -1,15 +0,0 @@
-"""
- SleekXMPP: The Sleek XMPP Library
- Copyright (C) 2013 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_0048.stanza import Bookmarks, Conference, URL
-from sleekxmpp.plugins.xep_0048.bookmarks import XEP_0048
-
-
-register_plugin(XEP_0048)
diff --git a/sleekxmpp/plugins/xep_0048/bookmarks.py b/sleekxmpp/plugins/xep_0048/bookmarks.py
deleted file mode 100644
index 0bb5ae38..00000000
--- a/sleekxmpp/plugins/xep_0048/bookmarks.py
+++ /dev/null
@@ -1,76 +0,0 @@
-"""
- SleekXMPP: The Sleek XMPP Library
- Copyright (C) 2013 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 Iq
-from sleekxmpp.plugins import BasePlugin
-from sleekxmpp.exceptions import XMPPError
-from sleekxmpp.xmlstream.handler import Callback
-from sleekxmpp.xmlstream.matcher import StanzaPath
-from sleekxmpp.xmlstream import register_stanza_plugin
-from sleekxmpp.plugins.xep_0048 import stanza, Bookmarks, Conference, URL
-
-
-log = logging.getLogger(__name__)
-
-
-class XEP_0048(BasePlugin):
-
- name = 'xep_0048'
- description = 'XEP-0048: Bookmarks'
- dependencies = set(['xep_0045', 'xep_0049', 'xep_0060', 'xep_0163', 'xep_0223'])
- stanza = stanza
- default_config = {
- 'auto_join': False,
- 'storage_method': 'xep_0049'
- }
-
- def plugin_init(self):
- register_stanza_plugin(self.xmpp['xep_0060'].stanza.Item, Bookmarks)
-
- self.xmpp['xep_0049'].register(Bookmarks)
- self.xmpp['xep_0163'].register_pep('bookmarks', Bookmarks)
-
- self.xmpp.add_event_handler('session_start', self._autojoin)
-
- def plugin_end(self):
- self.xmpp.del_event_handler('session_start', self._autojoin)
-
- def _autojoin(self, __):
- if not self.auto_join:
- return
-
- try:
- result = self.get_bookmarks(method=self.storage_method)
- except XMPPError:
- return
-
- if self.storage_method == 'xep_0223':
- bookmarks = result['pubsub']['items']['item']['bookmarks']
- else:
- bookmarks = result['private']['bookmarks']
-
- for conf in bookmarks['conferences']:
- if conf['autojoin']:
- log.debug('Auto joining %s as %s', conf['jid'], conf['nick'])
- self.xmpp['xep_0045'].joinMUC(conf['jid'], conf['nick'],
- password=conf['password'])
-
- def set_bookmarks(self, bookmarks, method=None, **iqargs):
- if not method:
- method = self.storage_method
- return self.xmpp[method].store(bookmarks, **iqargs)
-
- def get_bookmarks(self, method=None, **iqargs):
- if not method:
- method = self.storage_method
-
- loc = 'storage:bookmarks' if method == 'xep_0223' else 'bookmarks'
-
- return self.xmpp[method].retrieve(loc, **iqargs)
diff --git a/sleekxmpp/plugins/xep_0048/stanza.py b/sleekxmpp/plugins/xep_0048/stanza.py
deleted file mode 100644
index 21829392..00000000
--- a/sleekxmpp/plugins/xep_0048/stanza.py
+++ /dev/null
@@ -1,65 +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 ET, ElementBase, register_stanza_plugin
-
-
-class Bookmarks(ElementBase):
- name = 'storage'
- namespace = 'storage:bookmarks'
- plugin_attrib = 'bookmarks'
- interfaces = set()
-
- def add_conference(self, jid, nick, name=None, autojoin=None, password=None):
- conf = Conference()
- conf['jid'] = jid
- conf['nick'] = nick
- if name is None:
- name = jid
- conf['name'] = name
- conf['autojoin'] = autojoin
- conf['password'] = password
- self.append(conf)
-
- def add_url(self, url, name=None):
- saved_url = URL()
- saved_url['url'] = url
- if name is None:
- name = url
- saved_url['name'] = name
- self.append(saved_url)
-
-
-class Conference(ElementBase):
- name = 'conference'
- namespace = 'storage:bookmarks'
- plugin_attrib = 'conference'
- plugin_multi_attrib = 'conferences'
- interfaces = set(['nick', 'password', 'autojoin', 'jid', 'name'])
- sub_interfaces = set(['nick', 'password'])
-
- def get_autojoin(self):
- value = self._get_attr('autojoin')
- return value in ('1', 'true')
-
- def set_autojoin(self, value):
- del self['autojoin']
- if value in ('1', 'true', True):
- self._set_attr('autojoin', 'true')
-
-
-class URL(ElementBase):
- name = 'url'
- namespace = 'storage:bookmarks'
- plugin_attrib = 'url'
- plugin_multi_attrib = 'urls'
- interfaces = set(['url', 'name'])
-
-
-register_stanza_plugin(Bookmarks, Conference, iterable=True)
-register_stanza_plugin(Bookmarks, URL, iterable=True)