discord-kurante/src/main.rs

63 lines
1.6 KiB
Rust
Raw Permalink Normal View History

2020-05-02 02:17:53 +00:00
use crate::commands::GENERAL_GROUP;
use crate::passive::Handler;
2020-05-02 05:04:51 +00:00
use env_logger;
use log::error;
use serenity::client::{validate_token, Client};
2020-05-02 02:17:53 +00:00
use serenity::framework::standard::StandardFramework;
2020-05-01 05:53:46 +00:00
use std::env;
2020-05-10 00:56:44 +00:00
use util::{db::DbConnPool, error::KuranteError};
2020-05-02 01:21:27 +00:00
2020-05-02 02:17:53 +00:00
mod commands;
mod passive;
2020-05-02 02:41:29 +00:00
mod util;
2020-05-01 05:53:46 +00:00
2020-05-03 03:56:04 +00:00
pub(crate) const COMMAND_PREFIX: &str = "\\";
2020-05-02 01:21:27 +00:00
2020-05-01 05:53:46 +00:00
#[tokio::main]
2020-05-02 05:04:51 +00:00
async fn main() {
std::process::exit(match run().await {
Ok(_) => 0,
Err(_) => 1,
});
}
async fn run() -> Result<(), KuranteError> {
// Init dotenv vars before the env logger
2020-05-01 05:53:46 +00:00
dotenv::dotenv().ok();
2020-05-02 05:04:51 +00:00
env_logger::init();
2020-05-01 05:53:46 +00:00
let framework = StandardFramework::new()
2020-05-02 01:21:27 +00:00
.configure(|c| c.prefix(COMMAND_PREFIX))
2020-05-01 05:53:46 +00:00
.group(&GENERAL_GROUP);
2020-05-02 05:04:51 +00:00
let token = match env::var("DISCORD_TOKEN") {
Ok(token) => match validate_token(&token) {
Ok(_) => token,
Err(_) => {
error!("Provided token was invalid.");
return Err(KuranteError::InvalidToken);
}
},
Err(e) => {
error!("`DISCORD_TOKEN` environment variable was not set. Unable to start bot!");
return Err(e.into());
}
};
2020-05-02 18:37:34 +00:00
let mut client = Client::new(token)
.event_handler(Handler::default())
.framework(framework)
.await?;
2020-05-01 05:53:46 +00:00
{
let mut data = client.data.write().await;
2020-05-02 05:04:51 +00:00
data.insert::<DbConnPool>(DbConnPool::new().await?);
2020-05-01 05:53:46 +00:00
}
if let Err(why) = client.start().await {
2020-05-02 17:48:18 +00:00
error!("An error occurred while running the client: {:?}", why);
2020-05-01 05:53:46 +00:00
}
Ok(())
}