mirror of
				https://github.com/LonamiWebs/Telethon.git
				synced 2025-10-25 21:21:24 +03:00 
			
		
		
		
	Start the background thread only if the user is authorized
This commit is contained in:
		
							parent
							
								
									4ba12e717f
								
							
						
					
					
						commit
						12c6d4d3ac
					
				|  | @ -126,6 +126,9 @@ class TelegramClient(TelegramBareClient): | ||||||
|         self._phone_code_hash = None |         self._phone_code_hash = None | ||||||
|         self._phone = None |         self._phone = None | ||||||
| 
 | 
 | ||||||
|  |         # Save whether the user is authorized here (a.k.a. logged in) | ||||||
|  |         self._authorized = False | ||||||
|  | 
 | ||||||
|         # Uploaded files cache so subsequent calls are instant |         # Uploaded files cache so subsequent calls are instant | ||||||
|         self._upload_cache = {} |         self._upload_cache = {} | ||||||
| 
 | 
 | ||||||
|  | @ -161,25 +164,16 @@ class TelegramClient(TelegramBareClient): | ||||||
|         else: |         else: | ||||||
|             ok = super().connect(exported_auth=exported_auth) |             ok = super().connect(exported_auth=exported_auth) | ||||||
| 
 | 
 | ||||||
|         # The main TelegramClient is the only one that will have |         if not ok: | ||||||
|         # constant_read, since it's also the only one who receives |             return False | ||||||
|         # updates and need to be processed as soon as they occur. |  | ||||||
|         # |  | ||||||
|         # TODO Allow to disable this to avoid the creation of a new thread |  | ||||||
|         # if the user is not going to work with updates at all? Whether to |  | ||||||
|         # read constantly or not for updates needs to be known before hand, |  | ||||||
|         # and further updates won't be able to be added unless allowing to |  | ||||||
|         # switch the mode on the fly. |  | ||||||
|         if ok and self._recv_thread is None: |  | ||||||
|             self._recv_thread = Thread( |  | ||||||
|                 name='ReadThread', daemon=True, |  | ||||||
|                 target=self._recv_thread_impl |  | ||||||
|             ) |  | ||||||
|             self._recv_thread.start() |  | ||||||
|             if self.updates.polling: |  | ||||||
|                 self.sync_updates() |  | ||||||
| 
 | 
 | ||||||
|         return ok |         try: | ||||||
|  |             self.sync_updates() | ||||||
|  |             self._set_connected_and_authorized() | ||||||
|  |         except UnauthorizedError: | ||||||
|  |             self._authorized = False | ||||||
|  | 
 | ||||||
|  |         return True | ||||||
| 
 | 
 | ||||||
|     def disconnect(self): |     def disconnect(self): | ||||||
|         """Disconnects from the Telegram server |         """Disconnects from the Telegram server | ||||||
|  | @ -291,7 +285,7 @@ class TelegramClient(TelegramBareClient): | ||||||
|     def is_user_authorized(self): |     def is_user_authorized(self): | ||||||
|         """Has the user been authorized yet |         """Has the user been authorized yet | ||||||
|            (code request sent and confirmed)?""" |            (code request sent and confirmed)?""" | ||||||
|         return self.session and self.get_me() is not None |         return self._authorized | ||||||
| 
 | 
 | ||||||
|     def send_code_request(self, phone): |     def send_code_request(self, phone): | ||||||
|         """Sends a code request to the specified phone number""" |         """Sends a code request to the specified phone number""" | ||||||
|  | @ -337,33 +331,37 @@ class TelegramClient(TelegramBareClient): | ||||||
|             except (PhoneCodeEmptyError, PhoneCodeExpiredError, |             except (PhoneCodeEmptyError, PhoneCodeExpiredError, | ||||||
|                     PhoneCodeHashEmptyError, PhoneCodeInvalidError): |                     PhoneCodeHashEmptyError, PhoneCodeInvalidError): | ||||||
|                 return None |                 return None | ||||||
| 
 |  | ||||||
|         elif password: |         elif password: | ||||||
|             salt = self(GetPasswordRequest()).current_salt |             salt = self(GetPasswordRequest()).current_salt | ||||||
|             result = self( |             result = self(CheckPasswordRequest( | ||||||
|                 CheckPasswordRequest(utils.get_password_hash(password, salt))) |                 utils.get_password_hash(password, salt) | ||||||
| 
 |             )) | ||||||
|         elif bot_token: |         elif bot_token: | ||||||
|             result = self(ImportBotAuthorizationRequest( |             result = self(ImportBotAuthorizationRequest( | ||||||
|                 flags=0, bot_auth_token=bot_token, |                 flags=0, bot_auth_token=bot_token, | ||||||
|                 api_id=self.api_id, api_hash=self.api_hash)) |                 api_id=self.api_id, api_hash=self.api_hash | ||||||
| 
 |             )) | ||||||
|         else: |         else: | ||||||
|             raise ValueError( |             raise ValueError( | ||||||
|                 'You must provide a phone and a code the first time, ' |                 'You must provide a phone and a code the first time, ' | ||||||
|                 'and a password only if an RPCError was raised before.') |                 'and a password only if an RPCError was raised before.' | ||||||
|  |             ) | ||||||
| 
 | 
 | ||||||
|  |         self._set_connected_and_authorized() | ||||||
|         return result.user |         return result.user | ||||||
| 
 | 
 | ||||||
|     def sign_up(self, code, first_name, last_name=''): |     def sign_up(self, code, first_name, last_name=''): | ||||||
|         """Signs up to Telegram. Make sure you sent a code request first!""" |         """Signs up to Telegram. Make sure you sent a code request first!""" | ||||||
|         return self(SignUpRequest( |         result = self(SignUpRequest( | ||||||
|             phone_number=self._phone, |             phone_number=self._phone, | ||||||
|             phone_code_hash=self._phone_code_hash, |             phone_code_hash=self._phone_code_hash, | ||||||
|             phone_code=code, |             phone_code=code, | ||||||
|             first_name=first_name, |             first_name=first_name, | ||||||
|             last_name=last_name |             last_name=last_name | ||||||
|         )).user |         )) | ||||||
|  | 
 | ||||||
|  |         self._set_connected_and_authorized() | ||||||
|  |         return result.user | ||||||
| 
 | 
 | ||||||
|     def log_out(self): |     def log_out(self): | ||||||
|         """Logs out and deletes the current session. |         """Logs out and deletes the current session. | ||||||
|  | @ -997,11 +995,7 @@ class TelegramClient(TelegramBareClient): | ||||||
|            called automatically on connection if self.updates.enabled = True, |            called automatically on connection if self.updates.enabled = True, | ||||||
|            otherwise it should be called manually after enabling updates. |            otherwise it should be called manually after enabling updates. | ||||||
|         """ |         """ | ||||||
|         try: |         self.updates.process(self(GetStateRequest())) | ||||||
|             self.updates.process(self(GetStateRequest())) |  | ||||||
|             return True |  | ||||||
|         except UnauthorizedError: |  | ||||||
|             return False |  | ||||||
| 
 | 
 | ||||||
|     def add_update_handler(self, handler): |     def add_update_handler(self, handler): | ||||||
|         """Adds an update handler (a function which takes a TLObject, |         """Adds an update handler (a function which takes a TLObject, | ||||||
|  | @ -1021,6 +1015,14 @@ class TelegramClient(TelegramBareClient): | ||||||
| 
 | 
 | ||||||
|     # Constant read |     # Constant read | ||||||
| 
 | 
 | ||||||
|  |     def _set_connected_and_authorized(self): | ||||||
|  |         self._authorized = True | ||||||
|  |         self._recv_thread = Thread( | ||||||
|  |             name='ReadThread', daemon=True, | ||||||
|  |             target=self._recv_thread_impl | ||||||
|  |         ) | ||||||
|  |         self._recv_thread.start() | ||||||
|  | 
 | ||||||
|     # By using this approach, another thread will be |     # By using this approach, another thread will be | ||||||
|     # created and started upon connection to constantly read |     # created and started upon connection to constantly read | ||||||
|     # from the other end. Otherwise, manual calls to .receive() |     # from the other end. Otherwise, manual calls to .receive() | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user