1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#[macro_use] extern crate diesel;
#[macro_use] extern crate diesel_migrations;
use crate::config::Config;
use actix_web::{App, HttpServer, FromRequest};
use actix_web::middleware::Logger;
use std::path::PathBuf;
use structopt::StructOpt;
use structopt::clap::AppSettings;
use rebuilderd_common::api::{BuildReport, SuiteImport};
use rebuilderd_common::errors::*;
pub mod api;
pub mod auth;
pub mod config;
pub mod db;
pub mod schema;
pub mod sync;
pub mod models;
pub mod versions;
pub mod web;
#[derive(Debug, StructOpt)]
#[structopt(global_settings = &[AppSettings::ColoredHelp])]
struct Args {
#[structopt(short)]
verbose: bool,
#[structopt(short, long)]
config: Option<PathBuf>,
}
pub async fn run_config(config: Config) -> Result<()> {
let pool = db::setup_pool("rebuilderd.db")?;
let bind_addr = config.bind_addr.clone();
HttpServer::new(move || {
App::new()
.wrap(Logger::default())
.data(pool.clone())
.data(config.clone())
.service(api::list_workers)
.service(api::list_pkgs)
.service(api::list_queue)
.service(api::push_queue)
.service(api::pop_queue)
.service(api::drop_from_queue)
.service(api::requeue_pkg)
.service(api::ping_build)
.service(api::get_build_log)
.service(api::get_diffoscope)
.service(
web::resource("/api/v0/build/report").app_data(
web::Json::<BuildReport>::configure(|cfg| {
cfg.limit(128 * 1024 * 1024)
})
)
.route(web::post().to(api::report_build))
)
.service(
web::resource("/api/v0/pkgs/sync").app_data(
web::Json::<SuiteImport>::configure(|cfg| {
cfg.limit(128 * 1024 * 1024)
})
)
.route(web::post().to(api::sync_work))
)
}).bind(&bind_addr)?
.run()
.await?;
Ok(())
}