aboutsummaryrefslogtreecommitdiff
path: root/src/main.rs
blob: ecb7219104ed6fd4a150f697d2baeb7313266a53 (plain) (blame)
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
extern crate actix_rt;
extern crate actix_web;
extern crate dotenv;
#[macro_use]
extern crate log;
extern crate env_logger;
#[macro_use]
extern crate diesel;
extern crate serde;
#[macro_use]
extern crate serde_derive;
extern crate serde_json;

pub mod messages;
pub mod routes;
pub mod schema;

use actix_web::{middleware, App, HttpServer};
use diesel::pg::PgConnection;
use diesel::prelude::*;
use dotenv::dotenv;
use std::{env, io::Error};

fn main() {
    if let Err(ref e) = run() {
        error!("error: {}", e);

        ::std::process::exit(1);
    }
}

// Run start-up for the server and dependencies
fn run() -> Result<(), Error> {
    dotenv().ok();
    let db_url = env::var("DATABASE_URL").expect("DATABASE_URL must be set");
    let bind_address = env::var("BIND_ADDRESS").expect("BIND_ADDRESS must be set");

    env_logger::init();
    let sys = actix_rt::System::new("august-offensive");

    PgConnection::establish(&db_url).expect(&format!("Error connecting to {}", db_url));

    HttpServer::new(|| {
        App::new()
            .wrap(middleware::Logger::default())
            .service(routes::get_scope())
    })
    .bind(&bind_address)?
    .start();

    info!("Started http server: {}", bind_address);

    sys.run()?;
    Ok(())
}