Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support for Soundboard and VC effects #9349

Merged
merged 35 commits into from
Oct 9, 2024

Conversation

codeofandrin
Copy link
Contributor

@codeofandrin codeofandrin commented Apr 9, 2023

Summary

Last updated: Sep 21, 2024
  • Bots can receive voice channel effects over gateway events
  • Bots can receive sounds over gateway events and over API requests
  • Bots can create, edit and delete sounds
  • Bots can send sounds

This PR includes

  • Support for voice channel effects
    • VoiceChannelEffect, VoiceChannelSoundEffect, VoiceChannelEffectAnimation models
    • VoiceChannelEffectAnimationType enum
    • on_voice_channel_effect event
  • Support for soundboard sounds
    • SoundboardSound, SoundboardDefaultSound models
    • create_, edit_, delete_ sound
    • fetch_ methods (default sounds, normal sounds, specific sound)
    • Request sounds over the gateway (may be superfluous since fetch_ methods exist) 
    • VoiceChannel.send_sound method
    • soundboard_sounds property and get_ methods (both for Guild and Client)
    • on_soundboard_sound_ events (create, update, delete) + GUILD_SOUNDBOARD_SOUNDS_UPDATE event (dispatches update event for every sound in the list)
  • Related Audit Log events
  • Intents.expressions -> emojis and emojis_and_stickers are now both aliases

Current Problems [solved]

All problems on Discord's side, which were stated in the related soundboard PR are fixed

  • There is no GET route for individual sounds or a guild's list of sounds. Guild sound lists can currently only be retrieved via the Gateway. GET routes should be added *
  • PATCHing a sound currently clears the sound's volume and emoji if those aren't included in the request. The PR documents this current behavior, let me know once it is fixed **
  • Looks like id and sound_id are always the same, but id is optional ***

* Now available
** The PR doesn't document this behaviour anymore
*** id has been removed

Others

Default sounds are identified with a sound_id, override_path has been removed

Related PRs: discord/discord-api-docs#6025 (voice channel effects), discord/discord-api-docs#6260 (soundboard)


Checklist

Testing pending

  • If code changes were made then they have been tested.
    • I have updated the documentation to reflect the changes.
  • This PR fixes an issue.
  • This PR adds something new (e.g. new method or parameters).
  • This PR is a breaking change (e.g. methods or parameters removed/renamed)
  • This PR is not a code change (e.g. documentation, README, ...)

Finished: VC effect + VC sound effect
Started: Soundboard support
@codeofandrin codeofandrin marked this pull request as draft April 9, 2023 14:27
@Rapptz Rapptz added the pending PR implements an in-progress or explicitly unreleased Discord feature label Apr 18, 2023
@SvenLie
Copy link

SvenLie commented Jun 20, 2023

When can we expect this to be undrafted and merged? @Puncher1

@codeofandrin
Copy link
Contributor Author

@SvenLie The GET method is still not supported which, at least for me, doesn't make sense to merge it yet.

@codeofandrin
Copy link
Contributor Author

Update

  • For the current status, please refer to the PR description
  • The 3.x checks are failing. Looks like there's an error in the installation, @Rapptz
  • Testing is pending, after that this PR is ready for review

@Rapptz
Copy link
Owner

Rapptz commented Oct 29, 2023

3.x is failing due to aiohttp not building on 3.12 and 3.x is latest Python, so CI is blocked on dependencies and not much I can do there.

@codeofandrin codeofandrin marked this pull request as ready for review November 2, 2023 19:14
@codeofandrin
Copy link
Contributor Author

This has been tested and is ready for review now.

@PaulMarisOUMary
Copy link

I believe the issues with 3.x have been resolved now. 🎉

Copy link
Owner

@Rapptz Rapptz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've only done a cursory pass at this. It has merge conflicts currently as well, though this feature is pretty complicated and definitely needs documentation on Discord's end for me to merge it.

There are a few things I'm kind of iffy about, some more important than others:

  1. The name SoundboardSound is pretty silly, I'm unsure if going Soudboard is any better but it doesn't read as oddly.
  2. The machinery to handle opcode 31 in the gateway seems very complicated for what it is. The chunking mechanism is the way it is because it's expected that multiple events flow in and it needs to be synced and waited. I have no reason to believe soundboard sounds operate the same way but I also have no idea if they do. I tried asking to get clarification on this though I haven't gotten a response yet. I'll update you when I do.

discord/channel.py Show resolved Hide resolved
discord/channel.py Outdated Show resolved Hide resolved
discord/channel.py Outdated Show resolved Hide resolved
discord/utils.py Outdated Show resolved Hide resolved
discord/channel.py Outdated Show resolved Hide resolved
discord/soundboard.py Outdated Show resolved Hide resolved
discord/state.py Outdated Show resolved Hide resolved
discord/asset.py Outdated Show resolved Hide resolved
@codeofandrin
Copy link
Contributor Author

Alright I'm done with the changes. Because of the name, how about just Sound? And should it be also applied for properties and attributes (e.g. Client.soundboard_sounds -> Client.sounds)?

@DA-344
Copy link
Contributor

DA-344 commented Jul 29, 2024

This will need changes because of the latests commits on the DDevs Docs PR: discord/discord-api-docs@ec86562

@codeofandrin
Copy link
Contributor Author

codeofandrin commented Aug 6, 2024

...
2. The machinery to handle opcode 31 in the gateway seems very complicated for what it is. The chunking mechanism is the way it is because it's expected that multiple events flow in and it needs to be synced and waited. I have no reason to believe soundboard sounds operate the same way but I also have no idea if they do. I tried asking to get clarification on this though I haven't gotten a response yet. I'll update you when I do.

@Rapptz You can now get soundboard sounds via GET /guilds/{guild_id}/soundboard-sounds, opcode 31 is now quite superfluous.

Edit
Except for receiving sounds for multiple guilds in one request 🤷‍♂️

@Rapptz
Copy link
Owner

Rapptz commented Aug 28, 2024

You can now get soundboard sounds via GET /guilds/{guild_id}/soundboard-sounds, opcode 31 is now quite superfluous.

If it's superfluous outside of multiple guilds -> sound then it should probably be removed. There isn't an immediate benefit to the complicated machinery being used for soundboards.

@codeofandrin codeofandrin marked this pull request as draft September 15, 2024 19:09
@codeofandrin codeofandrin marked this pull request as ready for review September 15, 2024 19:26
@codeofandrin
Copy link
Contributor Author

Messed up a bit (almost lost all changes lol), so I had to force push.

@codeofandrin
Copy link
Contributor Author

The soundboard PR on Discord's side is merged now as well.

@Rapptz Rapptz merged commit a70217a into Rapptz:master Oct 9, 2024
8 checks passed
@codeofandrin codeofandrin deleted the soundboard_vc_effects branch October 10, 2024 08:28
@owocado owocado mentioned this pull request Oct 10, 2024
6 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pending PR implements an in-progress or explicitly unreleased Discord feature
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants