aboutsummaryrefslogtreecommitdiff
path: root/src/main.rs
diff options
context:
space:
mode:
authorKevin J Hoerr <kjhoerr@protonmail.com>2018-08-27 23:22:53 -0400
committerKevin Hoerr <kjhoerr@submelon.tech>2018-08-31 23:24:45 -0400
commit47d13a8540d0d093a73a81265ede1154ec083911 (patch)
treef8e31a6bea83a13ede87b9a42a91392cb9355623 /src/main.rs
parent396f302937cc83c8cb50e4bba64b67f4b76b7c13 (diff)
downloadaugust-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.rs32
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!"
-}