generalize amqp references in SysEvents
This commit is contained in:
parent
f1d34ee242
commit
3ce9f3edd1
|
@ -40,7 +40,7 @@ fn main() {
|
||||||
let cloner = checkout::cached_cloner(Path::new(&cfg.checkout.root));
|
let cloner = checkout::cached_cloner(Path::new(&cfg.checkout.root));
|
||||||
let nix = cfg.nix();
|
let nix = cfg.nix();
|
||||||
|
|
||||||
let events = stats::RabbitMQ::new(
|
let events = stats::RabbitMQ::from_amqp(
|
||||||
&format!("{}-{}", cfg.runner.identity.clone(), cfg.nix.system.clone()),
|
&format!("{}-{}", cfg.runner.identity.clone(), cfg.nix.system.clone()),
|
||||||
session.open_channel(3).unwrap(),
|
session.open_channel(3).unwrap(),
|
||||||
);
|
);
|
||||||
|
|
|
@ -17,7 +17,7 @@ fn main() {
|
||||||
let mut session = easyamqp::session_from_config(&cfg.rabbitmq).unwrap();
|
let mut session = easyamqp::session_from_config(&cfg.rabbitmq).unwrap();
|
||||||
info!("Connected to rabbitmq");
|
info!("Connected to rabbitmq");
|
||||||
|
|
||||||
let events = stats::RabbitMQ::new(
|
let events = stats::RabbitMQ::from_amqp(
|
||||||
&format!("{}-{}", cfg.runner.identity.clone(), cfg.nix.system.clone()),
|
&format!("{}-{}", cfg.runner.identity.clone(), cfg.nix.system.clone()),
|
||||||
session.open_channel(3).unwrap(),
|
session.open_channel(3).unwrap(),
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
use amqp::protocol::basic::BasicProperties;
|
use amqp::protocol::basic;
|
||||||
use amqp::{Basic, Channel};
|
use amqp::Basic;
|
||||||
|
use async_std::task;
|
||||||
|
use lapin::options::BasicPublishOptions;
|
||||||
|
use lapin::CloseOnDrop;
|
||||||
|
|
||||||
include!(concat!(env!("OUT_DIR"), "/events.rs"));
|
include!(concat!(env!("OUT_DIR"), "/events.rs"));
|
||||||
|
|
||||||
|
@ -19,13 +22,13 @@ pub struct EventMessage {
|
||||||
pub events: Vec<Event>,
|
pub events: Vec<Event>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct RabbitMQ {
|
pub struct RabbitMQ<C> {
|
||||||
identity: String,
|
identity: String,
|
||||||
channel: Channel,
|
channel: C,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl RabbitMQ {
|
impl RabbitMQ<amqp::Channel> {
|
||||||
pub fn new(identity: &str, channel: Channel) -> RabbitMQ {
|
pub fn from_amqp(identity: &str, channel: amqp::Channel) -> Self {
|
||||||
RabbitMQ {
|
RabbitMQ {
|
||||||
identity: identity.to_owned(),
|
identity: identity.to_owned(),
|
||||||
channel,
|
channel,
|
||||||
|
@ -33,9 +36,9 @@ impl RabbitMQ {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl SysEvents for RabbitMQ {
|
impl SysEvents for RabbitMQ<amqp::Channel> {
|
||||||
fn notify(&mut self, event: Event) {
|
fn notify(&mut self, event: Event) {
|
||||||
let props = BasicProperties {
|
let props = basic::BasicProperties {
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
self.channel
|
self.channel
|
||||||
|
@ -55,3 +58,38 @@ impl SysEvents for RabbitMQ {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl RabbitMQ<CloseOnDrop<lapin::Channel>> {
|
||||||
|
pub fn from_lapin(identity: &str, channel: CloseOnDrop<lapin::Channel>) -> Self {
|
||||||
|
RabbitMQ {
|
||||||
|
identity: identity.to_owned(),
|
||||||
|
channel,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl SysEvents for RabbitMQ<CloseOnDrop<lapin::Channel>> {
|
||||||
|
fn notify(&mut self, event: Event) {
|
||||||
|
let props = lapin::BasicProperties::default().with_content_type("application/json".into());
|
||||||
|
task::block_on(async {
|
||||||
|
let _confirmaton = self
|
||||||
|
.channel
|
||||||
|
.basic_publish(
|
||||||
|
&String::from("stats"),
|
||||||
|
&"".to_owned(),
|
||||||
|
BasicPublishOptions::default(),
|
||||||
|
serde_json::to_string(&EventMessage {
|
||||||
|
sender: self.identity.clone(),
|
||||||
|
events: vec![event],
|
||||||
|
})
|
||||||
|
.unwrap()
|
||||||
|
.into_bytes(),
|
||||||
|
props,
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.unwrap()
|
||||||
|
.await
|
||||||
|
.unwrap();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue