send otr messages when contacts comes online
This commit is contained in:
		
							parent
							
								
									e353a1c109
								
							
						
					
					
						commit
						18871230e1
					
				| 
						 | 
					@ -73,7 +73,7 @@ public class PresenceParser extends AbstractParser {
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					updateLastseen(packet, account,true);
 | 
										updateLastseen(packet, account,true);
 | 
				
			||||||
					mXmppConnectionService.onContactStatusChanged
 | 
										mXmppConnectionService.onContactStatusChanged
 | 
				
			||||||
							.onContactStatusChanged(contact);
 | 
												.onContactStatusChanged(contact,true);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			} else if (type.equals("unavailable")) {
 | 
								} else if (type.equals("unavailable")) {
 | 
				
			||||||
				if (fromParts.length != 2) {
 | 
									if (fromParts.length != 2) {
 | 
				
			||||||
| 
						 | 
					@ -82,7 +82,7 @@ public class PresenceParser extends AbstractParser {
 | 
				
			||||||
					contact.removePresence(fromParts[1]);
 | 
										contact.removePresence(fromParts[1]);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
				mXmppConnectionService.onContactStatusChanged
 | 
									mXmppConnectionService.onContactStatusChanged
 | 
				
			||||||
						.onContactStatusChanged(contact);
 | 
											.onContactStatusChanged(contact,false);
 | 
				
			||||||
			} else if (type.equals("subscribe")) {
 | 
								} else if (type.equals("subscribe")) {
 | 
				
			||||||
				if (contact.getOption(Contact.Options.PREEMPTIVE_GRANT)) {
 | 
									if (contact.getOption(Contact.Options.PREEMPTIVE_GRANT)) {
 | 
				
			||||||
					mXmppConnectionService.sendPresenceUpdatesTo(contact);
 | 
										mXmppConnectionService.sendPresenceUpdatesTo(contact);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -98,10 +98,13 @@ public class XmppConnectionService extends Service {
 | 
				
			||||||
	public OnContactStatusChanged onContactStatusChanged = new OnContactStatusChanged() {
 | 
						public OnContactStatusChanged onContactStatusChanged = new OnContactStatusChanged() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		@Override
 | 
							@Override
 | 
				
			||||||
		public void onContactStatusChanged(Contact contact) {
 | 
							public void onContactStatusChanged(Contact contact, boolean online) {
 | 
				
			||||||
			Conversation conversation = findActiveConversation(contact);
 | 
								Conversation conversation = findActiveConversation(contact);
 | 
				
			||||||
			if (conversation != null) {
 | 
								if (conversation != null) {
 | 
				
			||||||
				conversation.endOtrIfNeeded();
 | 
									conversation.endOtrIfNeeded();
 | 
				
			||||||
 | 
									if (online&&(contact.getPresences().size() == 1)) {
 | 
				
			||||||
 | 
										sendUnsendMessages(conversation);
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -3,5 +3,5 @@ package eu.siacs.conversations.xmpp;
 | 
				
			||||||
import eu.siacs.conversations.entities.Contact;
 | 
					import eu.siacs.conversations.entities.Contact;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public interface OnContactStatusChanged {
 | 
					public interface OnContactStatusChanged {
 | 
				
			||||||
	public void onContactStatusChanged(Contact contact);
 | 
						public void onContactStatusChanged(Contact contact, boolean online);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue