feat(main): Add barebares thread listing
This ties together the first components here (actix, diesel etc.) to provide a _very_ simple thread overview.
This commit is contained in:
parent
36e520a2b2
commit
1402cfd948
3 changed files with 68 additions and 16 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -250,6 +250,7 @@ dependencies = [
|
||||||
"chrono 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"chrono 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"diesel 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"diesel 1.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"env_logger 0.5.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.5.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"futures 0.1.21 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"log 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"r2d2 0.8.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"r2d2 0.8.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
|
@ -11,3 +11,4 @@ diesel = { version = "1.2", features = ["postgres", "chrono", "r2d2"]}
|
||||||
chrono = "0.4"
|
chrono = "0.4"
|
||||||
log = "0.4"
|
log = "0.4"
|
||||||
r2d2 = "*"
|
r2d2 = "*"
|
||||||
|
futures = "*"
|
||||||
|
|
82
src/main.rs
82
src/main.rs
|
@ -1,33 +1,83 @@
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate diesel;
|
extern crate diesel;
|
||||||
|
|
||||||
|
#[macro_use]
|
||||||
|
extern crate log;
|
||||||
|
|
||||||
extern crate chrono;
|
extern crate chrono;
|
||||||
|
extern crate actix;
|
||||||
|
extern crate actix_web;
|
||||||
|
extern crate env_logger;
|
||||||
|
extern crate r2d2;
|
||||||
|
extern crate futures;
|
||||||
|
|
||||||
pub mod schema;
|
pub mod schema;
|
||||||
pub mod models;
|
pub mod models;
|
||||||
|
pub mod db;
|
||||||
|
|
||||||
|
use actix::prelude::*;
|
||||||
|
use actix_web::*;
|
||||||
|
|
||||||
use diesel::prelude::*;
|
|
||||||
use diesel::pg::PgConnection;
|
use diesel::pg::PgConnection;
|
||||||
|
use diesel::r2d2::{ConnectionManager, Pool};
|
||||||
use std::env;
|
use std::env;
|
||||||
|
use db::*;
|
||||||
|
use futures::Future;
|
||||||
|
use models::Thread;
|
||||||
|
|
||||||
fn connect_db() -> PgConnection {
|
/// Represents the state carried by the web server actors.
|
||||||
let db_url = env::var("DATABASE_URL")
|
struct AppState {
|
||||||
.expect("DATABASE_URL must be set");
|
db: Addr<Syn, DbExecutor>,
|
||||||
|
}
|
||||||
|
|
||||||
PgConnection::establish(&db_url)
|
/// Really inefficient renderer example!
|
||||||
.expect(&format!("Error connecting to {}", db_url))
|
fn render_threads(threads: Vec<Thread>) -> String {
|
||||||
|
let mut res = String::new();
|
||||||
|
|
||||||
|
for thread in threads {
|
||||||
|
res.push_str(&format!("Subject: {}\n", thread.title));
|
||||||
|
res.push_str(&format!("Posted at: {}\n\n", thread.posted));
|
||||||
|
res.push_str(&format!("{}\n", thread.body));
|
||||||
|
res.push_str("-------------------------------");
|
||||||
|
}
|
||||||
|
|
||||||
|
res
|
||||||
|
}
|
||||||
|
|
||||||
|
fn forum_index(req: HttpRequest<AppState>) -> FutureResponse<HttpResponse> {
|
||||||
|
req.state().db.send(ListThreads)
|
||||||
|
.from_err()
|
||||||
|
.and_then(|res| match res {
|
||||||
|
Ok(threads) => Ok(HttpResponse::from(render_threads(threads))),
|
||||||
|
Err(err) => {
|
||||||
|
error!("Error loading threads: {}", err);
|
||||||
|
Ok(HttpResponse::InternalServerError().into())
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.responder()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
use schema::threads::dsl::*;
|
env_logger::init();
|
||||||
use models::*;
|
|
||||||
|
|
||||||
let conn = connect_db();
|
info!("Welcome to Converse! Hold on tight while we're getting ready.");
|
||||||
let result: Vec<Thread> = threads
|
let sys = actix::System::new("converse");
|
||||||
.load::<Thread>(&conn)
|
|
||||||
.expect("Error loading threads");
|
|
||||||
|
|
||||||
for thread in result {
|
info!("Initialising database connection pool ...");
|
||||||
println!("Subject: {}\nPosted: {}\n", thread.title, thread.posted);
|
let db_url = env::var("DATABASE_URL")
|
||||||
println!("{}", thread.body);
|
.expect("DATABASE_URL must be set");
|
||||||
}
|
|
||||||
|
let manager = ConnectionManager::<PgConnection>::new(db_url);
|
||||||
|
let pool = Pool::builder().build(manager).expect("Failed to initialise DB pool");
|
||||||
|
|
||||||
|
let db_addr = SyncArbiter::start(2, move || DbExecutor(pool.clone()));
|
||||||
|
|
||||||
|
info!("Initialising HTTP server ...");
|
||||||
|
server::new(move || {
|
||||||
|
App::with_state(AppState { db: db_addr.clone() })
|
||||||
|
.middleware(middleware::Logger::default())
|
||||||
|
.route("/", http::Method::GET, &forum_index)
|
||||||
|
}).bind("127.0.0.1:4567").unwrap().start();
|
||||||
|
|
||||||
|
let _ = sys.run();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue