|  |  | @ -46,6 +46,7 @@ import org.whispersystems.textsecure.push.PushDestination; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.whispersystems.textsecure.push.PushMessageProtos.PushMessageContent; |  |  |  | import org.whispersystems.textsecure.push.PushMessageProtos.PushMessageContent; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.whispersystems.textsecure.push.PushServiceSocket; |  |  |  | import org.whispersystems.textsecure.push.PushServiceSocket; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.whispersystems.textsecure.push.RateLimitException; |  |  |  | import org.whispersystems.textsecure.push.RateLimitException; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | import org.whispersystems.textsecure.push.UnregisteredUserException; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.whispersystems.textsecure.storage.SessionRecordV2; |  |  |  | import org.whispersystems.textsecure.storage.SessionRecordV2; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.whispersystems.textsecure.util.InvalidNumberException; |  |  |  | import org.whispersystems.textsecure.util.InvalidNumberException; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -83,6 +84,10 @@ public class PushTransport extends BaseTransport { | 
			
		
	
		
		
			
				
					
					|  |  |  |       socket.sendMessage(destination, pushBody); |  |  |  |       socket.sendMessage(destination, pushBody); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       context.sendBroadcast(constructSentIntent(context, message.getId(), message.getType(), true)); |  |  |  |       context.sendBroadcast(constructSentIntent(context, message.getId(), message.getType(), true)); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } catch (UnregisteredUserException e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       Log.w("PushTransport", e); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       destroySessions(e.getAddresses()); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       throw new IOException("Not push registered after all."); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } catch (RateLimitException e) { |  |  |  |     } catch (RateLimitException e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       Log.w("PushTransport", e); |  |  |  |       Log.w("PushTransport", e); | 
			
		
	
		
		
			
				
					
					|  |  |  |       throw new IOException("Rate limit exceeded."); |  |  |  |       throw new IOException("Rate limit exceeded."); | 
			
		
	
	
		
		
			
				
					|  |  | @ -128,6 +133,10 @@ public class PushTransport extends BaseTransport { | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       socket.sendMessage(destinations, pushBodies); |  |  |  |       socket.sendMessage(destinations, pushBodies); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } catch (UnregisteredUserException e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       Log.w("PushTransport", e); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       destroySessions(e.getAddresses()); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       throw new IOException("No push registered after all."); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } catch (RateLimitException e) { |  |  |  |     } catch (RateLimitException e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       Log.w("PushTransport", e); |  |  |  |       Log.w("PushTransport", e); | 
			
		
	
		
		
			
				
					
					|  |  |  |       throw new IOException("Rate limit exceeded."); |  |  |  |       throw new IOException("Rate limit exceeded."); | 
			
		
	
	
		
		
			
				
					|  |  | @ -188,4 +197,16 @@ public class PushTransport extends BaseTransport { | 
			
		
	
		
		
			
				
					
					|  |  |  |       throw new AssertionError("Unknown ciphertext type: " + message.getType()); |  |  |  |       throw new AssertionError("Unknown ciphertext type: " + message.getType()); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   private void destroySessions(List<String> unregisteredUsers) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     for (String unregisteredUser : unregisteredUsers) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       Log.w("PushTransport", "Destroying session for: " + unregisteredUser); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       try { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         Recipients recipients = RecipientFactory.getRecipientsFromString(context, unregisteredUser, false); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         SessionRecordV2.delete(context, recipients.getPrimaryRecipient()); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       } catch (RecipientFormattingException e) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         Log.w("PushTransport", e); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					|  |  | 
 |