2011-09-06 00:45:53 +00:00
|
|
|
# Copyright 2010-2011 Florent Le Coz <louiz@louiz.org>
|
2010-01-10 20:14:17 +00:00
|
|
|
#
|
|
|
|
# This file is part of Poezio.
|
|
|
|
#
|
|
|
|
# Poezio is free software: you can redistribute it and/or modify
|
2011-09-11 15:10:05 +00:00
|
|
|
# it under the terms of the zlib license. See the COPYING file.
|
2010-01-10 20:14:17 +00:00
|
|
|
|
2010-05-18 13:29:02 +00:00
|
|
|
"""
|
|
|
|
Defines the Connection class
|
|
|
|
"""
|
|
|
|
|
2010-11-29 18:36:54 +00:00
|
|
|
import logging
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
2010-03-24 16:44:55 +00:00
|
|
|
from gettext import (bindtextdomain, textdomain, bind_textdomain_codeset,
|
|
|
|
gettext as _)
|
|
|
|
|
2011-01-13 22:20:17 +00:00
|
|
|
import getpass
|
2013-01-17 16:37:06 +00:00
|
|
|
import sys
|
2010-08-31 23:11:02 +00:00
|
|
|
import sleekxmpp
|
2010-01-10 20:14:17 +00:00
|
|
|
|
2012-08-05 00:04:52 +00:00
|
|
|
from config import config, options
|
2010-08-31 23:11:02 +00:00
|
|
|
from logger import logger
|
2011-01-09 00:09:51 +00:00
|
|
|
import common
|
2012-08-08 21:59:00 +00:00
|
|
|
from common import safeJID
|
2010-01-10 20:14:17 +00:00
|
|
|
|
2010-08-31 23:11:02 +00:00
|
|
|
class Connection(sleekxmpp.ClientXMPP):
|
2010-01-10 20:14:17 +00:00
|
|
|
"""
|
2010-01-21 01:54:50 +00:00
|
|
|
Receives everything from Jabber and emits the
|
|
|
|
appropriate signals
|
2010-01-10 20:14:17 +00:00
|
|
|
"""
|
2011-03-05 20:42:56 +00:00
|
|
|
__init = False
|
2010-08-31 23:11:02 +00:00
|
|
|
def __init__(self):
|
2010-10-16 18:47:39 +00:00
|
|
|
resource = config.get('resource', '')
|
2010-09-08 23:00:55 +00:00
|
|
|
if config.get('jid', ''):
|
2011-03-05 20:42:56 +00:00
|
|
|
self.anon = False # Field used to know if we are anonymous or not.
|
2010-09-08 23:00:55 +00:00
|
|
|
# many features will be handled diferently
|
|
|
|
# depending on this setting
|
2012-08-01 18:10:00 +00:00
|
|
|
jid = '%s' % config.get('jid', '')
|
|
|
|
if resource:
|
2012-08-02 14:32:59 +00:00
|
|
|
jid = '%s/%s'% (jid, resource)
|
2011-01-13 22:20:17 +00:00
|
|
|
password = config.get('password', '') or getpass.getpass()
|
2010-10-16 18:47:39 +00:00
|
|
|
else: # anonymous auth
|
2010-09-08 23:00:55 +00:00
|
|
|
self.anon = True
|
2013-05-06 18:20:47 +00:00
|
|
|
jid = config.get('server', 'anon.jeproteste.info')
|
2012-08-08 21:59:00 +00:00
|
|
|
if resource:
|
|
|
|
jid = '%s/%s' % (jid, resource)
|
2010-09-08 23:00:55 +00:00
|
|
|
password = None
|
2012-08-08 21:59:00 +00:00
|
|
|
jid = safeJID(jid)
|
2012-12-31 13:00:09 +00:00
|
|
|
# TODO: use the system language
|
|
|
|
sleekxmpp.ClientXMPP.__init__(self, jid, password, lang=config.get('lang', 'en'))
|
2013-06-03 21:12:19 +00:00
|
|
|
|
2014-02-12 23:48:19 +00:00
|
|
|
force_encryption = config.get('force_encryption', 'true').lower() != 'false'
|
|
|
|
if force_encryption:
|
|
|
|
self['feature_mechanisms'].unencrypted_plain = False
|
|
|
|
self['feature_mechanisms'].unencrypted_digest = False
|
|
|
|
self['feature_mechanisms'].unencrypted_cram = False
|
|
|
|
self['feature_mechanisms'].unencrypted_scram = False
|
|
|
|
|
2011-11-28 23:00:47 +00:00
|
|
|
self.core = None
|
2012-01-26 16:21:13 +00:00
|
|
|
self.auto_reconnect = True if config.get('auto_reconnect', 'false').lower() in ('true', '1') else False
|
2012-07-13 00:20:55 +00:00
|
|
|
self.reconnect_max_attempts = 0
|
2011-01-11 05:43:31 +00:00
|
|
|
self.auto_authorize = None
|
2014-01-15 17:28:23 +00:00
|
|
|
# prosody defaults, lowest is AES128-SHA, it should be a minimum
|
|
|
|
# for anything that came out after 2002
|
|
|
|
self.ciphers = config.get('ciphers', 'HIGH+kEDH:HIGH+kEECDH:HIGH:!PSK:!SRP:!3DES:!aNULL')
|
2012-03-08 23:48:49 +00:00
|
|
|
self.ca_certs = config.get('ca_cert_path', '') or None
|
2012-03-13 17:46:02 +00:00
|
|
|
interval = config.get('whitespace_interval', '300')
|
2013-06-03 21:12:19 +00:00
|
|
|
if interval.isdecimal() and int(interval) > 0:
|
2012-03-13 17:46:02 +00:00
|
|
|
self.whitespace_keepalive_interval = int(interval)
|
|
|
|
else:
|
|
|
|
self.whitespace_keepalive_interval = 300
|
2013-01-17 16:37:06 +00:00
|
|
|
# Hack to check the sleekxmpp version
|
|
|
|
# TODO: Remove that when a sufficient time has passed since the move
|
2013-02-28 21:44:07 +00:00
|
|
|
self.register_plugin('xep_0004')
|
2012-08-02 14:24:10 +00:00
|
|
|
self.register_plugin('xep_0012')
|
2011-01-09 00:09:51 +00:00
|
|
|
self.register_plugin('xep_0030')
|
2011-03-29 18:36:02 +00:00
|
|
|
self.register_plugin('xep_0045')
|
2012-03-13 20:39:06 +00:00
|
|
|
self.register_plugin('xep_0048')
|
2013-02-28 21:44:07 +00:00
|
|
|
self.register_plugin('xep_0060')
|
2013-11-14 20:26:19 +00:00
|
|
|
self.register_plugin('xep_0066')
|
2013-02-28 21:44:07 +00:00
|
|
|
self.register_plugin('xep_0071')
|
2013-11-14 20:26:19 +00:00
|
|
|
self.register_plugin('xep_0077')
|
|
|
|
self.plugin['xep_0077'].create_account = False
|
2011-02-24 19:02:18 +00:00
|
|
|
self.register_plugin('xep_0085')
|
2013-03-03 12:47:11 +00:00
|
|
|
self.register_plugin('xep_0115')
|
2012-08-01 23:09:10 +00:00
|
|
|
self.register_plugin('xep_0191')
|
2013-06-18 18:37:57 +00:00
|
|
|
self.register_plugin('xep_0199')
|
|
|
|
self.set_keepalive_values()
|
2013-03-11 10:43:32 +00:00
|
|
|
|
2013-03-11 22:06:52 +00:00
|
|
|
if config.get('enable_user_tune', 'true') != 'false':
|
2013-03-11 10:43:32 +00:00
|
|
|
self.register_plugin('xep_0118')
|
2013-03-11 22:06:52 +00:00
|
|
|
|
|
|
|
if config.get('enable_user_nick', 'true') != 'false':
|
2013-03-11 16:54:29 +00:00
|
|
|
self.register_plugin('xep_0172')
|
2013-03-11 22:06:52 +00:00
|
|
|
|
|
|
|
if config.get('enable_user_mood', 'true') != 'false':
|
|
|
|
self.register_plugin('xep_0107')
|
|
|
|
|
|
|
|
if config.get('enable_user_activity', 'true') != 'false':
|
|
|
|
self.register_plugin('xep_0108')
|
|
|
|
|
2013-03-12 15:12:47 +00:00
|
|
|
if config.get('enable_user_gaming', 'true') != 'false':
|
|
|
|
self.register_plugin('xep_0196')
|
|
|
|
|
2011-01-09 00:09:51 +00:00
|
|
|
if config.get('send_poezio_info', 'true') == 'true':
|
|
|
|
info = {'name':'poezio',
|
2012-08-05 00:04:52 +00:00
|
|
|
'version': options.version}
|
2011-01-09 00:09:51 +00:00
|
|
|
if config.get('send_os_info', 'true') == 'true':
|
|
|
|
info['os'] = common.get_os_info()
|
2012-05-04 16:52:36 +00:00
|
|
|
self.plugin['xep_0030'].set_identities(identities=set([('client', 'pc', None,'Poezio')]))
|
2012-04-18 21:07:28 +00:00
|
|
|
else:
|
|
|
|
info = {'name': '', 'version': ''}
|
2012-05-04 16:52:36 +00:00
|
|
|
self.plugin['xep_0030'].set_identities(identities=set([('client', 'pc', None,'')]))
|
2012-04-18 21:07:28 +00:00
|
|
|
self.register_plugin('xep_0092', pconfig=info)
|
2011-01-09 00:09:51 +00:00
|
|
|
if config.get('send_time', 'true') == 'true':
|
|
|
|
self.register_plugin('xep_0202')
|
2012-01-27 18:13:04 +00:00
|
|
|
self.register_plugin('xep_0224')
|
2013-06-10 21:49:10 +00:00
|
|
|
self.register_plugin('xep_0280')
|
|
|
|
self.register_plugin('xep_0297')
|
2012-10-12 15:28:41 +00:00
|
|
|
self.register_plugin('xep_0308')
|
2011-01-08 23:20:27 +00:00
|
|
|
|
2013-06-18 18:37:57 +00:00
|
|
|
def set_keepalive_values(self, option=None, value=None):
|
|
|
|
"""
|
|
|
|
Called at startup, or triggered when one of
|
|
|
|
"connection_timeout_delay" and "connection_check_interval" options
|
|
|
|
is changed.
|
|
|
|
Unload and reload the ping plugin, with the new values.
|
|
|
|
"""
|
|
|
|
ping_interval = config.get('connection_check_interval', 60)
|
|
|
|
timeout_delay = config.get('connection_timeout_delay', 10)
|
|
|
|
if timeout_delay <= 0:
|
2013-06-18 18:38:16 +00:00
|
|
|
# We help the stupid user (with a delay of 0, poezio will try to
|
|
|
|
# reconnect immediately because the timeout is immediately
|
|
|
|
# passed)
|
|
|
|
# 1 second is short, but, well
|
|
|
|
timeout_delay = 1
|
2013-06-18 18:37:57 +00:00
|
|
|
self.plugin['xep_0199'].disable_keepalive()
|
2013-06-18 18:38:16 +00:00
|
|
|
# If the ping_interval is 0 or less, we just disable the keepalive
|
|
|
|
if ping_interval > 0:
|
|
|
|
self.plugin['xep_0199'].enable_keepalive(ping_interval, timeout_delay)
|
2013-06-18 18:37:57 +00:00
|
|
|
|
2010-08-31 23:11:02 +00:00
|
|
|
def start(self):
|
|
|
|
# TODO, try multiple servers
|
2010-11-29 18:36:54 +00:00
|
|
|
# With anon auth.
|
2010-11-08 01:33:36 +00:00
|
|
|
# (domain, config.get('port', 5222))
|
|
|
|
custom_host = config.get('custom_host', '')
|
2011-11-10 16:20:25 +00:00
|
|
|
custom_port = config.get('custom_port', 5222)
|
2012-06-01 20:46:21 +00:00
|
|
|
if custom_port == -1:
|
|
|
|
custom_port = 5222
|
2011-11-10 16:20:25 +00:00
|
|
|
if custom_host:
|
2012-07-13 00:20:55 +00:00
|
|
|
res = self.connect((custom_host, custom_port), reattempt=True)
|
2011-11-15 18:39:12 +00:00
|
|
|
elif custom_port != 5222 and custom_port != -1:
|
2012-07-13 00:20:55 +00:00
|
|
|
res = self.connect((self.boundjid.host, custom_port), reattempt=True)
|
2010-10-16 18:53:13 +00:00
|
|
|
else:
|
2012-07-13 00:20:55 +00:00
|
|
|
res = self.connect(reattempt=True)
|
2011-01-08 23:20:27 +00:00
|
|
|
if not res:
|
|
|
|
return False
|
2010-11-08 01:33:36 +00:00
|
|
|
self.process(threaded=True)
|
2011-01-08 23:20:27 +00:00
|
|
|
return True
|
2011-11-28 23:00:47 +00:00
|
|
|
|
|
|
|
def send_raw(self, data, now=False, reconnect=None):
|
|
|
|
"""
|
|
|
|
Overrides XMLStream.send_raw, with an event added
|
|
|
|
"""
|
|
|
|
if self.core:
|
|
|
|
self.core.outgoing_stanza(data)
|
|
|
|
sleekxmpp.ClientXMPP.send_raw(self, data, now, reconnect)
|
|
|
|
|
|
|
|
class MatchAll(sleekxmpp.xmlstream.matcher.base.MatcherBase):
|
2012-05-21 00:14:25 +00:00
|
|
|
"""
|
|
|
|
Callback to retrieve all the stanzas for the XML tab
|
|
|
|
"""
|
2011-11-28 23:00:47 +00:00
|
|
|
def match(self, xml):
|
|
|
|
return True
|