diff options
| author | Kevin J Hoerr <kjhoerr@protonmail.com> | 2018-08-27 23:22:53 -0400 |
|---|---|---|
| committer | Kevin Hoerr <kjhoerr@submelon.tech> | 2018-08-31 23:24:45 -0400 |
| commit | 47d13a8540d0d093a73a81265ede1154ec083911 (patch) | |
| tree | f8e31a6bea83a13ede87b9a42a91392cb9355623 /src/main.rs | |
| parent | 396f302937cc83c8cb50e4bba64b67f4b76b7c13 (diff) | |
| download | august-offensive-47d13a8540d0d093a73a81265ede1154ec083911.tar.gz august-offensive-47d13a8540d0d093a73a81265ede1154ec083911.tar.bz2 august-offensive-47d13a8540d0d093a73a81265ede1154ec083911.zip | |
Replace error_chain with failure; return JSON object for callback api
Diffstat (limited to 'src/main.rs')
| -rw-r--r-- | src/main.rs | 32 |
1 files changed, 12 insertions, 20 deletions
diff --git a/src/main.rs b/src/main.rs index 157d035..a9bf995 100644 --- a/src/main.rs +++ b/src/main.rs @@ -2,41 +2,36 @@ #![recursion_limit = "1024"] extern crate dotenv; -#[macro_use] -extern crate error_chain; +extern crate failure; extern crate actix; extern crate actix_web; extern crate env_logger; #[macro_use] extern crate diesel; +extern crate serde; +#[macro_use] +extern crate serde_derive; -pub mod errors; pub mod schema; +pub mod routes; -use actix_web::{middleware, server, App, HttpRequest}; +use actix_web::{middleware, server, App}; use diesel::prelude::*; use diesel::pg::PgConnection; use dotenv::dotenv; use std::env; -use errors::*; +use failure::Error; +use routes::*; fn main() { if let Err(ref e) = run() { println!("error: {}", e); - for e in e.iter().skip(1) { - println!("caused by: {}", e); - } - - if let Some(backtrace) = e.backtrace() { - println!("backtrace: {:?}", backtrace); - } - ::std::process::exit(1); } } -fn run() -> Result<()> { +fn run() -> Result<(), Error> { dotenv().ok(); let db_url = env::var("DATABASE_URL") .expect("DATABASE_URL must be set"); @@ -53,8 +48,9 @@ fn run() -> Result<()> { server::new(|| { App::new() .middleware(middleware::Logger::default()) - .resource("/index.html", |r| r.f(index)) - .resource("/", |r| r.f(index)) + .prefix("/api") + .handler("/callback", callback) + .default_resource(|r| r.f(not_understood)) }).bind(&bind_address) .unwrap() .start(); @@ -63,7 +59,3 @@ fn run() -> Result<()> { let _ = sys.run(); Ok(()) } - -fn index(_req: &HttpRequest) -> &'static str { - "Hello, world!" -} |
