2023-01-09 18:38:08 -05:00
|
|
|
use poise::serenity_prelude as serenity;
|
2023-01-10 13:11:06 -05:00
|
|
|
use rand::seq::IteratorRandom;
|
|
|
|
use std::{
|
|
|
|
fs::File,
|
|
|
|
io::{BufRead, BufReader}
|
|
|
|
};
|
2023-01-09 18:38:08 -05:00
|
|
|
|
|
|
|
struct Data {}
|
|
|
|
|
|
|
|
type Error = Box<dyn std::error::Error + Send + Sync>;
|
|
|
|
type Context<'a> = poise::Context<'a, Data, Error>;
|
|
|
|
|
2023-01-09 18:41:05 -05:00
|
|
|
// Basically a ping command. Should be moved to a mod.
|
2023-01-09 18:38:08 -05:00
|
|
|
#[poise::command(slash_command, prefix_command)]
|
|
|
|
async fn slur(
|
|
|
|
ctx: Context<'_>,
|
|
|
|
) -> Result<(), Error> {
|
2023-01-10 13:11:06 -05:00
|
|
|
let file = File::open("quotes.txt").unwrap_or_else(|_e| panic!("Quote file missing."));
|
|
|
|
let file = BufReader::new(file);
|
|
|
|
let quotes = file.lines().map(|res| res.expect("Failed to read line."));
|
|
|
|
let quote = quotes.choose(&mut rand::thread_rng()).expect("No lines in file.");
|
|
|
|
|
|
|
|
ctx.say(quote).await?;
|
2023-01-09 18:38:08 -05:00
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::main]
|
|
|
|
async fn main() {
|
|
|
|
let framework = poise::Framework::builder()
|
|
|
|
.options(poise::FrameworkOptions {
|
2023-01-10 13:11:06 -05:00
|
|
|
commands: vec![slur()], // IntelliJ doesn't like this, but it's fine.
|
2023-01-09 18:38:08 -05:00
|
|
|
..Default::default()
|
|
|
|
})
|
|
|
|
.token(std::env::var("DISCORD_TOKEN").expect("missing DISCORD_TOKEN"))
|
|
|
|
.intents(serenity::GatewayIntents::non_privileged())
|
|
|
|
.setup(|ctx, _ready, framework| {
|
|
|
|
Box::pin(async move {
|
|
|
|
poise::builtins::register_globally(ctx, &framework.options().commands).await?;
|
|
|
|
Ok(Data {})
|
|
|
|
})
|
|
|
|
});
|
|
|
|
|
|
|
|
framework.run().await.unwrap();
|
2023-01-09 18:41:05 -05:00
|
|
|
}
|