|
@ -149,7 +149,7 @@ class VoiceProtocol: |
|
|
""" |
|
|
""" |
|
|
raise NotImplementedError |
|
|
raise NotImplementedError |
|
|
|
|
|
|
|
|
async def connect(self, *, timeout: float, reconnect: bool) -> None: |
|
|
async def connect(self, *, timeout: float, reconnect: bool, self_deaf: bool = False, self_mute: bool = False) -> None: |
|
|
"""|coro| |
|
|
"""|coro| |
|
|
|
|
|
|
|
|
An abstract method called when the client initiates the connection request. |
|
|
An abstract method called when the client initiates the connection request. |
|
@ -169,6 +169,14 @@ class VoiceProtocol: |
|
|
The timeout for the connection. |
|
|
The timeout for the connection. |
|
|
reconnect: :class:`bool` |
|
|
reconnect: :class:`bool` |
|
|
Whether reconnection is expected. |
|
|
Whether reconnection is expected. |
|
|
|
|
|
self_mute: :class:`bool` |
|
|
|
|
|
Indicates if the client should be self-muted. |
|
|
|
|
|
|
|
|
|
|
|
.. versionadded: 2.0 |
|
|
|
|
|
self_deaf: :class:`bool` |
|
|
|
|
|
Indicates if the client should be self-deafened. |
|
|
|
|
|
|
|
|
|
|
|
.. versionadded: 2.0 |
|
|
""" |
|
|
""" |
|
|
raise NotImplementedError |
|
|
raise NotImplementedError |
|
|
|
|
|
|
|
@ -339,8 +347,8 @@ class VoiceClient(VoiceProtocol): |
|
|
|
|
|
|
|
|
self._voice_server_complete.set() |
|
|
self._voice_server_complete.set() |
|
|
|
|
|
|
|
|
async def voice_connect(self) -> None: |
|
|
async def voice_connect(self, self_deaf: bool = False, self_mute: bool = False) -> None: |
|
|
await self.channel.guild.change_voice_state(channel=self.channel) |
|
|
await self.channel.guild.change_voice_state(channel=self.channel, self_deaf=self_deaf, self_mute=self_mute) |
|
|
|
|
|
|
|
|
async def voice_disconnect(self) -> None: |
|
|
async def voice_disconnect(self) -> None: |
|
|
_log.info('The voice handshake is being terminated for Channel ID %s (Guild ID %s)', self.channel.id, self.guild.id) |
|
|
_log.info('The voice handshake is being terminated for Channel ID %s (Guild ID %s)', self.channel.id, self.guild.id) |
|
@ -367,7 +375,7 @@ class VoiceClient(VoiceProtocol): |
|
|
self._connected.set() |
|
|
self._connected.set() |
|
|
return ws |
|
|
return ws |
|
|
|
|
|
|
|
|
async def connect(self, *, reconnect: bool, timeout: float) -> None: |
|
|
async def connect(self, *, reconnect: bool, timeout: float, self_deaf: bool = False, self_mute: bool = False) -> None: |
|
|
_log.info('Connecting to voice...') |
|
|
_log.info('Connecting to voice...') |
|
|
self.timeout = timeout |
|
|
self.timeout = timeout |
|
|
|
|
|
|
|
@ -381,7 +389,7 @@ class VoiceClient(VoiceProtocol): |
|
|
] |
|
|
] |
|
|
|
|
|
|
|
|
# Start the connection flow |
|
|
# Start the connection flow |
|
|
await self.voice_connect() |
|
|
await self.voice_connect(self_deaf=self_deaf, self_mute=self_mute) |
|
|
|
|
|
|
|
|
try: |
|
|
try: |
|
|
await utils.sane_wait_for(futures, timeout=timeout) |
|
|
await utils.sane_wait_for(futures, timeout=timeout) |
|
|