Skip to content
This repository has been archived by the owner on Feb 19, 2020. It is now read-only.

Commit

Permalink
Merge branch 'master' into develop
Browse files Browse the repository at this point in the history
  • Loading branch information
legastero committed Aug 10, 2012
2 parents 14aa831 + f7a710e commit 962dfad
Show file tree
Hide file tree
Showing 6 changed files with 44 additions and 18 deletions.
2 changes: 1 addition & 1 deletion sleekxmpp/features/feature_mechanisms/mechanisms.py
Expand Up @@ -109,7 +109,7 @@ def _default_credentials(self, required_values, optional_values):
elif value == 'realm':
result[value] = self.xmpp.boundjid.domain
elif value == 'service-name':
result[value] = self.xmpp.address[0]
result[value] = self.xmpp._service_name
elif value == 'service':
result[value] = 'xmpp'
elif value in creds:
Expand Down
1 change: 1 addition & 0 deletions sleekxmpp/plugins/xep_0045.py
Expand Up @@ -156,6 +156,7 @@ def handle_groupchat_presence(self, pr):
entry = pr['muc'].getStanzaValues()
entry['show'] = pr['show']
entry['status'] = pr['status']
entry['alt_nick'] = pr['nick']
if pr['type'] == 'unavailable':
if entry['nick'] in self.rooms[entry['room']]:
del self.rooms[entry['room']][entry['nick']]
Expand Down
15 changes: 9 additions & 6 deletions sleekxmpp/thirdparty/statemachine.py
Expand Up @@ -29,7 +29,7 @@ def addStates(self, states):
if state in self.__states:
raise IndexError("The state '%s' is already in the StateMachine." % state)
self.__states.append(state)
finally:
finally:
self.lock.release()


Expand Down Expand Up @@ -83,11 +83,14 @@ def transition_any(self, from_states, to_state, wait=0.0, func=None, args=[], kw
if not to_state in self.__states:
raise ValueError("StateMachine does not contain to_state %s." % to_state)

if self.__current_state == to_state:
return True

start = time.time()
while not self.lock.acquire(False):
time.sleep(.001)
if (start + wait - time.time()) <= 0.0:
log.debug("Could not acquire lock")
log.debug("==== Could not acquire lock in %s sec: %s -> %s ", wait, self.__current_state, to_state)
return False

while not self.__current_state in from_states:
Expand All @@ -108,7 +111,7 @@ def transition_any(self, from_states, to_state, wait=0.0, func=None, args=[], kw

# some 'false' value returned from func,
# indicating that transition should not occur:
if not return_val:
if not return_val:
return return_val

log.debug(' ==== TRANSITION %s -> %s', self.__current_state, to_state)
Expand Down Expand Up @@ -193,9 +196,9 @@ def ensure_any(self, states, wait=0.0, block_on_transition=False):
while not self.__current_state in states:
# detect timeout:
remainder = start + wait - time.time()
if remainder > 0:
if remainder > 0:
self.lock.wait(remainder)
else:
else:
self.lock.release()
return False
self.lock.release()
Expand Down Expand Up @@ -241,7 +244,7 @@ def __enter__(self):
while not self.state_machine[self.from_state] or not self.state_machine.lock.acquire(False):
# detect timeout:
remainder = start + self.wait - time.time()
if remainder > 0:
if remainder > 0:
self.state_machine.lock.wait(remainder)
else:
log.debug('StateMachine timeout while waiting for state: %s', self.from_state)
Expand Down
2 changes: 2 additions & 0 deletions sleekxmpp/util/misc_ops.py
Expand Up @@ -4,6 +4,8 @@

def unicode(text):
if sys.version_info < (3, 0):
if isinstance(text, str):
text = text.decode('utf-8')
import __builtin__
return __builtin__.unicode(text)
return str(text)
Expand Down
21 changes: 12 additions & 9 deletions sleekxmpp/xmlstream/resolver.py
Expand Up @@ -102,7 +102,7 @@ def resolve(host, port=None, service=None, proto='tcp',
try:
# If `host` is an IPv4 literal, we can return it immediately.
ipv4 = socket.inet_aton(host)
yield (host, port)
yield (host, host, port)
except socket.error:
pass

Expand All @@ -112,7 +112,7 @@ def resolve(host, port=None, service=None, proto='tcp',
# it immediately.
if hasattr(socket, 'inet_pton'):
ipv6 = socket.inet_pton(socket.AF_INET6, host)
yield (host, port)
yield (host, host, port)
except socket.error:
pass

Expand All @@ -128,16 +128,16 @@ def resolve(host, port=None, service=None, proto='tcp',
results = []
if host == 'localhost':
if use_ipv6:
results.append(('::1', port))
results.append(('127.0.0.1', port))
results.append((host, '::1', port))
results.append((host, '127.0.0.1', port))
if use_ipv6:
for address in get_AAAA(host, resolver=resolver):
results.append((address, port))
results.append((host, address, port))
for address in get_A(host, resolver=resolver):
results.append((address, port))
results.append((host, address, port))

for address, port in results:
yield address, port
for host, address, port in results:
yield host, address, port


def get_A(host, resolver=None):
Expand Down Expand Up @@ -297,7 +297,10 @@ def get_SRV(host, port, service, proto='tcp', resolver=None):
for running_sum in sums:
if running_sum >= selected:
rec = sums[running_sum]
sorted_recs.append((rec.target.to_text(), rec.port))
host = rec.target.to_text()
if host.endswith('.'):
host = host[:-1]
sorted_recs.append((host, rec.port))
answers[priority].remove(rec)
break

Expand Down
21 changes: 19 additions & 2 deletions sleekxmpp/xmlstream/xmlstream.py
Expand Up @@ -192,6 +192,7 @@ def __init__(self, socket=None, host='', port=0):

#: The expected name of the server, for validation.
self._expected_server_name = ''
self._service_name = ''

#: The desired, or actual, address of the connected server.
self.address = (host, int(port))
Expand Down Expand Up @@ -473,8 +474,10 @@ def _connect(self, reattempt=True):

if self.default_domain:
try:
self.address = self.pick_dns_answer(self.default_domain,
self.address[1])
host, address, port = self.pick_dns_answer(self.default_domain,
self.address[1])
self.address = (address, port)
self._service_name = host
except StopIteration:
log.debug("No remaining DNS records to try.")
self.dns_answers = None
Expand Down Expand Up @@ -723,6 +726,20 @@ def _disconnect(self, reconnect=False, wait=None, send_close=True):
self.event("disconnected", direct=True)
return True

def abort(self):
self.session_started_event.clear()
self.stop.set()
if self._disconnect_wait_for_threads:
self._wait_for_threads()
try:
self.socket.shutdown(Socket.SHUT_RDWR)
self.socket.close()
self.filesocket.close()
except Socket.error:
pass
self.state.transition_any(['connected', 'disconnected'], 'disconnected', func=lambda: True)
self.event("killed", direct=True)

def reconnect(self, reattempt=True, wait=False, send_close=True):
"""Reset the stream's state and reconnect to the server."""
log.debug("reconnecting...")
Expand Down

0 comments on commit 962dfad

Please sign in to comment.