mirror of
				https://github.com/Rapptz/discord.py.git
				synced 2025-10-24 18:13:00 +00:00 
			
		
		
		
	Add guild_ready_timeout to control the timeout of GUILD_CREATE stream
This also fixes a timing issue where READY would take far too long to load for big bot authors. Closes #4112
This commit is contained in:
		| @@ -159,6 +159,11 @@ class Client: | ||||
|         WebSocket in the case of not receiving a HEARTBEAT_ACK. Useful if | ||||
|         processing the initial packets take too long to the point of disconnecting | ||||
|         you. The default timeout is 60 seconds. | ||||
|     guild_ready_timeout: :class:`float` | ||||
|         The maximum number of seconds to wait for the GUILD_CREATE stream to end before | ||||
|         preparing the member cache and firing READY. The default timeout is 2 seconds. | ||||
|  | ||||
|         .. versionadded:: 1.4 | ||||
|     guild_subscriptions: :class:`bool` | ||||
|         Whether to dispatching of presence or typing events. Defaults to ``True``. | ||||
|  | ||||
|   | ||||
| @@ -80,6 +80,10 @@ class ConnectionState: | ||||
|         self._ready_task = None | ||||
|         self._fetch_offline = options.get('fetch_offline_members', True) | ||||
|         self.heartbeat_timeout = options.get('heartbeat_timeout', 60.0) | ||||
|         self.guild_ready_timeout = options.get('guild_ready_timeout', 2.0) | ||||
|         if self.guild_ready_timeout < 0: | ||||
|             raise ValueError('guild_ready_timeout cannot be negative') | ||||
|  | ||||
|         self.guild_subscriptions = options.get('guild_subscriptions', True) | ||||
|         allowed_mentions = options.get('allowed_mentions') | ||||
|  | ||||
| @@ -369,10 +373,10 @@ class ConnectionState: | ||||
|             # only real bots wait for GUILD_CREATE streaming | ||||
|             if self.is_bot: | ||||
|                 while True: | ||||
|                     # this snippet of code is basically waiting 2 seconds | ||||
|                     # this snippet of code is basically waiting N seconds | ||||
|                     # until the last GUILD_CREATE was sent | ||||
|                     try: | ||||
|                         await asyncio.wait_for(launch.wait(), timeout=2.0) | ||||
|                         await asyncio.wait_for(launch.wait(), timeout=self.guild_ready_timeout) | ||||
|                     except asyncio.TimeoutError: | ||||
|                         break | ||||
|                     else: | ||||
| @@ -1086,10 +1090,10 @@ class AutoShardedConnectionState(ConnectionState): | ||||
|         await self.shards_launched.wait() | ||||
|         launch = self._ready_state.launch | ||||
|         while True: | ||||
|             # this snippet of code is basically waiting 2 * shard_ids seconds | ||||
|             # this snippet of code is basically waiting N seconds | ||||
|             # until the last GUILD_CREATE was sent | ||||
|             try: | ||||
|                 await asyncio.wait_for(launch.wait(), timeout=2.0 * len(self.shard_ids)) | ||||
|                 await asyncio.wait_for(launch.wait(), timeout=self.guild_ready_timeout) | ||||
|             except asyncio.TimeoutError: | ||||
|                 break | ||||
|             else: | ||||
|   | ||||
		Reference in New Issue
	
	Block a user