give error messages when local message could not be sent, see #2586
This commit is contained in:
parent
f5fedaf737
commit
745434fdab
|
@ -398,7 +398,7 @@ class Dispatcher(PlugIn):
|
||||||
Additional callback arguments can be specified in args. '''
|
Additional callback arguments can be specified in args. '''
|
||||||
self.SendAndWaitForResponse(stanza, 0, func, args)
|
self.SendAndWaitForResponse(stanza, 0, func, args)
|
||||||
|
|
||||||
def send(self, stanza):
|
def send(self, stanza, is_message = False):
|
||||||
''' Serialise stanza and put it on the wire. Assign an unique ID to it before send.
|
''' Serialise stanza and put it on the wire. Assign an unique ID to it before send.
|
||||||
Returns assigned ID.'''
|
Returns assigned ID.'''
|
||||||
if type(stanza) in [type(''), type(u'')]:
|
if type(stanza) in [type(''), type(u'')]:
|
||||||
|
@ -425,7 +425,7 @@ class Dispatcher(PlugIn):
|
||||||
stanza=route
|
stanza=route
|
||||||
stanza.setNamespace(self._owner.Namespace)
|
stanza.setNamespace(self._owner.Namespace)
|
||||||
stanza.setParent(self._metastream)
|
stanza.setParent(self._metastream)
|
||||||
self._owner.Connection.send(stanza)
|
self._owner.Connection.send(stanza, is_message)
|
||||||
return _ID
|
return _ID
|
||||||
|
|
||||||
def disconnect(self):
|
def disconnect(self):
|
||||||
|
|
|
@ -33,10 +33,10 @@ DATA_SENT='DATA SENT'
|
||||||
TYPE_SERVER, TYPE_CLIENT = range(2)
|
TYPE_SERVER, TYPE_CLIENT = range(2)
|
||||||
|
|
||||||
# wait XX sec to establish a connection
|
# wait XX sec to establish a connection
|
||||||
CONNECT_TIMEOUT_SECONDS = 30
|
CONNECT_TIMEOUT_SECONDS = 10
|
||||||
|
|
||||||
# after XX sec with no activity, close the stream
|
# after XX sec with no activity, close the stream
|
||||||
ACTIVITY_TIMEOUT_SECONDS = 180
|
ACTIVITY_TIMEOUT_SECONDS = 30
|
||||||
|
|
||||||
class ZeroconfListener(IdleObject):
|
class ZeroconfListener(IdleObject):
|
||||||
def __init__(self, port, conn_holder):
|
def __init__(self, port, conn_holder):
|
||||||
|
@ -68,6 +68,7 @@ class ZeroconfListener(IdleObject):
|
||||||
self.started = True
|
self.started = True
|
||||||
|
|
||||||
def pollend(self):
|
def pollend(self):
|
||||||
|
#print 'pollend'
|
||||||
''' called when we stop listening on (host, port) '''
|
''' called when we stop listening on (host, port) '''
|
||||||
self.disconnect()
|
self.disconnect()
|
||||||
|
|
||||||
|
@ -89,13 +90,13 @@ class ZeroconfListener(IdleObject):
|
||||||
self.conn_holder.kill_all_connections()
|
self.conn_holder.kill_all_connections()
|
||||||
|
|
||||||
def accept_conn(self):
|
def accept_conn(self):
|
||||||
''' accepts a new incomming connection '''
|
''' accepts a new incoming connection '''
|
||||||
_sock = self._serv.accept()
|
_sock = self._serv.accept()
|
||||||
_sock[0].setblocking(False)
|
_sock[0].setblocking(False)
|
||||||
return _sock
|
return _sock
|
||||||
|
|
||||||
class P2PClient(IdleObject):
|
class P2PClient(IdleObject):
|
||||||
def __init__(self, _sock, host, port, conn_holder, messagequeue = [], to = None):
|
def __init__(self, _sock, host, port, conn_holder, stanzaqueue = [], to = None):
|
||||||
self._owner = self
|
self._owner = self
|
||||||
self.Namespace = 'jabber:client'
|
self.Namespace = 'jabber:client'
|
||||||
self.defaultNamespace = self.Namespace
|
self.defaultNamespace = self.Namespace
|
||||||
|
@ -103,7 +104,7 @@ class P2PClient(IdleObject):
|
||||||
self._registered_name = None
|
self._registered_name = None
|
||||||
self._caller = conn_holder.caller
|
self._caller = conn_holder.caller
|
||||||
self.conn_holder = conn_holder
|
self.conn_holder = conn_holder
|
||||||
self.messagequeue = messagequeue
|
self.stanzaqueue = stanzaqueue
|
||||||
self.to = to
|
self.to = to
|
||||||
self.Server = host
|
self.Server = host
|
||||||
self.DBG = 'client'
|
self.DBG = 'client'
|
||||||
|
@ -121,28 +122,45 @@ class P2PClient(IdleObject):
|
||||||
self.sock_type = TYPE_SERVER
|
self.sock_type = TYPE_SERVER
|
||||||
else:
|
else:
|
||||||
self.sock_type = TYPE_CLIENT
|
self.sock_type = TYPE_CLIENT
|
||||||
conn = P2PConnection('', _sock, host, port, self._caller, self.on_connect)
|
conn = P2PConnection('', _sock, host, port, self._caller, self.on_connect, self)
|
||||||
self.sock_hash = conn._sock.__hash__
|
self.sock_hash = conn._sock.__hash__
|
||||||
self.conn_holder.add_connection(self, self.Server, self.to)
|
self.fd = conn.fd
|
||||||
|
self.conn_holder.add_connection(self, self.Server, port, self.to)
|
||||||
|
self.conn_holder.number_of_awaiting_messages[self.fd] = len(self.stanzaqueue)
|
||||||
|
|
||||||
def add_message(self, message):
|
def add_stanza(self, stanza, is_message = False):
|
||||||
if self.Connection:
|
if self.Connection:
|
||||||
if self.Connection.state == -1:
|
if self.Connection.state == -1:
|
||||||
return False
|
return False
|
||||||
self.send(message)
|
self.send(stanza, is_message)
|
||||||
else:
|
else:
|
||||||
self.messagequeue.append(message)
|
self.stanzaqueue.append((stanza, is_message))
|
||||||
|
|
||||||
|
if is_message:
|
||||||
|
#print 'fd: %s' % self.fd
|
||||||
|
if self.conn_holder.number_of_awaiting_messages.has_key(self.fd):
|
||||||
|
self.conn_holder.number_of_awaiting_messages[self.fd]+=1
|
||||||
|
else:
|
||||||
|
self.conn_holder.number_of_awaiting_messages[self.fd] = 1
|
||||||
|
|
||||||
|
#print "number_of_awaiting_messages %s" % self.conn_holder.number_of_awaiting_messages
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
def on_message_sent(self, connection_id):
|
||||||
|
#print 'message successfully sent'
|
||||||
|
#print connection_id
|
||||||
|
self.conn_holder.number_of_awaiting_messages[connection_id]-=1
|
||||||
|
#print self.conn_holder.number_of_awaiting_messages
|
||||||
|
|
||||||
def on_connect(self, conn):
|
def on_connect(self, conn):
|
||||||
self.Connection = conn
|
self.Connection = conn
|
||||||
self.Connection.PlugIn(self)
|
self.Connection.PlugIn(self)
|
||||||
dispatcher_nb.Dispatcher().PlugIn(self)
|
dispatcher_nb.Dispatcher().PlugIn(self)
|
||||||
self._register_handlers()
|
self._register_handlers()
|
||||||
if self.sock_type == TYPE_CLIENT:
|
if self.sock_type == TYPE_CLIENT:
|
||||||
while self.messagequeue:
|
while self.stanzaqueue:
|
||||||
message = self.messagequeue.pop(0)
|
stanza, is_message = self.stanzaqueue.pop(0)
|
||||||
self.send(message)
|
self.send(stanza, is_message)
|
||||||
|
|
||||||
def StreamInit(self):
|
def StreamInit(self):
|
||||||
''' Send an initial stream header. '''
|
''' Send an initial stream header. '''
|
||||||
|
@ -171,13 +189,19 @@ class P2PClient(IdleObject):
|
||||||
return
|
return
|
||||||
if self.sock_type == TYPE_SERVER:
|
if self.sock_type == TYPE_SERVER:
|
||||||
self.send_stream_header()
|
self.send_stream_header()
|
||||||
while self.messagequeue:
|
while self.stanzaqueue:
|
||||||
message = self.messagequeue.pop(0)
|
stanza, is_message = self.stanzaqueue.pop(0)
|
||||||
self.send(message)
|
self.send(stanza, is_message)
|
||||||
|
|
||||||
|
|
||||||
def on_disconnect(self):
|
def on_disconnect(self):
|
||||||
|
#print 'on_disconnect, to:%s' % self.to
|
||||||
if self.conn_holder:
|
if self.conn_holder:
|
||||||
|
if self.conn_holder.number_of_awaiting_messages.has_key(self.fd):
|
||||||
|
if self.conn_holder.number_of_awaiting_messages[self.fd] > 0:
|
||||||
|
self._caller.dispatch('MSGERROR',[unicode(self.to), -1, \
|
||||||
|
_('Connection to host could not be established'), None, None])
|
||||||
|
del self.conn_holder.number_of_awaiting_messages[self.fd]
|
||||||
self.conn_holder.remove_connection(self.sock_hash)
|
self.conn_holder.remove_connection(self.sock_hash)
|
||||||
if self.__dict__.has_key('Dispatcher'):
|
if self.__dict__.has_key('Dispatcher'):
|
||||||
self.Dispatcher.PlugOut()
|
self.Dispatcher.PlugOut()
|
||||||
|
@ -227,16 +251,19 @@ class P2PClient(IdleObject):
|
||||||
|
|
||||||
class P2PConnection(IdleObject, PlugIn):
|
class P2PConnection(IdleObject, PlugIn):
|
||||||
''' class for sending file to socket over socks5 '''
|
''' class for sending file to socket over socks5 '''
|
||||||
def __init__(self, sock_hash, _sock, host = None, port = None, caller = None, on_connect = None):
|
def __init__(self, sock_hash, _sock, host = None, port = None, caller = None, on_connect = None, client = None):
|
||||||
IdleObject.__init__(self)
|
IdleObject.__init__(self)
|
||||||
self._owner = None
|
self._owner = client
|
||||||
PlugIn.__init__(self)
|
PlugIn.__init__(self)
|
||||||
self.DBG_LINE='socket'
|
self.DBG_LINE='socket'
|
||||||
self.sendqueue = []
|
self.sendqueue = []
|
||||||
self.sendbuff = None
|
self.sendbuff = None
|
||||||
|
self.buff_is_message = False
|
||||||
self._sock = _sock
|
self._sock = _sock
|
||||||
|
self.sock_hash = None
|
||||||
self.host, self.port = host, port
|
self.host, self.port = host, port
|
||||||
self.on_connect = on_connect
|
self.on_connect = on_connect
|
||||||
|
self.client = client
|
||||||
self.writable = False
|
self.writable = False
|
||||||
self.readable = False
|
self.readable = False
|
||||||
self._exported_methods=[self.send, self.disconnect, self.onreceive]
|
self._exported_methods=[self.send, self.disconnect, self.onreceive]
|
||||||
|
@ -284,26 +311,33 @@ class P2PConnection(IdleObject, PlugIn):
|
||||||
if not recv_handler(None) and _tmp == self.on_receive:
|
if not recv_handler(None) and _tmp == self.on_receive:
|
||||||
self.on_receive = recv_handler
|
self.on_receive = recv_handler
|
||||||
|
|
||||||
|
def send(self, packet, is_message = False):
|
||||||
|
|
||||||
def send(self, stanza):
|
|
||||||
'''Append stanza to the queue of messages to be send.
|
'''Append stanza to the queue of messages to be send.
|
||||||
If supplied data is unicode string, encode it to utf-8.
|
If supplied data is unicode string, encode it to utf-8.
|
||||||
'''
|
'''
|
||||||
if self.state <= 0:
|
if self.state <= 0:
|
||||||
return
|
return
|
||||||
r = stanza
|
|
||||||
|
r = packet
|
||||||
|
|
||||||
if isinstance(r, unicode):
|
if isinstance(r, unicode):
|
||||||
r = r.encode('utf-8')
|
r = r.encode('utf-8')
|
||||||
elif not isinstance(r, str):
|
elif not isinstance(r, str):
|
||||||
r = ustr(r).encode('utf-8')
|
r = ustr(r).encode('utf-8')
|
||||||
self.sendqueue.append(r)
|
|
||||||
|
self.sendqueue.append((r, is_message))
|
||||||
self._plug_idle()
|
self._plug_idle()
|
||||||
|
|
||||||
def read_timeout(self):
|
def read_timeout(self):
|
||||||
|
#print 'read_timeout: %s' % self.fd
|
||||||
|
#print self.client.conn_holder.number_of_awaiting_messages
|
||||||
|
if self.client.conn_holder.number_of_awaiting_messages[self.fd] > 0:
|
||||||
|
self.client._caller.dispatch('MSGERROR',[unicode(self.client.to), -1, \
|
||||||
|
_('Connection to host could not be established'), None, None])
|
||||||
|
#print 'error, set to zero'
|
||||||
|
self.client.conn_holder.number_of_awaiting_messages[self.fd] = 0
|
||||||
self.pollend()
|
self.pollend()
|
||||||
|
|
||||||
|
|
||||||
def do_connect(self):
|
def do_connect(self):
|
||||||
errnum = 0
|
errnum = 0
|
||||||
try:
|
try:
|
||||||
|
@ -328,6 +362,7 @@ class P2PConnection(IdleObject, PlugIn):
|
||||||
if self.state == 0:
|
if self.state == 0:
|
||||||
self.do_connect()
|
self.do_connect()
|
||||||
return
|
return
|
||||||
|
#print 'pollout:'
|
||||||
gajim.idlequeue.remove_timeout(self.fd)
|
gajim.idlequeue.remove_timeout(self.fd)
|
||||||
self._do_send()
|
self._do_send()
|
||||||
|
|
||||||
|
@ -391,6 +426,7 @@ class P2PConnection(IdleObject, PlugIn):
|
||||||
|
|
||||||
def disconnect(self):
|
def disconnect(self):
|
||||||
''' Closes the socket. '''
|
''' Closes the socket. '''
|
||||||
|
#print 'disconnect'
|
||||||
gajim.idlequeue.remove_timeout(self.fd)
|
gajim.idlequeue.remove_timeout(self.fd)
|
||||||
gajim.idlequeue.unplug_idle(self.fd)
|
gajim.idlequeue.unplug_idle(self.fd)
|
||||||
try:
|
try:
|
||||||
|
@ -408,7 +444,7 @@ class P2PConnection(IdleObject, PlugIn):
|
||||||
if not self.sendbuff:
|
if not self.sendbuff:
|
||||||
if not self.sendqueue:
|
if not self.sendqueue:
|
||||||
return None # nothing to send
|
return None # nothing to send
|
||||||
self.sendbuff = self.sendqueue.pop(0)
|
self.sendbuff, self.buff_is_message = self.sendqueue.pop(0)
|
||||||
self.sent_data = self.sendbuff
|
self.sent_data = self.sendbuff
|
||||||
try:
|
try:
|
||||||
send_count = self._sock.send(self.sendbuff)
|
send_count = self._sock.send(self.sendbuff)
|
||||||
|
@ -423,6 +459,7 @@ class P2PConnection(IdleObject, PlugIn):
|
||||||
# we are not waiting for write
|
# we are not waiting for write
|
||||||
self._plug_idle()
|
self._plug_idle()
|
||||||
self._on_send()
|
self._on_send()
|
||||||
|
|
||||||
except socket.error, e:
|
except socket.error, e:
|
||||||
sys.exc_clear()
|
sys.exc_clear()
|
||||||
if e[0] == socket.SSL_ERROR_WANT_WRITE:
|
if e[0] == socket.SSL_ERROR_WANT_WRITE:
|
||||||
|
@ -452,6 +489,9 @@ class P2PConnection(IdleObject, PlugIn):
|
||||||
if hasattr(self._owner, 'Dispatcher'):
|
if hasattr(self._owner, 'Dispatcher'):
|
||||||
self._owner.Dispatcher.Event('', DATA_SENT, self.sent_data)
|
self._owner.Dispatcher.Event('', DATA_SENT, self.sent_data)
|
||||||
self.sent_data = None
|
self.sent_data = None
|
||||||
|
if self.buff_is_message:
|
||||||
|
self._owner.on_message_sent(self.fd)
|
||||||
|
self.buff_is_message = False
|
||||||
|
|
||||||
def _on_send_failure(self):
|
def _on_send_failure(self):
|
||||||
self.DEBUG("Socket error while sending data",'error')
|
self.DEBUG("Socket error while sending data",'error')
|
||||||
|
@ -468,7 +508,9 @@ class ClientZeroconf:
|
||||||
self.connections = {}
|
self.connections = {}
|
||||||
self.recipient_to_hash = {}
|
self.recipient_to_hash = {}
|
||||||
self.ip_to_hash = {}
|
self.ip_to_hash = {}
|
||||||
|
self.hash_to_port = {}
|
||||||
self.listener = None
|
self.listener = None
|
||||||
|
self.number_of_awaiting_messages = {}
|
||||||
|
|
||||||
def test_avahi(self):
|
def test_avahi(self):
|
||||||
try:
|
try:
|
||||||
|
@ -545,11 +587,12 @@ class ClientZeroconf:
|
||||||
for connection in self.connections.values():
|
for connection in self.connections.values():
|
||||||
connection.force_disconnect()
|
connection.force_disconnect()
|
||||||
|
|
||||||
def add_connection(self, connection, ip, recipient):
|
def add_connection(self, connection, ip, port, recipient):
|
||||||
sock_hash = connection.sock_hash
|
sock_hash = connection.sock_hash
|
||||||
if sock_hash not in self.connections:
|
if sock_hash not in self.connections:
|
||||||
self.connections[sock_hash] = connection
|
self.connections[sock_hash] = connection
|
||||||
self.ip_to_hash[ip] = sock_hash
|
self.ip_to_hash[ip] = sock_hash
|
||||||
|
self.hash_to_port[sock_hash] = port
|
||||||
if recipient:
|
if recipient:
|
||||||
self.recipient_to_hash[recipient] = sock_hash
|
self.recipient_to_hash[recipient] = sock_hash
|
||||||
|
|
||||||
|
@ -564,6 +607,8 @@ class ClientZeroconf:
|
||||||
if self.ip_to_hash[i] == sock_hash:
|
if self.ip_to_hash[i] == sock_hash:
|
||||||
del self.ip_to_hash[i]
|
del self.ip_to_hash[i]
|
||||||
break
|
break
|
||||||
|
if self.hash_to_port.has_key(sock_hash):
|
||||||
|
del self.hash_to_port[sock_hash]
|
||||||
|
|
||||||
def start_listener(self, port):
|
def start_listener(self, port):
|
||||||
for p in range(port, port + 5):
|
for p in range(port, port + 5):
|
||||||
|
@ -579,21 +624,34 @@ class ClientZeroconf:
|
||||||
return self.roster.getRoster()
|
return self.roster.getRoster()
|
||||||
return {}
|
return {}
|
||||||
|
|
||||||
def send(self, msg_iq):
|
def send(self, stanza, is_message = False):
|
||||||
msg_iq.setFrom(self.roster.zeroconf.name)
|
#print 'send called, is_message = %s' % is_message
|
||||||
to = msg_iq.getTo()
|
#print stanza
|
||||||
if to in self.recipient_to_hash:
|
stanza.setFrom(self.roster.zeroconf.name)
|
||||||
conn = self.connections[self.recipient_to_hash[to]]
|
to = stanza.getTo()
|
||||||
if conn.add_message(msg_iq):
|
|
||||||
return
|
|
||||||
try:
|
try:
|
||||||
item = self.roster[to]
|
item = self.roster[to]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
#XXX invalid recipient, show some error maybe ?
|
self.caller.dispatch('MSGERROR', [unicode(to), '-1', _('Contact is offline. Your message could not be sent.'), None, None])
|
||||||
return
|
return False
|
||||||
if item['address'] in self.ip_to_hash:
|
|
||||||
conn = self.connections[self.ip_to_hash[item['address']]]
|
|
||||||
if conn.add_message(msg_iq):
|
|
||||||
return
|
|
||||||
P2PClient(None, item['address'], item['port'], self, [msg_iq], to)
|
|
||||||
|
|
||||||
|
# look for hashed connections
|
||||||
|
if to in self.recipient_to_hash:
|
||||||
|
conn = self.connections[self.recipient_to_hash[to]]
|
||||||
|
#print 'hashed recipient: %s' % conn.sock_hash
|
||||||
|
if conn.add_stanza(stanza, is_message):
|
||||||
|
return
|
||||||
|
|
||||||
|
#print 'hash_to_port: %s' % self.hash_to_port
|
||||||
|
#print 'ip_to_hash: %s' % self.ip_to_hash
|
||||||
|
if item['address'] in self.ip_to_hash:
|
||||||
|
hash = self.ip_to_hash[item['address']]
|
||||||
|
if self.hash_to_port[hash] == item['port']:
|
||||||
|
#print 'hashed recipient by address: %s' % conn.sock_hash
|
||||||
|
conn = self.connections[hash]
|
||||||
|
if conn.add_stanza(stanza, is_message):
|
||||||
|
return
|
||||||
|
|
||||||
|
# otherwise open new connection
|
||||||
|
P2PClient(None, item['address'], item['port'], self, [(stanza, is_message)], to)
|
||||||
|
|
|
@ -302,7 +302,6 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
# 'disconnect'
|
# 'disconnect'
|
||||||
elif show == 'offline' and self.connected:
|
elif show == 'offline' and self.connected:
|
||||||
self.disconnect()
|
self.disconnect()
|
||||||
self.dispatch('STATUS', 'offline')
|
|
||||||
|
|
||||||
# update status
|
# update status
|
||||||
elif show != 'offline' and self.connected:
|
elif show != 'offline' and self.connected:
|
||||||
|
@ -311,6 +310,8 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
if show == 'invisible':
|
if show == 'invisible':
|
||||||
check = check and self.connection.remove_announce()
|
check = check and self.connection.remove_announce()
|
||||||
elif was_invisible:
|
elif was_invisible:
|
||||||
|
if not self.connected:
|
||||||
|
check = check and self.connect(show, msg)
|
||||||
check = check and self.connection.announce()
|
check = check and self.connection.announce()
|
||||||
if self.connection and not show == 'invisible':
|
if self.connection and not show == 'invisible':
|
||||||
check = check and self.connection.set_show_msg(show, msg)
|
check = check and self.connection.set_show_msg(show, msg)
|
||||||
|
@ -319,7 +320,7 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
if check:
|
if check:
|
||||||
self.dispatch('STATUS', show)
|
self.dispatch('STATUS', show)
|
||||||
else:
|
else:
|
||||||
# show notification that avahi, or system bus is down
|
# show notification that avahi or system bus is down
|
||||||
self.dispatch('STATUS', 'offline')
|
self.dispatch('STATUS', 'offline')
|
||||||
self.status = 'offline'
|
self.status = 'offline'
|
||||||
self.dispatch('CONNECTION_LOST',
|
self.dispatch('CONNECTION_LOST',
|
||||||
|
@ -339,6 +340,10 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
if not msg and chatstate is None:
|
if not msg and chatstate is None:
|
||||||
return
|
return
|
||||||
|
|
||||||
|
if self.status in ('invisible', 'offline'):
|
||||||
|
self.dispatch('MSGERROR', [unicode(jid), '-1', _('You are not connected or not visible to others. Your message could not be sent.'), None, None])
|
||||||
|
return
|
||||||
|
|
||||||
msgtxt = msg
|
msgtxt = msg
|
||||||
msgenc = ''
|
msgenc = ''
|
||||||
if keyID and USE_GPG:
|
if keyID and USE_GPG:
|
||||||
|
@ -384,7 +389,9 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
if chatstate is 'composing' or msgtxt:
|
if chatstate is 'composing' or msgtxt:
|
||||||
chatstate_node.addChild(name = 'composing')
|
chatstate_node.addChild(name = 'composing')
|
||||||
|
|
||||||
self.connection.send(msg_iq)
|
if not self.connection.send(msg_iq, msg != None):
|
||||||
|
return
|
||||||
|
|
||||||
no_log_for = gajim.config.get_per('accounts', self.name, 'no_log_for')
|
no_log_for = gajim.config.get_per('accounts', self.name, 'no_log_for')
|
||||||
ji = gajim.get_jid_without_resource(jid)
|
ji = gajim.get_jid_without_resource(jid)
|
||||||
if self.name not in no_log_for and ji not in no_log_for:
|
if self.name not in no_log_for and ji not in no_log_for:
|
||||||
|
@ -402,11 +409,9 @@ class ConnectionZeroconf(ConnectionHandlersZeroconf):
|
||||||
|
|
||||||
def send_stanza(self, stanza):
|
def send_stanza(self, stanza):
|
||||||
# send a stanza untouched
|
# send a stanza untouched
|
||||||
print 'connection_zeroconf.py: send_stanza'
|
|
||||||
if not self.connection:
|
if not self.connection:
|
||||||
return
|
return
|
||||||
#self.connection.send(stanza)
|
self.connection.send(stanza)
|
||||||
pass
|
|
||||||
|
|
||||||
def ack_subscribed(self, jid):
|
def ack_subscribed(self, jid):
|
||||||
gajim.log.debug('This should not happen (ack_subscribed)')
|
gajim.log.debug('This should not happen (ack_subscribed)')
|
||||||
|
|
Loading…
Reference in New Issue