[red-agent] autoreconnect to MUC automatically. Fixes #5257
This commit is contained in:
		
							parent
							
								
									815255d317
								
							
						
					
					
						commit
						378cdaeaf0
					
				
					 2 changed files with 38 additions and 0 deletions
				
			
		|  | @ -162,6 +162,8 @@ class Config: | ||||||
| 		'restore_timeout': [opt_int, 60, _('How many minutes should last lines from previous conversation last.')], | 		'restore_timeout': [opt_int, 60, _('How many minutes should last lines from previous conversation last.')], | ||||||
| 		'muc_restore_lines': [opt_int, 20, _('How many lines to request to server when entering a groupchat.')], | 		'muc_restore_lines': [opt_int, 20, _('How many lines to request to server when entering a groupchat.')], | ||||||
| 		'muc_restore_timeout': [opt_int, 60, _('How many minutes back to request logs when a entering a groupchat.')], | 		'muc_restore_timeout': [opt_int, 60, _('How many minutes back to request logs when a entering a groupchat.')], | ||||||
|  | 		'muc_autorejoin_timeout': [opt_int, 1, _('How many seconds to wait before trying to autorejoin to a conference you are being disconnected from. Set to 0 to disable autorejoining.')], | ||||||
|  | 		'muc_autorejoin_on_kick': [opt_bool, False, 'Should autorejoin be activated when we are being kicked from a conference?'], | ||||||
| 		'send_on_ctrl_enter': [opt_bool, False, _('Send message on Ctrl+Enter and with Enter make new line (Mirabilis ICQ Client default behaviour).')], | 		'send_on_ctrl_enter': [opt_bool, False, _('Send message on Ctrl+Enter and with Enter make new line (Mirabilis ICQ Client default behaviour).')], | ||||||
| 		'show_roster_on_startup': [opt_bool, True], | 		'show_roster_on_startup': [opt_bool, True], | ||||||
| 		'key_up_lines': [opt_int, 25, _('How many lines to store for Ctrl+KeyUP.')], | 		'key_up_lines': [opt_int, 25, _('How many lines to store for Ctrl+KeyUP.')], | ||||||
|  |  | ||||||
|  | @ -194,6 +194,14 @@ class GroupchatControl(ChatControlBase): | ||||||
| 		self.is_continued=is_continued | 		self.is_continued=is_continued | ||||||
| 		self.is_anonymous = True | 		self.is_anonymous = True | ||||||
| 
 | 
 | ||||||
|  | 		# Controls the state of autorejoin. | ||||||
|  | 		# None - autorejoin is neutral. | ||||||
|  | 		# False - autorejoin is to be prevented (gets reset to initial state in | ||||||
|  | 		#         got_connected()). | ||||||
|  | 		# int - autorejoin is being active and working (gets reset to initial | ||||||
|  | 		#       state in got_connected()). | ||||||
|  | 		self.autorejoin = None | ||||||
|  | 
 | ||||||
| 		self.actions_button = self.xml.get_widget('muc_window_actions_button') | 		self.actions_button = self.xml.get_widget('muc_window_actions_button') | ||||||
| 		id_ = self.actions_button.connect('clicked', | 		id_ = self.actions_button.connect('clicked', | ||||||
| 			self.on_actions_button_clicked) | 			self.on_actions_button_clicked) | ||||||
|  | @ -981,6 +989,11 @@ class GroupchatControl(ChatControlBase): | ||||||
| 		self.draw_banner_text() | 		self.draw_banner_text() | ||||||
| 
 | 
 | ||||||
| 	def got_connected(self): | 	def got_connected(self): | ||||||
|  | 		# Make autorejoin stop. | ||||||
|  | 		if self.autorejoin: | ||||||
|  | 			gobject.source_remove(self.autorejoin) | ||||||
|  | 		self.autorejoin = None | ||||||
|  | 
 | ||||||
| 		gajim.gc_connected[self.account][self.room_jid] = True | 		gajim.gc_connected[self.account][self.room_jid] = True | ||||||
| 		ChatControlBase.got_connected(self) | 		ChatControlBase.got_connected(self) | ||||||
| 		# We don't redraw the whole banner here, because only icon change | 		# We don't redraw the whole banner here, because only icon change | ||||||
|  | @ -1015,6 +1028,20 @@ class GroupchatControl(ChatControlBase): | ||||||
| 		if self.parent_win: | 		if self.parent_win: | ||||||
| 			self.parent_win.redraw_tab(self) | 			self.parent_win.redraw_tab(self) | ||||||
| 
 | 
 | ||||||
|  | 		# Autorejoin stuff goes here. | ||||||
|  | 		if self.autorejoin is None: | ||||||
|  | 			ar_to = gajim.config.get('muc_autorejoin_timeout') | ||||||
|  | 			if ar_to: | ||||||
|  | 				self.autorejoin = gobject.timeout_add_seconds(ar_to, self.rejoin) | ||||||
|  | 
 | ||||||
|  | 	def rejoin(self): | ||||||
|  | 		if not self.autorejoin: | ||||||
|  | 			return False | ||||||
|  | 		password = gajim.gc_passwords.get(self.room_jid, '') | ||||||
|  | 		gajim.connections[self.account].join_gc(self.nick, self.room_jid, | ||||||
|  | 			password) | ||||||
|  | 		return True | ||||||
|  | 
 | ||||||
| 	def draw_roster(self): | 	def draw_roster(self): | ||||||
| 		self.list_treeview.get_model().clear() | 		self.list_treeview.get_model().clear() | ||||||
| 		for nick in gajim.contacts.get_nick_list(self.account, self.room_jid): | 		for nick in gajim.contacts.get_nick_list(self.account, self.room_jid): | ||||||
|  | @ -1173,6 +1200,9 @@ class GroupchatControl(ChatControlBase): | ||||||
| 							'who': actor, | 							'who': actor, | ||||||
| 							'reason': reason } | 							'reason': reason } | ||||||
| 					self.print_conversation(s, 'info', tim=tim) | 					self.print_conversation(s, 'info', tim=tim) | ||||||
|  | 					if nick == self.nick and not gajim.config.get( | ||||||
|  | 					'muc_autorejoin_on_kick'): | ||||||
|  | 						self.autorejoin = False | ||||||
| 				elif '301' in statusCode: | 				elif '301' in statusCode: | ||||||
| 					if actor is None: # do not print 'banned by None' | 					if actor is None: # do not print 'banned by None' | ||||||
| 						s = _('%(nick)s has been banned: %(reason)s') % { | 						s = _('%(nick)s has been banned: %(reason)s') % { | ||||||
|  | @ -1184,6 +1214,8 @@ class GroupchatControl(ChatControlBase): | ||||||
| 							'who': actor, | 							'who': actor, | ||||||
| 							'reason': reason } | 							'reason': reason } | ||||||
| 					self.print_conversation(s, 'info', tim=tim) | 					self.print_conversation(s, 'info', tim=tim) | ||||||
|  | 					if nick == self.nick: | ||||||
|  | 						self.autorejoin = False | ||||||
| 				elif '303' in statusCode: # Someone changed his or her nick | 				elif '303' in statusCode: # Someone changed his or her nick | ||||||
| 					if new_nick == self.new_nick or nick == self.nick: | 					if new_nick == self.new_nick or nick == self.nick: | ||||||
| 						# We changed our nick | 						# We changed our nick | ||||||
|  | @ -1853,6 +1885,10 @@ class GroupchatControl(ChatControlBase): | ||||||
| 	def shutdown(self, status='offline'): | 	def shutdown(self, status='offline'): | ||||||
| 		# destroy banner tooltip - bug #pygtk for that! | 		# destroy banner tooltip - bug #pygtk for that! | ||||||
| 		self.subject_tooltip.destroy() | 		self.subject_tooltip.destroy() | ||||||
|  | 
 | ||||||
|  | 		# Preventing autorejoin from being activated | ||||||
|  | 		self.autorejoin = False | ||||||
|  | 
 | ||||||
| 		if self.room_jid in gajim.gc_connected[self.account] and \ | 		if self.room_jid in gajim.gc_connected[self.account] and \ | ||||||
| 		gajim.gc_connected[self.account][self.room_jid]: | 		gajim.gc_connected[self.account][self.room_jid]: | ||||||
| 			# Tell connection to note the date we disconnect to avoid duplicate | 			# Tell connection to note the date we disconnect to avoid duplicate | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue