mirror of
https://github.com/correl/SleekXMPP.git
synced 2024-11-27 19:19:54 +00:00
Merge branch 'develop' of git://github.com/fritzy/SleekXMPP into develop
This commit is contained in:
commit
6469cdb4ca
2 changed files with 52 additions and 2 deletions
|
@ -66,6 +66,8 @@ class ClientXMPP(basexmpp, XMLStream):
|
||||||
#TODO: Use stream state here
|
#TODO: Use stream state here
|
||||||
self.authenticated = False
|
self.authenticated = False
|
||||||
self.sessionstarted = False
|
self.sessionstarted = False
|
||||||
|
self.bound = False
|
||||||
|
self.bindfail = False
|
||||||
self.registerHandler(Callback('Stream Features', MatchXPath('{http://etherx.jabber.org/streams}features'), self._handleStreamFeatures, thread=True))
|
self.registerHandler(Callback('Stream Features', MatchXPath('{http://etherx.jabber.org/streams}features'), self._handleStreamFeatures, thread=True))
|
||||||
self.registerHandler(Callback('Roster Update', MatchXPath('{%s}iq/{jabber:iq:roster}query' % self.default_ns), self._handleRoster, thread=True))
|
self.registerHandler(Callback('Roster Update', MatchXPath('{%s}iq/{jabber:iq:roster}query' % self.default_ns), self._handleRoster, thread=True))
|
||||||
#self.registerHandler(Callback('Roster Update', MatchXMLMask("<presence xmlns='%s' type='subscribe' />" % self.default_ns), self._handlePresenceSubscribe, thread=True))
|
#self.registerHandler(Callback('Roster Update', MatchXMLMask("<presence xmlns='%s' type='subscribe' />" % self.default_ns), self._handlePresenceSubscribe, thread=True))
|
||||||
|
@ -221,19 +223,23 @@ class ClientXMPP(basexmpp, XMLStream):
|
||||||
response = iq.send()
|
response = iq.send()
|
||||||
#response = self.send(iq, self.Iq(sid=iq['id']))
|
#response = self.send(iq, self.Iq(sid=iq['id']))
|
||||||
self.set_jid(response.xml.find('{urn:ietf:params:xml:ns:xmpp-bind}bind/{urn:ietf:params:xml:ns:xmpp-bind}jid').text)
|
self.set_jid(response.xml.find('{urn:ietf:params:xml:ns:xmpp-bind}bind/{urn:ietf:params:xml:ns:xmpp-bind}jid').text)
|
||||||
|
self.bound = True
|
||||||
logging.info("Node set to: %s" % self.fulljid)
|
logging.info("Node set to: %s" % self.fulljid)
|
||||||
if "{urn:ietf:params:xml:ns:xmpp-session}session" not in self.features:
|
if "{urn:ietf:params:xml:ns:xmpp-session}session" not in self.features or self.bindfail:
|
||||||
logging.debug("Established Session")
|
logging.debug("Established Session")
|
||||||
self.sessionstarted = True
|
self.sessionstarted = True
|
||||||
self.event("session_start")
|
self.event("session_start")
|
||||||
|
|
||||||
def handler_start_session(self, xml):
|
def handler_start_session(self, xml):
|
||||||
if self.authenticated:
|
if self.authenticated and self.bound:
|
||||||
iq = self.makeIqSet(xml)
|
iq = self.makeIqSet(xml)
|
||||||
response = iq.send()
|
response = iq.send()
|
||||||
logging.debug("Established Session")
|
logging.debug("Established Session")
|
||||||
self.sessionstarted = True
|
self.sessionstarted = True
|
||||||
self.event("session_start")
|
self.event("session_start")
|
||||||
|
else:
|
||||||
|
#bind probably hasn't happened yet
|
||||||
|
self.bindfail = True
|
||||||
|
|
||||||
def _handleRoster(self, iq, request=False):
|
def _handleRoster(self, iq, request=False):
|
||||||
if iq['type'] == 'set' or (iq['type'] == 'result' and request):
|
if iq['type'] == 'set' or (iq['type'] == 'result' and request):
|
||||||
|
|
44
sleekxmpp/plugins/jobs.py
Normal file
44
sleekxmpp/plugins/jobs.py
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
from . import base
|
||||||
|
import logging
|
||||||
|
from xml.etree import cElementTree as ET
|
||||||
|
|
||||||
|
class jobs(base.base_plugin):
|
||||||
|
def plugin_init(self):
|
||||||
|
self.xep = 'pubsubjob'
|
||||||
|
self.description = "Job distribution over Pubsub"
|
||||||
|
|
||||||
|
def post_init(self):
|
||||||
|
pass
|
||||||
|
#TODO add event
|
||||||
|
|
||||||
|
def createJobNode(self, host, jid, node, config=None):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def createJob(self, host, node, jobid=None, payload=None):
|
||||||
|
return self.xmpp.plugin['xep_0060'].setItem(host, node, ((jobid, payload),))
|
||||||
|
|
||||||
|
def claimJob(self, host, node, jobid, ifrom=None):
|
||||||
|
return self._setState(host, node, jobid, ET.Element('{http://andyet.net/protocol/pubsubjob}claimed'))
|
||||||
|
|
||||||
|
def unclaimJob(self, jobid):
|
||||||
|
return self._setState(host, node, jobid, ET.Element('{http://andyet.net/protocol/pubsubjob}unclaimed'))
|
||||||
|
|
||||||
|
def finishJob(self, host, node, jobid, payload=None):
|
||||||
|
finished = ET.Element('{http://andyet.net/protocol/pubsubjob}finished')
|
||||||
|
if payload is not None:
|
||||||
|
finished.append(payload)
|
||||||
|
return self._setState(host, node, jobid, finished)
|
||||||
|
|
||||||
|
def _setState(self, host, node, jobid, state, ifrom=None):
|
||||||
|
iq = self.xmpp.Iq()
|
||||||
|
iq['to'] = host
|
||||||
|
if ifrom: iq['from'] = ifrom
|
||||||
|
iq['type'] = 'set'
|
||||||
|
iq['psstate']['node'] = node
|
||||||
|
iq['psstate']['item'] = jobid
|
||||||
|
iq['psstate']['payload'] = state
|
||||||
|
result = iq.send()
|
||||||
|
if result is None or result['type'] != 'result':
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
Loading…
Reference in a new issue