use poise::serenity_prelude as serenity;
type Error = &'static str;
type Context<'a> = poise::Context<'a, (), Error>;
async fn my_check(ctx: Context<'_>) -> Result<bool, Error> {
println!(
"In command specific check: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
Ok(true)
}
async fn my_autocomplete(ctx: Context<'_>, _: &str) -> impl Iterator<Item = String> {
println!(
"In autocomplete: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
std::iter::empty()
}
#[poise::command(prefix_command, slash_command, check = "my_check")]
pub async fn invocation_data_test(
ctx: Context<'_>,
#[description = "Whether this command should succeed (yes if 0, no otherwise)"]
#[autocomplete = "my_autocomplete"]
should_succeed: u32,
) -> Result<(), Error> {
println!(
"In command: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
if should_succeed > 0 {
Ok(())
} else {
Err("")
}
}
#[tokio::main]
async fn main() {
let token = std::env::var("TOKEN").unwrap();
let intents =
serenity::GatewayIntents::non_privileged() | serenity::GatewayIntents::MESSAGE_CONTENT;
let framework = poise::Framework::builder()
.setup(move |ctx, _, framework| {
Box::pin(async move {
let commands =
poise::builtins::create_application_commands(&framework.options().commands);
serenity::GuildId::new(703332075914264606)
.set_commands(ctx, commands)
.await
.unwrap();
Ok(())
})
})
.options(poise::FrameworkOptions {
pre_command: |ctx| {
Box::pin(async move {
println!(
"In pre_command: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
})
},
command_check: Some(|ctx| {
Box::pin(async move {
println!("Writing invocation data!");
ctx.set_invocation_data("hello").await;
println!(
"In global check: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
Ok(true)
})
}),
post_command: |ctx| {
Box::pin(async move {
println!(
"In post_command: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
})
},
on_error: |err| {
Box::pin(async move {
match err {
poise::FrameworkError::Command { ctx, .. } => {
println!(
"In on_error: {:?}",
ctx.invocation_data::<&str>().await.as_deref()
);
}
err => poise::builtins::on_error(err).await.unwrap(),
}
})
},
commands: vec![invocation_data_test()],
prefix_options: poise::PrefixFrameworkOptions {
prefix: Some("~".into()),
..Default::default()
},
..Default::default()
})
.build();
let client = serenity::ClientBuilder::new(token, intents)
.framework(framework)
.await;
client.unwrap().start().await.unwrap();
}