summaryrefslogtreecommitdiffstats
path: root/server/src/db/user_view.rs
diff options
context:
space:
mode:
Diffstat (limited to 'server/src/db/user_view.rs')
-rw-r--r--server/src/db/user_view.rs53
1 files changed, 53 insertions, 0 deletions
diff --git a/server/src/db/user_view.rs b/server/src/db/user_view.rs
new file mode 100644
index 00000000..3d78ae1a
--- /dev/null
+++ b/server/src/db/user_view.rs
@@ -0,0 +1,53 @@
+use super::*;
+
+table! {
+ user_view (id) {
+ id -> Int4,
+ name -> Varchar,
+ fedi_name -> Varchar,
+ admin -> Bool,
+ banned -> Bool,
+ published -> Timestamp,
+ number_of_posts -> BigInt,
+ post_score -> BigInt,
+ number_of_comments -> BigInt,
+ comment_score -> BigInt,
+ }
+}
+
+#[derive(Queryable, Identifiable, PartialEq, Debug, Serialize, Deserialize,QueryableByName,Clone)]
+#[table_name="user_view"]
+pub struct UserView {
+ pub id: i32,
+ pub name: String,
+ pub fedi_name: String,
+ pub admin: bool,
+ pub banned: bool,
+ pub published: chrono::NaiveDateTime,
+ pub number_of_posts: i64,
+ pub post_score: i64,
+ pub number_of_comments: i64,
+ pub comment_score: i64,
+}
+
+impl UserView {
+ pub fn read(conn: &PgConnection, from_user_id: i32) -> Result<Self, Error> {
+ use super::user_view::user_view::dsl::*;
+
+ user_view.find(from_user_id)
+ .first::<Self>(conn)
+ }
+
+ pub fn admins(conn: &PgConnection) -> Result<Vec<Self>, Error> {
+ use super::user_view::user_view::dsl::*;
+ user_view.filter(admin.eq(true))
+ .load::<Self>(conn)
+ }
+
+ pub fn banned(conn: &PgConnection) -> Result<Vec<Self>, Error> {
+ use super::user_view::user_view::dsl::*;
+ user_view.filter(banned.eq(true))
+ .load::<Self>(conn)
+ }
+}
+