[Kjell Braden] Fix OTR for chat and GC queries for real now.
This commit is contained in:
		
							parent
							
								
									573568f9ac
								
							
						
					
					
						commit
						d2731268d7
					
				
					 2 changed files with 25 additions and 5 deletions
				
			
		
							
								
								
									
										28
									
								
								src/gajim.py
									
										
									
									
									
								
							
							
						
						
									
										28
									
								
								src/gajim.py
									
										
									
									
									
								
							|  | @ -286,17 +286,37 @@ class OtrlMessageAppOps: | ||||||
| 		tim = time.localtime() | 		tim = time.localtime() | ||||||
| 
 | 
 | ||||||
| 		if not no_print: | 		if not no_print: | ||||||
| 			ctrl = gajim.interface.msg_win_mgr.get_control( | 			ctrl = self.get_control(fjid, account) | ||||||
| 					gajim.get_jid_without_resource(fjid), account) |  | ||||||
| 			if ctrl: | 			if ctrl: | ||||||
| 				ctrl.print_conversation_line(u" [OTR] %s"%msg, 'status', '', None) | 				ctrl.print_conversation_line(u" [OTR] %s"%msg, 'status', '', None) | ||||||
| 		id = gajim.logger.write('chat_msg_recv', fjid, message=msg, tim=tim) | 		id = gajim.logger.write('chat_msg_recv', fjid, message=msg, tim=tim) | ||||||
|  | 		# gajim.logger.write() only marks a message as unread (and so only | ||||||
|  | 		# returns an id) when fjid is a real contact (NOT if it's a GC private | ||||||
|  | 		# chat) | ||||||
| 		if id: | 		if id: | ||||||
| 			gajim.logger.set_read_messages([id]) | 			gajim.logger.set_read_messages([id]) | ||||||
|  | 	 | ||||||
|  | 	def get_control(self, fjid, account): | ||||||
|  | 		# first try to get the window with the full jid | ||||||
|  | 		ctrl = gajim.interface.msg_win_mgr.get_control(fjid, account) | ||||||
|  | 		if ctrl: | ||||||
|  | 			# got one, be happy | ||||||
|  | 			return ctrl | ||||||
|  | 		 | ||||||
|  | 		# otherwise try without the resource | ||||||
|  | 		ctrl = gajim.interface.msg_win_mgr.get_control( | ||||||
|  | 			gajim.get_jid_without_resource(fjid), account) | ||||||
|  | 		# but only use it when it is not a GC window | ||||||
|  | 		if ctrl and ctrl.TYPE_ID == message_control.TYPE_CHAT: | ||||||
|  | 			return ctrl | ||||||
| 
 | 
 | ||||||
| 	def policy(self, opdata=None, context=None): | 	def policy(self, opdata=None, context=None): | ||||||
| 		policy = gajim.config.get_per("contacts", | 		policy = gajim.config.get_per("contacts", context.username, | ||||||
| 			gajim.get_jid_without_resource(context.username), "otr_flags") | 			"otr_flags") | ||||||
|  | 		if policy <= 0: | ||||||
|  | 			policy = gajim.config.get_per("contacts", | ||||||
|  | 					gajim.get_jid_without_resource(context.username), | ||||||
|  | 					"otr_flags") | ||||||
| 		if policy <= 0: | 		if policy <= 0: | ||||||
| 			policy = gajim.config.get_per("accounts", opdata['account'], "otr_flags") | 			policy = gajim.config.get_per("accounts", opdata['account'], "otr_flags") | ||||||
| 		return policy | 		return policy | ||||||
|  |  | ||||||
|  | @ -224,7 +224,7 @@ class ContactOtrWindow: | ||||||
| 		otr_flags = gajim.config.get_per("contacts", self.contact.jid, | 		otr_flags = gajim.config.get_per("contacts", self.contact.jid, | ||||||
| 			"otr_flags") | 			"otr_flags") | ||||||
| 
 | 
 | ||||||
| 		if otr_flags > 0: | 		if otr_flags >= 0: | ||||||
| 			self.gw("otr_default_checkbutton").set_active(0) | 			self.gw("otr_default_checkbutton").set_active(0) | ||||||
| 			for w in self.gw("otr_settings_vbox").get_children(): | 			for w in self.gw("otr_settings_vbox").get_children(): | ||||||
| 				w.set_sensitive(True) | 				w.set_sensitive(True) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue