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:
		
							parent
							
								
									dc0fa61cd6
								
							
						
					
					
						commit
						27ee476990
					
				
					 1 changed files with 57 additions and 57 deletions
				
			
		|  | @ -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) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue