refactor connect so that new_account can use it (SSL and SRV now works when we create a new account)

This commit is contained in:
Yann Leboulanger 2005-10-14 18:55:48 +00:00
parent dc0fa61cd6
commit 27ee476990
1 changed files with 57 additions and 57 deletions

View File

@ -1341,22 +1341,43 @@ class Connection:
elif event == common.xmpp.transports.DATA_SENT: elif event == common.xmpp.transports.DATA_SENT:
self.dispatch('STANZA_SENT', unicode(data)) self.dispatch('STANZA_SENT', unicode(data))
def connect(self): def connect(self, data = None):
"""Connect and authenticate to the Jabber server """Connect and authenticate to the Jabber server
Returns connection, and connection type ('tls', 'ssl', 'tcp', '')""" Returns connection, and connection type ('tls', 'ssl', 'tcp', '')
data MUST contain name, hostname, resource, usessl, proxy,
use_custom_host, custom_host (if use_custom_host), custom_port (if
use_custom_host), """
if self.connection: if self.connection:
return self.connection return self.connection
if data:
name = data['name']
hostname = data['hostname']
resource = data['resource']
usessl = data['usessl']
try_connecting_for_foo_secs = 45
p = data['proxy']
use_srv = True
use_custom = data['use_custom_host']
if use_custom:
custom_h = data['custom_host']
custom_p = data['custom_port']
else:
name = gajim.config.get_per('accounts', self.name, 'name') name = gajim.config.get_per('accounts', self.name, 'name')
hostname = gajim.config.get_per('accounts', self.name, 'hostname') hostname = gajim.config.get_per('accounts', self.name, 'hostname')
resource = gajim.config.get_per('accounts', self.name, 'resource') resource = gajim.config.get_per('accounts', self.name, 'resource')
usessl = gajim.config.get_per('accounts', self.name, 'usessl') usessl = gajim.config.get_per('accounts', self.name, 'usessl')
try_connecting_for_foo_secs = gajim.config.get_per('accounts', self.name, try_connecting_for_foo_secs = gajim.config.get_per('accounts',
'try_connecting_for_foo_secs') self.name, 'try_connecting_for_foo_secs')
p = gajim.config.get_per('accounts', self.name, 'proxy')
use_srv = gajim.config.get_per('accounts', self.name, 'use_srv')
use_custom = gajim.config.get_per('accounts', self.name,
'use_custom_host')
custom_h = gajim.config.get_per('accounts', self.name, 'custom_host')
custom_p = gajim.config.get_per('accounts', self.name, 'custom_port')
#create connection if it doesn't already exist #create connection if it doesn't already exist
self.connected = 1 self.connected = 1
p = gajim.config.get_per('accounts', self.name, 'proxy')
if p and p in gajim.config.get_per('proxies'): if p and p in gajim.config.get_per('proxies'):
proxy = {'host': gajim.config.get_per('proxies', p, 'host')} proxy = {'host': gajim.config.get_per('proxies', p, 'host')}
proxy['port'] = gajim.config.get_per('proxies', p, 'port') proxy['port'] = gajim.config.get_per('proxies', p, 'port')
@ -1376,14 +1397,13 @@ class Connection:
p = 5222 p = 5222
# autodetect [for SSL in 5223/443 and for TLS if broadcasted] # autodetect [for SSL in 5223/443 and for TLS if broadcasted]
secur = None secur = None
use_srv = gajim.config.get_per('accounts', self.name, 'use_srv')
if usessl: if usessl:
p = 5223 p = 5223
secur = 1 # 1 means force SSL no matter what the port will be secur = 1 # 1 means force SSL no matter what the port will be
use_srv = False # wants ssl? disable srv lookup use_srv = False # wants ssl? disable srv lookup
if gajim.config.get_per('accounts', self.name, 'use_custom_host'): if use_custom:
h = gajim.config.get_per('accounts', self.name, 'custom_host') h = custom_h
p = gajim.config.get_per('accounts', self.name, 'custom_port') p = custom_p
use_srv = False use_srv = False
# SRV resolver # SRV resolver
@ -1417,16 +1437,21 @@ class Connection:
if not self.connected: # We went offline during connecting process if not self.connected: # We went offline during connecting process
return None return None
if not con_type: if not con_type:
gajim.log.debug('Could not connect to %s' % self.name) gajim.log.debug('Could not connect to %s' % h)
if not self.retrycount: if not self.retrycount:
self.connected = 0 self.connected = 0
self.dispatch('STATUS', 'offline') self.dispatch('STATUS', 'offline')
self.dispatch('ERROR', (_('Could not connect to "%s"') % self.name, self.dispatch('ERROR', (_('Could not connect to "%s"') % h,
_('Check your connection or try again later.'))) _('Check your connection or try again later.')))
return None return None
self.peerhost = con.get_peerhost()
gajim.log.debug(_('Connected to server with %s') % con_type) gajim.log.debug(_('Connected to server with %s') % con_type)
return con, con_type
def connect_and_auth(self):
con, con_type = self.connect()
if not con_type:
return None
self.peerhost = con.get_peerhost()
# notify the gui about con_type # notify the gui about con_type
self.dispatch('CON_TYPE', con_type) self.dispatch('CON_TYPE', con_type)
@ -1474,12 +1499,16 @@ class Connection:
con.RegisterHandler('message', self._StanzaArrivedCB) con.RegisterHandler('message', self._StanzaArrivedCB)
con.RegisterEventHandler(self._event_dispatcher) con.RegisterEventHandler(self._event_dispatcher)
name = gajim.config.get_per('accounts', self.name, 'name')
hostname = gajim.config.get_per('accounts', self.name, 'hostname')
resource = gajim.config.get_per('accounts', self.name, 'resource')
try: try:
auth = con.auth(name, self.password, resource, 1) auth = con.auth(name, self.password, resource, 1)
except IOError: #probably a timeout except IOError: #probably a timeout
self.connected = 0 self.connected = 0
self.dispatch('STATUS', 'offline') self.dispatch('STATUS', 'offline')
self.dispatch('ERROR', (_('Could not connect to "%s"') % self.name, self.dispatch('ERROR', (_('Could not connect to "%s"') % hostname,
_('Check your connection or try again later'))) _('Check your connection or try again later')))
return None return None
if not self.connected: # We went offline during connecting process if not self.connected: # We went offline during connecting process
@ -1493,10 +1522,10 @@ class Connection:
self.connected = 2 self.connected = 2
return con # return connection return con # return connection
else: else:
gajim.log.debug("Couldn't authenticate to %s" % self.name) gajim.log.debug("Couldn't authenticate to %s" % hostname)
self.connected = 0 self.connected = 0
self.dispatch('STATUS', 'offline') self.dispatch('STATUS', 'offline')
self.dispatch('ERROR', (_('Authentication failed with "%s"') % self.name, self.dispatch('ERROR', (_('Authentication failed with "%s"') % hostname,
_('Please check your login and password for correctness.'))) _('Please check your login and password for correctness.')))
return None return None
# END connect # END connect
@ -1576,7 +1605,7 @@ class Connection:
def connect_and_init(self, show, msg, signed): def connect_and_init(self, show, msg, signed):
self.continue_connect_info = [show, msg, signed] self.continue_connect_info = [show, msg, signed]
self.connection = self.connect() self.connection = self.connect_and_auth()
def change_status(self, show, msg, sync = False, auto = False): def change_status(self, show, msg, sync = False, auto = False):
if sync: if sync:
@ -1786,45 +1815,16 @@ class Connection:
# If a connection already exist we cannot create a new account # If a connection already exist we cannot create a new account
if self.connection: if self.connection:
return return
p = config['proxy'] config['name'] = name
if p and p in gajim.config.get_per('proxies'): con, con_type = self.connect(config)
proxy = {'host': gajim.config.get_per('proxies', p, 'host')}
proxy['port'] = gajim.config.get_per('proxies', p, 'port')
proxy['user'] = gajim.config.get_per('proxies', p, 'user')
proxy['password'] = gajim.config.get_per('proxies', p, 'pass')
else:
proxy = None
if gajim.verbose:
c = common.xmpp.Client(server = config['hostname'])
else:
c = common.xmpp.Client(server = config['hostname'], debug = [])
common.xmpp.dispatcher.DefaultTimeout = 45
c.UnregisterDisconnectHandler(c.DisconnectHandler)
c.RegisterDisconnectHandler(self._disconnectedCB)
h = config['hostname']
p = 5222
usessl = None
if usessl: #FIXME: we cannot create an account if we want ssl connection to create it
p = 5223
if config['use_custom_host']:
h = config['custom_host']
p = config['custom_port']
secur = None # autodetect [for SSL in 5223/443 and for TLS if broadcasted]
if usessl:
secur=1 #1 means force SSL no matter what the port is
con_type = c.connect((h, p), proxy = proxy, secure=secur)#FIXME: blocking
if not con_type: if not con_type:
gajim.log.debug("Couldn't connect to %s" % name) return None
self.dispatch('ERROR', (_('Could not connect to "%s"') % name,
_('Check your connection or try again later.')))
return False
gajim.log.debug(_('Connected to server with %s'), con_type)
c.RegisterEventHandler(self._event_dispatcher) con.RegisterEventHandler(self._event_dispatcher)
self.new_account_info = config self.new_account_info = config
self.connection = c self.connection = con
self.name = name self.name = name
common.xmpp.features.getRegInfo(c, config['hostname']) common.xmpp.features.getRegInfo(con, config['hostname'])
def account_changed(self, new_name): def account_changed(self, new_name):
self.name = new_name self.name = new_name
@ -2053,7 +2053,7 @@ class Connection:
def unregister_account(self): def unregister_account(self):
if self.connected == 0: if self.connected == 0:
self.connection = self.connect() self.connection = self.connect_and_auth()
if self.connected > 1: if self.connected > 1:
hostname = gajim.config.get_per('accounts', self.name, 'hostname') hostname = gajim.config.get_per('accounts', self.name, 'hostname')
iq = common.xmpp.Iq(typ = 'set', to = hostname) iq = common.xmpp.Iq(typ = 'set', to = hostname)