Merge remote-tracking branch 'origin/released' into next

This commit is contained in:
Graham Christensen 2018-02-09 19:11:02 -05:00
commit 666596b251
No known key found for this signature in database
GPG key ID: ACA1C1D120C83D5C

View file

@ -30,7 +30,9 @@ use std::env;
#[derive(Serialize, Deserialize, Debug)]
struct MessageToIRC {
target: String,
body: String
body: String,
#[serde(default = "default_irc_message_type")]
message_type: IRCMessageType
}
#[derive(Serialize, Deserialize, Debug)]
@ -40,6 +42,17 @@ struct MessageFromIRC {
body: String
}
#[derive(Serialize, Deserialize, Debug)]
#[serde(rename_all = "lowercase")]
enum IRCMessageType {
Privmsg,
Notice
}
fn default_irc_message_type() -> IRCMessageType {
IRCMessageType::Privmsg
}
fn main() {
if let Err(_) = env::var("RUST_LOG") {
env::set_var("RUST_LOG", "info");
@ -81,8 +94,15 @@ fn main() {
move |_channel: &mut Channel, _deliver: Deliver, _headers: BasicProperties, body: Vec<u8>| {
let msg: Result<MessageToIRC, serde_json::Error> = serde_json::from_slice(&body);
if let Ok(msg) = msg {
match msg.message_type {
IRCMessageType::Notice => {
server.send_notice(&msg.target, &msg.body).unwrap();
}
IRCMessageType::Privmsg => {
server.send_privmsg(&msg.target, &msg.body).unwrap();
}
}
}
},
"queue-publish", "", false, true, false, false, Table::new());
println!("Starting consumer {:?}", consumer_name);