|  |  | @ -21,7 +21,6 @@ import org.thoughtcrime.securesms.jobs.GcmRefreshJob; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.push.TextSecureCommunicationFactory; |  |  |  | import org.thoughtcrime.securesms.push.TextSecureCommunicationFactory; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.recipients.Recipient; |  |  |  | import org.thoughtcrime.securesms.recipients.Recipient; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.recipients.RecipientFactory; |  |  |  | import org.thoughtcrime.securesms.recipients.RecipientFactory; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.recipients.RecipientFormattingException; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.util.DirectoryHelper; |  |  |  | import org.thoughtcrime.securesms.util.DirectoryHelper; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.util.TextSecurePreferences; |  |  |  | import org.thoughtcrime.securesms.util.TextSecurePreferences; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.thoughtcrime.securesms.util.Util; |  |  |  | import org.thoughtcrime.securesms.util.Util; | 
			
		
	
	
		
		
			
				
					|  |  | @ -34,6 +33,7 @@ import org.whispersystems.textsecure.api.TextSecureAccountManager; | 
			
		
	
		
		
			
				
					
					|  |  |  | import org.whispersystems.textsecure.api.push.exceptions.ExpectationFailedException; |  |  |  | import org.whispersystems.textsecure.api.push.exceptions.ExpectationFailedException; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | import java.io.IOException; |  |  |  | import java.io.IOException; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | import java.lang.ref.WeakReference; | 
			
		
	
		
		
			
				
					
					|  |  |  | import java.util.List; |  |  |  | import java.util.List; | 
			
		
	
		
		
			
				
					
					|  |  |  | import java.util.concurrent.ExecutorService; |  |  |  | import java.util.concurrent.ExecutorService; | 
			
		
	
		
		
			
				
					
					|  |  |  | import java.util.concurrent.Executors; |  |  |  | import java.util.concurrent.Executors; | 
			
		
	
	
		
		
			
				
					|  |  | @ -77,7 +77,7 @@ public class RegistrationService extends Service { | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   private volatile RegistrationState registrationState = new RegistrationState(RegistrationState.STATE_IDLE); |  |  |  |   private volatile RegistrationState registrationState = new RegistrationState(RegistrationState.STATE_IDLE); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   private volatile Handler                 registrationStateHandler; |  |  |  |   private volatile WeakReference<Handler>  registrationStateHandler; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   private volatile ChallengeReceiver       challengeReceiver; |  |  |  |   private volatile ChallengeReceiver       challengeReceiver; | 
			
		
	
		
		
			
				
					
					|  |  |  |   private          String                  challenge; |  |  |  |   private          String                  challenge; | 
			
		
	
		
		
			
				
					
					|  |  |  |   private          long                    verificationStartTime; |  |  |  |   private          long                    verificationStartTime; | 
			
		
	
	
		
		
			
				
					|  |  | @ -298,6 +298,8 @@ public class RegistrationService extends Service { | 
			
		
	
		
		
			
				
					
					|  |  |  |   private void setState(RegistrationState state) { |  |  |  |   private void setState(RegistrationState state) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     this.registrationState = state; |  |  |  |     this.registrationState = state; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     Handler registrationStateHandler = this.registrationStateHandler.get(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (registrationStateHandler != null) { |  |  |  |     if (registrationStateHandler != null) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       registrationStateHandler.obtainMessage(state.state, state).sendToTarget(); |  |  |  |       registrationStateHandler.obtainMessage(state.state, state).sendToTarget(); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
	
		
		
			
				
					|  |  | @ -319,7 +321,7 @@ public class RegistrationService extends Service { | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   public void setRegistrationStateHandler(Handler registrationStateHandler) { |  |  |  |   public void setRegistrationStateHandler(Handler registrationStateHandler) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     this.registrationStateHandler = registrationStateHandler; |  |  |  |     this.registrationStateHandler = new WeakReference<>(registrationStateHandler); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   public class RegistrationServiceBinder extends Binder { |  |  |  |   public class RegistrationServiceBinder extends Binder { | 
			
		
	
	
		
		
			
				
					|  |  | 
 |