slixmpp/sleekxmpp/features/feature_session/session.py

55 lines
1.4 KiB
Python
Raw Normal View History

2011-06-30 22:40:22 +00:00
"""
SleekXMPP: The Sleek XMPP Library
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
from sleekxmpp.stanza import Iq, StreamFeatures
from sleekxmpp.xmlstream import register_stanza_plugin
2012-03-13 02:52:20 +00:00
from sleekxmpp.plugins import BasePlugin
2011-06-30 22:40:22 +00:00
from sleekxmpp.features.feature_session import stanza
2011-06-30 22:40:22 +00:00
log = logging.getLogger(__name__)
2012-03-13 02:52:20 +00:00
class FeatureSession(BasePlugin):
2011-06-30 22:40:22 +00:00
2012-03-13 02:52:20 +00:00
name = 'feature_session'
description = 'RFC 3920: Stream Feature: Start Session'
dependencies = set()
stanza = stanza
2011-06-30 22:40:22 +00:00
2012-03-13 02:52:20 +00:00
def plugin_init(self):
2011-06-30 22:40:22 +00:00
self.xmpp.register_feature('session',
self._handle_start_session,
restart=False,
order=10001)
register_stanza_plugin(Iq, stanza.Session)
register_stanza_plugin(StreamFeatures, stanza.Session)
2011-06-30 22:40:22 +00:00
def _handle_start_session(self, features):
"""
Handle the start of the session.
Arguments:
feature -- The stream features element.
"""
iq = self.xmpp.Iq()
iq['type'] = 'set'
iq.enable('session')
2012-02-17 22:59:56 +00:00
iq.send(now=True)
2011-06-30 22:40:22 +00:00
self.xmpp.features.add('session')
2011-06-30 22:40:22 +00:00
log.debug("Established Session")
self.xmpp.sessionstarted = True
self.xmpp.session_started_event.set()
self.xmpp.event("session_start")