better database handling, rwlock daily, some minor other improvements
This commit is contained in:
@@ -1,22 +1,22 @@
|
|||||||
use crate::common::{Context, Error};
|
|
||||||
|
use crate::common::{self, Context, Error};
|
||||||
use poise::serenity_prelude as serenity;
|
use poise::serenity_prelude as serenity;
|
||||||
|
|
||||||
/// Tells you what your or someone else's balance is
|
/// Tells you what your or someone else's balance is
|
||||||
#[poise::command(slash_command, prefix_command, aliases("bal"))]
|
#[poise::command(slash_command, prefix_command, aliases("bal"))]
|
||||||
pub async fn balance(ctx: Context<'_>, user: Option<serenity::User>) -> Result<(), Error> {
|
pub async fn balance(ctx: Context<'_>, user: Option<serenity::User>) -> Result<(), Error> {
|
||||||
let user = user.as_ref().unwrap_or(ctx.author());
|
let user = user.as_ref().unwrap_or(ctx.author());
|
||||||
let data = ctx.data();
|
let db = &ctx.data().database;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
let wealth = super::get_balance(user.id, db).await?;
|
let wealth = super::get_balance(user.id, db).await?;
|
||||||
|
|
||||||
ctx.reply(format!("{} **{}** token(s).",
|
common::no_ping_reply(&ctx, format!("{} **{}** token(s).",
|
||||||
if user.id == ctx.author().id {
|
if user.id == ctx.author().id {
|
||||||
"You have".to_string()
|
"You have".to_string()
|
||||||
} else {
|
} else {
|
||||||
format!("{} has", user.name)
|
format!("{} has", user)
|
||||||
}, wealth)).await?;
|
}, wealth)
|
||||||
|
).await?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,30 +15,26 @@ fn format_duration(duration: Duration) -> String {
|
|||||||
#[poise::command(slash_command, prefix_command)]
|
#[poise::command(slash_command, prefix_command)]
|
||||||
pub async fn daily(ctx: Context<'_>) -> Result<(), Error> {
|
pub async fn daily(ctx: Context<'_>) -> Result<(), Error> {
|
||||||
let data = ctx.data();
|
let data = ctx.data();
|
||||||
let mut db = data.database.lock().await;
|
let user = ctx.author().id;
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
let id = ctx.author().id;
|
let day_ago = Instant::now() - Duration::from_secs(24 * 60 * 60);
|
||||||
|
let last = *data.dailies.read().await.get(&user).unwrap_or(&day_ago);
|
||||||
|
|
||||||
let mut dailies = data.dailies.lock().await;
|
if last <= day_ago {
|
||||||
|
data.dailies.write().await.insert(user, Instant::now());
|
||||||
|
|
||||||
match dailies.get_mut(&id) {
|
let db = &data.database;
|
||||||
Some(daily) => {
|
let mut tx = db.begin().await?;
|
||||||
|
|
||||||
if daily.elapsed() >= Duration::from_secs(24 * 60 * 60) {
|
let bal = super::get_balance(user, &mut *tx).await?;
|
||||||
*daily = Instant::now();
|
super::change_balance(user, bal + 50, &mut *tx).await?;
|
||||||
super::add_balance(id, 50, db).await?;
|
|
||||||
ctx.reply("Added **50** credits to your account!").await?;
|
tx.commit().await?;
|
||||||
} else {
|
|
||||||
let until_next_daily = Duration::from_secs(24 * 60 * 60) - daily.elapsed();
|
ctx.reply(format!("**50** tokens have been added to your balance.")).await?;
|
||||||
ctx.reply(format!("Your next daily will be available in **{}**.", format_duration(until_next_daily))).await?;
|
} else {
|
||||||
}
|
let next = Duration::from_secs(24 * 60 * 60) - last.elapsed();
|
||||||
},
|
ctx.reply(format!("Your next daily will be available in **{}**.", format_duration(next))).await?;
|
||||||
None => {
|
|
||||||
dailies.insert(id.clone(), Instant::now());
|
|
||||||
super::add_balance(id, 50, db).await?;
|
|
||||||
ctx.reply("Added **50** credits to your account!").await?;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|||||||
@@ -9,23 +9,23 @@ pub async fn give(ctx: Context<'_>, user: serenity::User, #[min = 1] amount: i32
|
|||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
|
|
||||||
let data = ctx.data();
|
let mut tx = ctx.data().database.begin().await?;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
let author_balance = super::get_balance(ctx.author().id, db).await?;
|
let author_balance = super::get_balance(ctx.author().id, &mut *tx).await?;
|
||||||
|
|
||||||
if author_balance < amount {
|
if author_balance < amount {
|
||||||
ctx.reply(format!("You do not have a high enough balance (**{author_balance}**) to complete this transaction.")).await?;
|
ctx.reply(format!("You do not have a high enough balance (**{author_balance}**) to complete this transaction.")).await?;
|
||||||
} else {
|
} else {
|
||||||
let author_new_balance = author_balance - amount;
|
let author_new_balance = author_balance - amount;
|
||||||
let reciever_new_balance = super::get_balance(user.id, db).await? + amount;
|
let reciever_new_balance = super::get_balance(user.id, &mut *tx).await? + amount;
|
||||||
|
|
||||||
super::change_balance(user.id, reciever_new_balance, db).await?;
|
super::change_balance(user.id, reciever_new_balance, &mut *tx).await?;
|
||||||
super::change_balance(ctx.author().id, author_new_balance, db).await?;
|
super::change_balance(ctx.author().id, author_new_balance, &mut *tx).await?;
|
||||||
|
|
||||||
ctx.reply(format!("You've given **{}** **{}** tokens!", user.display_name(), amount)).await?;
|
ctx.reply(format!("You've given **{}** **{}** tokens!", user.display_name(), amount)).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tx.commit().await?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
0
src/commands/gambling/leaderboard.rs
Normal file
0
src/commands/gambling/leaderboard.rs
Normal file
@@ -3,12 +3,16 @@ pub mod balance;
|
|||||||
pub mod give;
|
pub mod give;
|
||||||
pub mod wager;
|
pub mod wager;
|
||||||
pub mod daily;
|
pub mod daily;
|
||||||
|
pub mod leaderboard;
|
||||||
|
|
||||||
use crate::common::Error;
|
use crate::common::Error;
|
||||||
use poise::serenity_prelude::UserId;
|
use poise::serenity_prelude::UserId;
|
||||||
use sqlx::{Row, PgConnection};
|
use sqlx::{Row, PgExecutor};
|
||||||
|
|
||||||
pub async fn get_balance(id: UserId, db: &mut PgConnection) -> Result<i32, Error> {
|
pub async fn get_balance<'a, E>(id: UserId, db: E) -> Result<i32, Error>
|
||||||
|
where
|
||||||
|
E: PgExecutor<'a>,
|
||||||
|
{
|
||||||
let row = sqlx::query("SELECT balance FROM bank WHERE id = $1")
|
let row = sqlx::query("SELECT balance FROM bank WHERE id = $1")
|
||||||
.bind(id.get() as i64)
|
.bind(id.get() as i64)
|
||||||
.fetch_one(db).await.ok();
|
.fetch_one(db).await.ok();
|
||||||
@@ -22,7 +26,10 @@ pub async fn get_balance(id: UserId, db: &mut PgConnection) -> Result<i32, Error
|
|||||||
Ok(balance)
|
Ok(balance)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn change_balance(id: UserId, balance: i32, db: &mut PgConnection) -> Result<(), Error> {
|
pub async fn change_balance<'a, E>(id: UserId, balance: i32, db: E) -> Result<(), Error>
|
||||||
|
where
|
||||||
|
E: PgExecutor<'a>,
|
||||||
|
{
|
||||||
sqlx::query("INSERT INTO bank (id, balance) VALUES ($1, $2) ON CONFLICT (id) DO UPDATE SET balance = EXCLUDED.balance")
|
sqlx::query("INSERT INTO bank (id, balance) VALUES ($1, $2) ON CONFLICT (id) DO UPDATE SET balance = EXCLUDED.balance")
|
||||||
.bind(id.get() as i64)
|
.bind(id.get() as i64)
|
||||||
.bind(balance)
|
.bind(balance)
|
||||||
@@ -30,9 +37,3 @@ pub async fn change_balance(id: UserId, balance: i32, db: &mut PgConnection) ->
|
|||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn add_balance(id: UserId, amount: i32, db: &mut PgConnection) -> Result<(), Error> {
|
|
||||||
let balance = get_balance(id, db).await?;
|
|
||||||
change_balance(id, balance + amount, db).await?;
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
@@ -4,14 +4,17 @@ use crate::common::{Context, Error};
|
|||||||
#[poise::command(slash_command, prefix_command)]
|
#[poise::command(slash_command, prefix_command)]
|
||||||
pub async fn wager(
|
pub async fn wager(
|
||||||
ctx: Context<'_>,
|
ctx: Context<'_>,
|
||||||
#[min = 1]
|
|
||||||
amount: i32) -> Result<(), Error>
|
amount: i32) -> Result<(), Error>
|
||||||
{
|
{
|
||||||
let data = ctx.data();
|
// #[min = 1] does not appear to work with prefix commands
|
||||||
let mut db = data.database.lock().await;
|
if amount < 1 {
|
||||||
let db = db.as_mut();
|
ctx.reply("you cannot wager less than 1 token.").await?;
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
let mut wealth = super::get_balance(ctx.author().id, db).await?;
|
let mut tx = ctx.data().database.begin().await?;
|
||||||
|
|
||||||
|
let mut wealth = super::get_balance(ctx.author().id, &mut *tx).await?;
|
||||||
|
|
||||||
if wealth < amount {
|
if wealth < amount {
|
||||||
ctx.reply(format!("You do not have enough tokens (**{}**) to wager this amount.",
|
ctx.reply(format!("You do not have enough tokens (**{}**) to wager this amount.",
|
||||||
@@ -29,7 +32,9 @@ pub async fn wager(
|
|||||||
amount, wealth)).await?;
|
amount, wealth)).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
super::change_balance(ctx.author().id, wealth, db).await?;
|
super::change_balance(ctx.author().id, wealth, &mut *tx).await?;
|
||||||
|
|
||||||
|
tx.commit().await?;
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
@@ -42,12 +42,10 @@ pub async fn color(ctx: Context<'_>, color: String) -> Result<(), Error> {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let data = ctx.data();
|
let mut tx = ctx.data().database.begin().await?;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
if let Some(guild) = ctx.guild_id() {
|
if let Some(guild) = ctx.guild_id() {
|
||||||
match super::get_user_role(ctx.author().id, guild, db).await? {
|
match super::get_user_role(ctx.author().id, guild, &mut *tx).await? {
|
||||||
Some(role) => {
|
Some(role) => {
|
||||||
guild.edit_role(ctx, role, EditRole::new().colour(color)).await?;
|
guild.edit_role(ctx, role, EditRole::new().colour(color)).await?;
|
||||||
let role = guild.role(ctx, role).await?;
|
let role = guild.role(ctx, role).await?;
|
||||||
@@ -66,7 +64,7 @@ pub async fn color(ctx: Context<'_>, color: String) -> Result<(), Error> {
|
|||||||
.bind(ctx.author().id.get() as i64)
|
.bind(ctx.author().id.get() as i64)
|
||||||
.bind(role.id.get() as i64)
|
.bind(role.id.get() as i64)
|
||||||
.bind(guild.get() as i64)
|
.bind(guild.get() as i64)
|
||||||
.execute(db).await?;
|
.execute(&mut *tx).await?;
|
||||||
|
|
||||||
let member = guild.member(ctx, ctx.author().id).await?;
|
let member = guild.member(ctx, ctx.author().id).await?;
|
||||||
member.add_role(ctx, role.clone()).await?;
|
member.add_role(ctx, role.clone()).await?;
|
||||||
|
|||||||
@@ -4,9 +4,7 @@ use crate::common::{Context, Error};
|
|||||||
/// Remove and delete your personal role
|
/// Remove and delete your personal role
|
||||||
#[poise::command(slash_command, prefix_command)]
|
#[poise::command(slash_command, prefix_command)]
|
||||||
pub async fn disown(ctx: Context<'_>) -> Result<(), Error> {
|
pub async fn disown(ctx: Context<'_>) -> Result<(), Error> {
|
||||||
let data = ctx.data();
|
let db = &ctx.data().database;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
if let Some(guild) = ctx.guild_id() {
|
if let Some(guild) = ctx.guild_id() {
|
||||||
if let Some(role) = super::get_user_role(ctx.author().id, guild, db).await? {
|
if let Some(role) = super::get_user_role(ctx.author().id, guild, db).await? {
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
|
|
||||||
use crate::common::{Context, Error};
|
use crate::common::{Context, Error};
|
||||||
use sqlx::{PgConnection, Row};
|
use sqlx::{PgExecutor, Row};
|
||||||
use poise::serenity_prelude::{RoleId, UserId, GuildId};
|
use poise::serenity_prelude::{RoleId, UserId, GuildId};
|
||||||
|
|
||||||
mod register;
|
mod register;
|
||||||
@@ -26,7 +26,10 @@ pub async fn role(_ctx: Context<'_>) -> Result<(), Error> {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_user_role(user: UserId, guild: GuildId, db: &mut PgConnection) -> Result<Option<RoleId>, Error> {
|
pub async fn get_user_role<'a, E>(user: UserId, guild: GuildId, db: E) -> Result<Option<RoleId>, Error>
|
||||||
|
where
|
||||||
|
E: PgExecutor<'a>,
|
||||||
|
{
|
||||||
match sqlx::query("SELECT roleid FROM selfroles WHERE userid = $1 AND guildid = $2")
|
match sqlx::query("SELECT roleid FROM selfroles WHERE userid = $1 AND guildid = $2")
|
||||||
.bind(user.get() as i64)
|
.bind(user.get() as i64)
|
||||||
.bind(guild.get() as i64)
|
.bind(guild.get() as i64)
|
||||||
|
|||||||
@@ -6,9 +6,7 @@ use poise::serenity_prelude::EditRole;
|
|||||||
/// Change the name of your personal role
|
/// Change the name of your personal role
|
||||||
#[poise::command(slash_command, prefix_command)]
|
#[poise::command(slash_command, prefix_command)]
|
||||||
pub async fn name(ctx: Context<'_>, name: String) -> Result<(), Error> {
|
pub async fn name(ctx: Context<'_>, name: String) -> Result<(), Error> {
|
||||||
let data = ctx.data();
|
let db = &ctx.data().database;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
if let Some(guild) = ctx.guild_id() {
|
if let Some(guild) = ctx.guild_id() {
|
||||||
let role = match super::get_user_role(ctx.author().id, guild, db).await? {
|
let role = match super::get_user_role(ctx.author().id, guild, db).await? {
|
||||||
|
|||||||
@@ -6,34 +6,31 @@ use poise::serenity_prelude as serenity;
|
|||||||
/// Register an existing role as a user's custom role
|
/// Register an existing role as a user's custom role
|
||||||
#[poise::command(slash_command, prefix_command, required_permissions = "MANAGE_ROLES")]
|
#[poise::command(slash_command, prefix_command, required_permissions = "MANAGE_ROLES")]
|
||||||
pub async fn register(ctx: Context<'_>, user: serenity::User, role: serenity::Role) -> Result<(), Error> {
|
pub async fn register(ctx: Context<'_>, user: serenity::User, role: serenity::Role) -> Result<(), Error> {
|
||||||
let data = ctx.data();
|
let mut tx = ctx.data().database.begin().await?;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
if let Some(guild) = ctx.guild_id() {
|
if let Some(guild) = ctx.guild_id() {
|
||||||
match super::get_user_role(user.id, guild, db).await? {
|
match super::get_user_role(user.id, guild, &mut *tx).await? {
|
||||||
Some(role) => {
|
Some(role) => {
|
||||||
let role = guild.role(ctx, role).await?;
|
let role = guild.role(ctx, role).await?;
|
||||||
common::no_ping_reply(&ctx, format!("{} already has the role {} registered.", user, role)).await?;
|
common::no_ping_reply(&ctx, format!("{} already has the role {} registered.", user, role)).await?;
|
||||||
Ok(())
|
|
||||||
},
|
},
|
||||||
None => {
|
None => {
|
||||||
sqlx::query("INSERT INTO selfroles (userid, guildid, roleid) VALUES ($1, $2, $3)")
|
sqlx::query("INSERT INTO selfroles (userid, guildid, roleid) VALUES ($1, $2, $3)")
|
||||||
.bind(user.id.get() as i64)
|
.bind(user.id.get() as i64)
|
||||||
.bind(guild.get() as i64)
|
.bind(guild.get() as i64)
|
||||||
.bind(role.id.get() as i64)
|
.bind(role.id.get() as i64)
|
||||||
.execute(db).await?;
|
.execute(&mut *tx).await?;
|
||||||
|
|
||||||
let member = guild.member(ctx, user.id).await?;
|
let member = guild.member(ctx, user.id).await?;
|
||||||
member.add_role(ctx, role.id).await?;
|
member.add_role(ctx, role.id).await?;
|
||||||
|
|
||||||
common::no_ping_reply(&ctx, format!("{} now has {} set as their personal role.", user, role)).await?;
|
common::no_ping_reply(&ctx, format!("{} now has {} set as their personal role.", user, role)).await?;
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ctx.reply("This command can only be run in a guild!").await?;
|
ctx.reply("This command can only be run in a guild!").await?;
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tx.commit().await?;
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,9 +6,7 @@ use poise::serenity_prelude as serenity;
|
|||||||
/// force remove someone's role (this does not delete the role)
|
/// force remove someone's role (this does not delete the role)
|
||||||
#[poise::command(slash_command, prefix_command, required_permissions = "MANAGE_ROLES")]
|
#[poise::command(slash_command, prefix_command, required_permissions = "MANAGE_ROLES")]
|
||||||
pub async fn remove(ctx: Context<'_>, user: serenity::User) -> Result<(), Error> {
|
pub async fn remove(ctx: Context<'_>, user: serenity::User) -> Result<(), Error> {
|
||||||
let data = ctx.data();
|
let db = &ctx.data().database;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
if let Some(guild) = ctx.guild_id() {
|
if let Some(guild) = ctx.guild_id() {
|
||||||
match super::get_user_role(user.id, guild, db).await? {
|
match super::get_user_role(user.id, guild, db).await? {
|
||||||
|
|||||||
@@ -8,9 +8,7 @@ use sqlx::Row;
|
|||||||
/// Let you know who is the owner of a role.
|
/// Let you know who is the owner of a role.
|
||||||
#[poise::command(slash_command, prefix_command)]
|
#[poise::command(slash_command, prefix_command)]
|
||||||
pub async fn whois(ctx: Context<'_>, role: serenity::Role) -> Result<(), Error> {
|
pub async fn whois(ctx: Context<'_>, role: serenity::Role) -> Result<(), Error> {
|
||||||
let data = ctx.data();
|
let db = &ctx.data().database;
|
||||||
let mut db = data.database.lock().await;
|
|
||||||
let db = db.as_mut();
|
|
||||||
|
|
||||||
if let Some(guild) = ctx.guild_id() {
|
if let Some(guild) = ctx.guild_id() {
|
||||||
let row = match sqlx::query("SELECT userid FROM selfroles WHERE roleid = $1")
|
let row = match sqlx::query("SELECT userid FROM selfroles WHERE roleid = $1")
|
||||||
|
|||||||
@@ -1,15 +1,15 @@
|
|||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use tokio::sync::Mutex;
|
use tokio::sync::{Mutex, RwLock};
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use poise::{serenity_prelude::UserId, ReplyHandle};
|
use poise::{serenity_prelude::UserId, ReplyHandle};
|
||||||
use sqlx::PgConnection;
|
use sqlx::{Pool, Postgres};
|
||||||
|
|
||||||
pub struct Data {
|
pub struct Data {
|
||||||
pub database: Arc<Mutex<PgConnection>>,
|
pub database: Pool<Postgres>,
|
||||||
pub mentions: Arc<Mutex<HashMap<UserId, std::time::Instant>>>,
|
pub mentions: Arc<Mutex<HashMap<UserId, std::time::Instant>>>,
|
||||||
|
|
||||||
/// last time the user redeemed a daily
|
/// last time the user redeemed a daily
|
||||||
pub dailies: Arc<Mutex<HashMap<UserId, std::time::Instant>>>,
|
pub dailies: Arc<RwLock<HashMap<UserId, std::time::Instant>>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub type Error = Box<dyn std::error::Error + Send + Sync>;
|
pub type Error = Box<dyn std::error::Error + Send + Sync>;
|
||||||
|
|||||||
16
src/main.rs
16
src/main.rs
@@ -9,11 +9,11 @@ use std::env;
|
|||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
use poise::serenity_prelude::{self as serenity};
|
use poise::serenity_prelude::{self as serenity};
|
||||||
use tokio::sync::Mutex;
|
use tokio::sync::{Mutex, RwLock};
|
||||||
|
|
||||||
use clap::Parser;
|
use clap::Parser;
|
||||||
|
|
||||||
use sqlx::{PgConnection, Connection};
|
use sqlx::postgres::PgPoolOptions;
|
||||||
|
|
||||||
#[derive(Parser, Debug)]
|
#[derive(Parser, Debug)]
|
||||||
struct BotArgs {
|
struct BotArgs {
|
||||||
@@ -68,7 +68,9 @@ async fn main() -> Result<(), Error> {
|
|||||||
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?;
|
||||||
|
|
||||||
let mut database = PgConnection::connect(&database_url).await?;
|
let database = PgPoolOptions::new()
|
||||||
|
.max_connections(5)
|
||||||
|
.connect(&database_url).await?;
|
||||||
|
|
||||||
sqlx::query(
|
sqlx::query(
|
||||||
r#"
|
r#"
|
||||||
@@ -77,7 +79,7 @@ async fn main() -> Result<(), Error> {
|
|||||||
balance INT
|
balance INT
|
||||||
)
|
)
|
||||||
"#,
|
"#,
|
||||||
).execute(&mut database).await?;
|
).execute(&database).await?;
|
||||||
|
|
||||||
sqlx::query(
|
sqlx::query(
|
||||||
r#"
|
r#"
|
||||||
@@ -88,14 +90,14 @@ async fn main() -> Result<(), Error> {
|
|||||||
UNIQUE (userid, guildid)
|
UNIQUE (userid, guildid)
|
||||||
)
|
)
|
||||||
"#,
|
"#,
|
||||||
).execute(&mut database).await?;
|
).execute(&database).await?;
|
||||||
|
|
||||||
println!("Bot is ready!");
|
println!("Bot is ready!");
|
||||||
|
|
||||||
Ok(Data {
|
Ok(Data {
|
||||||
database: Arc::new(Mutex::new(database)),
|
database,
|
||||||
mentions: Arc::new(Mutex::new(HashMap::new())),
|
mentions: Arc::new(Mutex::new(HashMap::new())),
|
||||||
dailies: Arc::new(Mutex::new(HashMap::new())),
|
dailies: Arc::new(RwLock::new(HashMap::new())),
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user