aboutsummaryrefslogtreecommitdiffstats
path: root/src/main.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/main.rs')
-rw-r--r--src/main.rs32
1 files changed, 2 insertions, 30 deletions
diff --git a/src/main.rs b/src/main.rs
index c94dab5..f89a39f 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -16,6 +16,8 @@ use rocket::request::Request;
use rocket::http::{ContentType, Status};
use std::io::Cursor;
+mod posts;
+
#[derive(BartDisplay, Serialize)]
#[template = "templates/index.html"]
struct IndexTemplate<'a> {
@@ -63,36 +65,6 @@ fn index_json(conn: rocket_blog::DbConn) -> Json<Vec<models::Post>> {
Json(get_posts(conn))
}
-mod posts {
- use rocket::request::Form;
- use rocket::response::Redirect;
- use diesel::{self, ExecuteDsl};
-
- #[derive(BartDisplay)]
- #[template = "templates/new_post.html"]
- pub struct NewPostTemplate<'a> {
- title: &'a str,
- post: ::models::NewPost
- }
-
- #[get("/new", format = "text/html")]
- fn new<'a>(_conn: ::rocket_blog::DbConn) -> NewPostTemplate<'a> {
- NewPostTemplate { title: "Bloggen", post: Default::default() }
- }
-
- #[post("/create", data="<post>")]
- fn create(post: Form<::models::NewPost>, conn: ::rocket_blog::DbConn) -> Redirect {
- use ::schema::posts;
-
- diesel::insert(post.get())
- .into(posts::table)
- .execute(&*conn)
- .expect("Error saving post.");
-
- Redirect::to("/")
- }
-}
-
fn main() {
rocket::ignite()
.manage(rocket_blog::init_db_pool())