diff options
author | Harald Eilertsen <haraldei@anduin.net> | 2018-07-31 16:49:42 +0200 |
---|---|---|
committer | Harald Eilertsen <haraldei@anduin.net> | 2018-07-31 16:49:42 +0200 |
commit | 7f5e8887e9b1a90d1ed3dd31f053dadec4c75d94 (patch) | |
tree | 0a6464a7434a6c43ffb285d300cf9a999fc6d226 /src | |
parent | 6a5f1bd90e46c2bea7be73b512d5202954900cad (diff) | |
download | rocket-blog-7f5e8887e9b1a90d1ed3dd31f053dadec4c75d94.tar.gz rocket-blog-7f5e8887e9b1a90d1ed3dd31f053dadec4c75d94.tar.bz2 rocket-blog-7f5e8887e9b1a90d1ed3dd31f053dadec4c75d94.zip |
Add view to list all users
Diffstat (limited to 'src')
-rw-r--r-- | src/controllers/users_controller.rs | 31 | ||||
-rw-r--r-- | src/models/user.rs | 5 |
2 files changed, 25 insertions, 11 deletions
diff --git a/src/controllers/users_controller.rs b/src/controllers/users_controller.rs index 9708a1b..9bfb5e1 100644 --- a/src/controllers/users_controller.rs +++ b/src/controllers/users_controller.rs @@ -4,23 +4,32 @@ use rocket::response::{Flash, Redirect}; use utils; #[derive(BartDisplay)] -#[template = "templates/new_user.html"] -pub struct NewUserTemplate { - user: ::models::NewUser +#[template = "templates/users.html"] +pub struct UsersTemplate { + users: Vec<::models::User> } -implement_responder_for!(NewUserTemplate); +implement_responder_for!(UsersTemplate); -impl NewUserTemplate { - pub fn realname(&self) -> String { - self.user.realname.as_ref().unwrap_or(&String::new()).clone() +#[get("/", format = "text/html")] +fn index(conn: utils::DbConn) -> utils::Page<UsersTemplate> { + utils::Page { + title: String::from("Users"), + flash: None, + content: UsersTemplate { + users: ::models::User::all(conn).unwrap() + } } +} - pub fn email(&self) -> String { - self.user.email.as_ref().unwrap_or(&String::new()).clone() - } +#[derive(BartDisplay)] +#[template = "templates/new_user.html"] +pub struct NewUserTemplate { + user: ::models::NewUser } +implement_responder_for!(NewUserTemplate); + #[get("/new", format = "text/html")] fn new() -> utils::Page<NewUserTemplate> { utils::Page { @@ -41,5 +50,5 @@ fn create(user: Form<::models::NewUser>, conn: utils::DbConn) -> Flash<Redirect> } pub fn routes() -> Vec<rocket::Route> { - routes![new, create] + routes![index, new, create] } diff --git a/src/models/user.rs b/src/models/user.rs index 537dfe6..7f6fe88 100644 --- a/src/models/user.rs +++ b/src/models/user.rs @@ -13,6 +13,11 @@ pub struct User { } impl User { + pub fn all(conn: utils::DbConn) -> QueryResult<Vec<User>> { + use schema::users::dsl::*; + users.load::<User>(&*conn) + } + pub fn by_id(user_id: i32, conn: utils::DbConn) -> QueryResult<User> { use schema::users::dsl::*; users.filter(id.eq(user_id)) |