Skip to content
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 10 additions & 4 deletions interactions/client/auto_shard_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
import time
from datetime import datetime
from collections import defaultdict
from typing import TYPE_CHECKING, Optional
from typing import TYPE_CHECKING, Optional, List

import interactions.api.events as events
from interactions.api.events import ShardConnect
Expand Down Expand Up @@ -35,6 +35,8 @@ def __init__(self, *args, **kwargs) -> None:
self.auto_sharding = "total_shards" not in kwargs
super().__init__(*args, **kwargs)

self.only_shards: Optional[List[int]] = kwargs.get("only_shards", None)

self._connection_state = None

self._connection_states: list[ConnectionState] = []
Expand Down Expand Up @@ -244,9 +246,13 @@ async def login(self, token: str | None = None) -> None:
)

self.logger.debug(f"Starting bot with {self.total_shards} shard{'s' if self.total_shards != 1 else ''}")
self._connection_states: list[ConnectionState] = [
ConnectionState(self, self.intents, shard_id) for shard_id in range(self.total_shards)
]

if self.only_shards:
self._connection_states = [ConnectionState(self, self.intents, shard_id) for shard_id in self.only_shards]
else:
self._connection_states = [
ConnectionState(self, self.intents, shard_id) for shard_id in range(self.total_shards)
]

async def change_presence(
self,
Expand Down