Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #491 from LnL7/lapin-evaluation-filter
lapin evaluation filter
- Loading branch information
Showing
2 changed files
with
64 additions
and
74 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,90 +1,77 @@ | ||
use amqp::Basic; | ||
use ofborg::config; | ||
use ofborg::easyamqp::{self, ChannelExt, ConsumerExt}; | ||
use ofborg::tasks; | ||
use ofborg::worker; | ||
|
||
use std::env; | ||
use std::error::Error; | ||
|
||
use async_std::task; | ||
use tracing::info; | ||
|
||
fn main() { | ||
let cfg = config::load(env::args().nth(1).unwrap().as_ref()); | ||
use ofborg::config; | ||
use ofborg::easyamqp::{self, ChannelExt, ConsumerExt}; | ||
use ofborg::easylapin; | ||
use ofborg::tasks; | ||
|
||
fn main() -> Result<(), Box<dyn Error>> { | ||
ofborg::setup_log(); | ||
|
||
info!("Hello, world!"); | ||
let arg = env::args() | ||
.nth(1) | ||
.expect("usage: evaluation-filter <config>"); | ||
let cfg = config::load(arg.as_ref()); | ||
|
||
let mut session = easyamqp::session_from_config(&cfg.rabbitmq).unwrap(); | ||
info!("Connected to rabbitmq"); | ||
let conn = easylapin::from_config(&cfg.rabbitmq)?; | ||
let mut chan = task::block_on(conn.create_channel())?; | ||
|
||
let mut channel = session.open_channel(1).unwrap(); | ||
chan.declare_exchange(easyamqp::ExchangeConfig { | ||
exchange: "github-events".to_owned(), | ||
exchange_type: easyamqp::ExchangeType::Topic, | ||
passive: false, | ||
durable: true, | ||
auto_delete: false, | ||
no_wait: false, | ||
internal: false, | ||
})?; | ||
|
||
channel | ||
.declare_exchange(easyamqp::ExchangeConfig { | ||
exchange: "github-events".to_owned(), | ||
exchange_type: easyamqp::ExchangeType::Topic, | ||
passive: false, | ||
durable: true, | ||
auto_delete: false, | ||
no_wait: false, | ||
internal: false, | ||
}) | ||
.unwrap(); | ||
chan.declare_queue(easyamqp::QueueConfig { | ||
queue: "mass-rebuild-check-jobs".to_owned(), | ||
passive: false, | ||
durable: true, | ||
exclusive: false, | ||
auto_delete: false, | ||
no_wait: false, | ||
})?; | ||
|
||
channel | ||
.declare_queue(easyamqp::QueueConfig { | ||
queue: "mass-rebuild-check-jobs".to_owned(), | ||
passive: false, | ||
durable: true, | ||
exclusive: false, | ||
auto_delete: false, | ||
no_wait: false, | ||
}) | ||
.unwrap(); | ||
let queue_name = String::from("mass-rebuild-check-jobs"); | ||
chan.declare_queue(easyamqp::QueueConfig { | ||
queue: queue_name.clone(), | ||
passive: false, | ||
durable: true, | ||
exclusive: false, | ||
auto_delete: false, | ||
no_wait: false, | ||
})?; | ||
|
||
channel | ||
.declare_queue(easyamqp::QueueConfig { | ||
queue: "mass-rebuild-check-inputs".to_owned(), | ||
passive: false, | ||
durable: true, | ||
exclusive: false, | ||
auto_delete: false, | ||
no_wait: false, | ||
}) | ||
.unwrap(); | ||
chan.bind_queue(easyamqp::BindQueueConfig { | ||
queue: queue_name.clone(), | ||
exchange: "github-events".to_owned(), | ||
routing_key: Some("pull_request.nixos/nixpkgs".to_owned()), | ||
no_wait: false, | ||
})?; | ||
|
||
channel | ||
.bind_queue(easyamqp::BindQueueConfig { | ||
queue: "mass-rebuild-check-inputs".to_owned(), | ||
exchange: "github-events".to_owned(), | ||
routing_key: Some("pull_request.nixos/nixpkgs".to_owned()), | ||
let handle = chan.consume( | ||
tasks::evaluationfilter::EvaluationFilterWorker::new(cfg.acl()), | ||
easyamqp::ConsumeConfig { | ||
queue: queue_name.clone(), | ||
consumer_tag: format!("{}-evaluation-filter", cfg.whoami()), | ||
no_local: false, | ||
no_ack: false, | ||
no_wait: false, | ||
}) | ||
.unwrap(); | ||
|
||
channel.basic_prefetch(1).unwrap(); | ||
let mut channel = channel | ||
.consume( | ||
worker::new(tasks::evaluationfilter::EvaluationFilterWorker::new( | ||
cfg.acl(), | ||
)), | ||
easyamqp::ConsumeConfig { | ||
queue: "mass-rebuild-check-inputs".to_owned(), | ||
consumer_tag: format!("{}-evaluation-filter", cfg.whoami()), | ||
no_local: false, | ||
no_ack: false, | ||
no_wait: false, | ||
exclusive: false, | ||
}, | ||
) | ||
.unwrap(); | ||
|
||
channel.start_consuming(); | ||
exclusive: false, | ||
}, | ||
)?; | ||
|
||
info!("Finished consuming?"); | ||
info!("Fetching jobs from {}", &queue_name); | ||
task::block_on(handle); | ||
|
||
channel.close(200, "Bye").unwrap(); | ||
info!("Closed the channel"); | ||
session.close(200, "Good Bye"); | ||
drop(conn); // Close connection. | ||
info!("Closed the session... EOF"); | ||
Ok(()) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters