2011-06-30 22:40:22 +00:00
|
|
|
"""
|
|
|
|
SleekXMPP: The Sleek XMPP Library
|
2011-07-03 05:49:34 +00:00
|
|
|
Copyright (C) 2011 Nathanael C. Fritz
|
2011-06-30 22:40:22 +00:00
|
|
|
This file is part of SleekXMPP.
|
|
|
|
|
|
|
|
See the file LICENSE for copying permission.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import logging
|
|
|
|
|
2011-07-01 21:45:55 +00:00
|
|
|
from sleekxmpp.stanza import Iq, StreamFeatures
|
|
|
|
from sleekxmpp.features.feature_bind import stanza
|
|
|
|
from sleekxmpp.xmlstream import register_stanza_plugin
|
2011-06-30 22:40:22 +00:00
|
|
|
from sleekxmpp.plugins.base import base_plugin
|
|
|
|
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class feature_bind(base_plugin):
|
|
|
|
|
|
|
|
def plugin_init(self):
|
|
|
|
self.name = 'Bind Resource'
|
|
|
|
self.rfc = '6120'
|
|
|
|
self.description = 'Resource Binding Stream Feature'
|
2011-07-01 21:45:55 +00:00
|
|
|
self.stanza = stanza
|
2011-06-30 22:40:22 +00:00
|
|
|
|
|
|
|
self.xmpp.register_feature('bind',
|
|
|
|
self._handle_bind_resource,
|
|
|
|
restart=False,
|
|
|
|
order=10000)
|
|
|
|
|
2011-07-01 21:45:55 +00:00
|
|
|
register_stanza_plugin(Iq, stanza.Bind)
|
|
|
|
register_stanza_plugin(StreamFeatures, stanza.Bind)
|
|
|
|
|
2011-06-30 22:40:22 +00:00
|
|
|
def _handle_bind_resource(self, features):
|
|
|
|
"""
|
|
|
|
Handle requesting a specific resource.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
features -- The stream features stanza.
|
|
|
|
"""
|
2011-11-19 20:07:57 +00:00
|
|
|
log.debug("Requesting resource: %s", self.xmpp.boundjid.resource)
|
2011-06-30 22:40:22 +00:00
|
|
|
iq = self.xmpp.Iq()
|
|
|
|
iq['type'] = 'set'
|
|
|
|
iq.enable('bind')
|
|
|
|
if self.xmpp.boundjid.resource:
|
|
|
|
iq['bind']['resource'] = self.xmpp.boundjid.resource
|
|
|
|
response = iq.send(now=True)
|
|
|
|
|
|
|
|
self.xmpp.set_jid(response['bind']['jid'])
|
|
|
|
self.xmpp.bound = True
|
2012-01-07 04:30:14 +00:00
|
|
|
self.xmpp.event('session_bind', self.xmpp.boundjid, direct=True)
|
2011-06-30 22:40:22 +00:00
|
|
|
|
2011-07-03 06:09:29 +00:00
|
|
|
self.xmpp.features.add('bind')
|
2011-07-03 05:30:34 +00:00
|
|
|
|
2011-11-19 20:07:57 +00:00
|
|
|
log.info("Node set to: %s", self.xmpp.boundjid.full)
|
2011-06-30 22:40:22 +00:00
|
|
|
|
|
|
|
if 'session' not in features['features']:
|
|
|
|
log.debug("Established Session")
|
|
|
|
self.xmpp.sessionstarted = True
|
|
|
|
self.xmpp.session_started_event.set()
|
|
|
|
self.xmpp.event("session_start")
|