mirror of
https://github.com/correl/SleekXMPP.git
synced 2024-11-23 19:19:53 +00:00
fixed some presence bugs
This commit is contained in:
parent
e06cdec81a
commit
8d5dbfa691
4 changed files with 11 additions and 7 deletions
|
@ -5,8 +5,12 @@ import logging
|
|||
from optparse import OptionParser
|
||||
import time
|
||||
|
||||
reload(sys)
|
||||
sys.setdefaultencoding('utf8')
|
||||
import sys
|
||||
|
||||
if sys.version_info < (3,0):
|
||||
reload(sys)
|
||||
sys.setdefaultencoding('utf8')
|
||||
|
||||
|
||||
class Example(sleekxmpp.ClientXMPP):
|
||||
|
||||
|
|
|
@ -279,15 +279,15 @@ class basexmpp(object):
|
|||
self.roster[jid]['presence'][resource] = {'show': show, 'status': status}
|
||||
self.roster[jid]['presence'][resource]['priority'] = priority
|
||||
name = self.roster[jid].get('name', '')
|
||||
if wasoffline and show in ('available', 'away', 'xa', 'na', 'ffc'):
|
||||
if wasoffline and (show == 'available' or show in presence.showtypes):
|
||||
self.event("got_online", presence)
|
||||
elif not wasoffline and show == 'unavailable':
|
||||
self.event("got_offline", presence)
|
||||
logging.debug("%s %s got offline" % (jid, resource))
|
||||
if len(self.roster[jid]['presence']) > 1:
|
||||
del self.roster[jid]['presence'][resource]
|
||||
else:
|
||||
del self.roster[jid]
|
||||
self.event("got_offline", presence)
|
||||
elif oldroster != self.roster.get(jid, {'presence': {}})['presence'].get(resource, {}):
|
||||
self.event("changed_status", presence)
|
||||
name = ''
|
||||
|
|
|
@ -6,7 +6,7 @@ from . rootstanza import RootStanza
|
|||
class Presence(RootStanza):
|
||||
interfaces = set(('type', 'to', 'from', 'id', 'status', 'priority'))
|
||||
types = set(('available', 'unavailable', 'error', 'probe', 'subscribe', 'subscribed', 'unsubscribe', 'unsubscribed'))
|
||||
showtypes = set(('dnd', 'ffc', 'xa', 'away'))
|
||||
showtypes = set(('dnd', 'chat', 'xa', 'away'))
|
||||
sub_interfaces = set(('status', 'priority'))
|
||||
name = 'presence'
|
||||
namespace = 'jabber:client'
|
||||
|
|
|
@ -154,7 +154,7 @@ class XMLStream(object):
|
|||
def _process(self):
|
||||
"Start processing the socket."
|
||||
firstrun = True
|
||||
while firstrun or self.state['reconnect']:
|
||||
while self.run and (firstrun or self.state['reconnect']):
|
||||
self.state.set('processing', True)
|
||||
firstrun = False
|
||||
try:
|
||||
|
@ -229,7 +229,7 @@ class XMLStream(object):
|
|||
edepth += 1
|
||||
|
||||
def _sendThread(self):
|
||||
while True:
|
||||
while self.run:
|
||||
data = self.sendqueue.get(True)
|
||||
logging.debug("SEND: %s" % data)
|
||||
try:
|
||||
|
|
Loading…
Reference in a new issue