Files
songbird/src/serenity.rs
Kyle Simpson c1d93f790c Docs: Fix module docs for songbird::tracks.
Module docs mistakenly used the old doc-link format, so removing `create_player` never fired an error! These have also been partially rewritten to explain the role of `Track` and `TrackHandle`.

Includes some other misc fixes to links, mention of `TrackHandle::action` for metadata handling, etc.

Closes #140.
2023-11-20 00:02:54 +00:00

90 lines
2.8 KiB
Rust

//! Compatibility and convenience methods for working with [serenity].
//! Requires the `"serenity"` feature.
//!
//! [serenity]: https://crates.io/crates/serenity
use crate::{Config, Songbird};
use serenity::{
client::{ClientBuilder, Context},
prelude::TypeMapKey,
};
use std::sync::Arc;
/// Zero-size type used to retrieve the registered [`Songbird`] instance
/// from serenity's inner [`TypeMap`].
///
/// [`Songbird`]: Songbird
/// [`TypeMap`]: serenity::prelude::TypeMap
pub struct SongbirdKey;
impl TypeMapKey for SongbirdKey {
type Value = Arc<Songbird>;
}
/// Installs a new songbird instance into the serenity client.
///
/// This should be called after any uses of `ClientBuilder::type_map`.
pub fn register(client_builder: ClientBuilder) -> ClientBuilder {
let voice = Songbird::serenity();
register_with(client_builder, voice)
}
/// Installs a given songbird instance into the serenity client.
///
/// This should be called after any uses of `ClientBuilder::type_map`.
pub fn register_with(client_builder: ClientBuilder, voice: Arc<Songbird>) -> ClientBuilder {
client_builder
.voice_manager_arc(voice.clone())
.type_map_insert::<SongbirdKey>(voice)
}
/// Installs a given songbird instance into the serenity client.
///
/// This should be called after any uses of `ClientBuilder::type_map`.
pub fn register_from_config(client_builder: ClientBuilder, config: Config) -> ClientBuilder {
let voice = Songbird::serenity_from_config(config);
register_with(client_builder, voice)
}
/// Retrieve the Songbird voice client from a serenity context's
/// shared key-value store.
pub async fn get(ctx: &Context) -> Option<Arc<Songbird>> {
let data = ctx.data.read().await;
data.get::<SongbirdKey>().cloned()
}
/// Helper trait to add installation/creation methods to serenity's
/// `ClientBuilder`.
///
/// These install the client to receive gateway voice events, and
/// store an easily accessible reference to Songbird's managers.
pub trait SerenityInit {
/// Registers a new Songbird voice system with serenity, storing it for easy
/// access via [`get`].
///
/// [`get`]: get
#[must_use]
fn register_songbird(self) -> Self;
/// Registers a given Songbird voice system with serenity, as above.
#[must_use]
fn register_songbird_with(self, voice: Arc<Songbird>) -> Self;
/// Registers a Songbird voice system serenity, based on the given configuration.
#[must_use]
fn register_songbird_from_config(self, config: Config) -> Self;
}
impl SerenityInit for ClientBuilder {
fn register_songbird(self) -> Self {
register(self)
}
fn register_songbird_with(self, voice: Arc<Songbird>) -> Self {
register_with(self, voice)
}
fn register_songbird_from_config(self, config: Config) -> Self {
register_from_config(self, config)
}
}