add wager and balance commands
This commit is contained in:
1
Cargo.lock
generated
1
Cargo.lock
generated
@@ -121,6 +121,7 @@ version = "0.1.0"
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"dotenv",
|
"dotenv",
|
||||||
"poise",
|
"poise",
|
||||||
|
"rand",
|
||||||
"tokio",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
@@ -6,4 +6,5 @@ edition = "2021"
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
poise = "0.6.1"
|
poise = "0.6.1"
|
||||||
tokio = { version = "1", features = ["full"] }
|
tokio = { version = "1", features = ["full"] }
|
||||||
dotenv = "0.15.0"
|
dotenv = "0.15.0"
|
||||||
|
rand = "0.8.5"
|
||||||
39
src/main.rs
39
src/main.rs
@@ -1,8 +1,12 @@
|
|||||||
use std::env;
|
use std::env;
|
||||||
use std::iter;
|
use std::iter;
|
||||||
|
use tokio::sync::Mutex;
|
||||||
use poise::{serenity_prelude::{self as serenity, Colour}, CreateReply};
|
use poise::{serenity_prelude::{self as serenity, Colour}, CreateReply};
|
||||||
|
|
||||||
struct Data {}
|
struct Data {
|
||||||
|
tokens: Mutex<usize>,
|
||||||
|
}
|
||||||
|
|
||||||
type Error = Box<dyn std::error::Error + Send + Sync>;
|
type Error = Box<dyn std::error::Error + Send + Sync>;
|
||||||
type Context<'a> = poise::Context<'a, Data, Error>;
|
type Context<'a> = poise::Context<'a, Data, Error>;
|
||||||
|
|
||||||
@@ -100,11 +104,38 @@ async fn yeehaw(ctx: Context<'_>,
|
|||||||
height: usize) -> Result<(), Error> {
|
height: usize) -> Result<(), Error> {
|
||||||
ctx.reply(iter::repeat("\u{1F920}".to_string().repeat(width))
|
ctx.reply(iter::repeat("\u{1F920}".to_string().repeat(width))
|
||||||
.take(height)
|
.take(height)
|
||||||
.collect::<Vec<String>>()
|
.collect::<Vec<_>>()
|
||||||
.join("\n")).await?;
|
.join("\n")).await?;
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[poise::command(slash_command)]
|
||||||
|
async fn wager(ctx: Context<'_>, amount: usize) -> Result<(), Error> {
|
||||||
|
let mut wealth = ctx.data().tokens.lock().await;
|
||||||
|
|
||||||
|
if *wealth < amount {
|
||||||
|
ctx.reply("You do not have enough tokens to wager this amount.").await?;
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
|
if rand::random() {
|
||||||
|
*wealth += amount;
|
||||||
|
ctx.reply(format!("You just gained {} tokens! You now have **{}**.", amount, *wealth)).await?;
|
||||||
|
} else {
|
||||||
|
*wealth -= amount;
|
||||||
|
ctx.reply(format!("You've lost **{}** tokens, you now have **{}**.", amount, *wealth)).await?;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[poise::command(slash_command)]
|
||||||
|
async fn balance(ctx: Context<'_>) -> Result<(), Error> {
|
||||||
|
let wealth = ctx.data().tokens.lock().await;
|
||||||
|
ctx.reply(format!("You have **{}** tokens.", *wealth)).await?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
#[tokio::main]
|
#[tokio::main]
|
||||||
async fn main() -> Result<(), Error> {
|
async fn main() -> Result<(), Error> {
|
||||||
dotenv::dotenv().ok();
|
dotenv::dotenv().ok();
|
||||||
@@ -114,13 +145,13 @@ async fn main() -> Result<(), Error> {
|
|||||||
|
|
||||||
let framework = poise::Framework::builder()
|
let framework = poise::Framework::builder()
|
||||||
.options(poise::FrameworkOptions {
|
.options(poise::FrameworkOptions {
|
||||||
commands: vec![ping(), dox(), yeehaw()],
|
commands: vec![ping(), dox(), yeehaw(), wager(), balance()],
|
||||||
..Default::default()
|
..Default::default()
|
||||||
})
|
})
|
||||||
.setup(|ctx, _ready, framework| {
|
.setup(|ctx, _ready, framework| {
|
||||||
Box::pin(async move {
|
Box::pin(async move {
|
||||||
poise::builtins::register_globally(ctx, &framework.options().commands).await?;
|
poise::builtins::register_globally(ctx, &framework.options().commands).await?;
|
||||||
Ok(Data {})
|
Ok(Data { tokens: Mutex::new(100) })
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.build();
|
.build();
|
||||||
|
|||||||
Reference in New Issue
Block a user