104 lines
3.4 KiB
Rust
Raw Normal View History

use discord;
use discord::Discord;
use discord::model::Event;
2017-02-16 01:05:33 -06:00
use modules::Module;
use toml::Table;
use event;
2017-02-16 00:16:48 -06:00
use std::sync::Arc;
use std::sync::mpsc::Sender;
use {MessageSender, Message, User, Channel};
2017-02-16 01:05:33 -06:00
pub struct DiscordModule {
token: String,
playing: String
}
const DEFAULT_PLAYING: &'static str = "tenquestionmarks 0.0.1";
2017-02-16 01:05:33 -06:00
impl DiscordModule {
pub fn new (configuration: &Table) -> Box<Module> {
let token = configuration.get("token")
.and_then(|value| value.as_str())
.unwrap_or("");
let playing = configuration.get("playing")
.and_then(|value| value.as_str())
.unwrap_or(DEFAULT_PLAYING);
2017-02-16 01:05:33 -06:00
Box::new(DiscordModule {
token: String::from(token),
playing: String::from(playing)
})
}
}
pub struct DiscordMessageSender {
discord: Arc<Discord>,
2017-02-16 00:16:48 -06:00
channel_id: discord::model::ChannelId
}
impl MessageSender for DiscordMessageSender {
fn send_message (&self, message: &str) {
2017-02-17 02:38:15 -06:00
debug!("Send message to channel id {:?}: {:?}", self.channel_id, message);
match self.discord.send_message(&self.channel_id, message, "", false) {
Ok(message) => { debug!("Send message succeeded: {:?}", message.id); },
Err(err) => { error!("Send message failed: {:?}", err) }
}
}
}
2017-02-16 01:05:33 -06:00
impl Module for DiscordModule {
fn produce_events<'a>(&'a self, sender: Sender<Arc<event::Event>>) {
2017-02-17 02:38:15 -06:00
let discord = Arc::new(Discord::from_bot_token(&self.token[..]).expect("Discord module: Login failed"));
let (mut connection, _) = discord.connect().expect("Discord module: Connection failed");
info!("Playing {}", self.playing);
connection.set_game_name(self.playing.clone());
loop {
match connection.recv_event() {
Ok(Event::MessageCreate(message)) => {
let author = User {
name: message.author.name.clone(),
sender: Box::new(DiscordMessageSender {
discord: discord.clone(),
2017-02-16 00:16:48 -06:00
channel_id: message.channel_id
})
};
let channel = Channel {
name: String::from("channel"),
description: String::from(""),
topic: String::from(""),
sender: Box::new(DiscordMessageSender {
discord: discord.clone(),
2017-02-16 00:16:48 -06:00
channel_id: message.channel_id
})
};
let message = Message {
author: author,
content: message.content,
channel: Some(channel)
};
match sender.send(Arc::new(event::Event::Message { message: message })) {
2017-02-17 02:38:15 -06:00
Err(err) => error!("Error sending message event: {:?}", err),
Ok(_) => {}
}
}
Ok(_) => {}
Err(discord::Error::Closed(code, body)) => {
2017-02-17 02:38:15 -06:00
error!("Gateway closed on us with code {:?}: {}", code, body);
break
}
2017-02-17 02:38:15 -06:00
Err(err) => error!("Received error: {:?}", err)
}
}
}
}