diff options
author | Dessalines <happydooby@gmail.com> | 2019-05-01 22:26:31 -0700 |
---|---|---|
committer | Dessalines <happydooby@gmail.com> | 2019-05-01 22:26:31 -0700 |
commit | b304b482eafd8ab87bd9fb8c263773a038ea1e6f (patch) | |
tree | 4aaee50876fd32c1f01fd4c5b05c57cd6aa096be /server/src | |
parent | b2d8bf304eff145999ed38956e88978a6e1b44fb (diff) |
Reworking some UI. Adding proper trending communities with hot rank.
- Breaking out subscribed and all into radios. Fixes #142
Diffstat (limited to 'server/src')
-rw-r--r-- | server/src/actions/community_view.rs | 3 | ||||
-rw-r--r-- | server/src/websocket_server/server.rs | 3 |
2 files changed, 5 insertions, 1 deletions
diff --git a/server/src/actions/community_view.rs b/server/src/actions/community_view.rs index a52897ff..9a162746 100644 --- a/server/src/actions/community_view.rs +++ b/server/src/actions/community_view.rs @@ -21,6 +21,7 @@ table! { number_of_subscribers -> BigInt, number_of_posts -> BigInt, number_of_comments -> BigInt, + hot_rank -> Int4, user_id -> Nullable<Int4>, subscribed -> Nullable<Bool>, } @@ -92,6 +93,7 @@ pub struct CommunityView { pub number_of_subscribers: i64, pub number_of_posts: i64, pub number_of_comments: i64, + pub hot_rank: i32, pub user_id: Option<i32>, pub subscribed: Option<bool>, } @@ -127,6 +129,7 @@ impl CommunityView { // The view lets you pass a null user_id, if you're not logged in match sort { + SortType::Hot => query = query.order_by(hot_rank.desc()).filter(user_id.is_null()), SortType::New => query = query.order_by(published.desc()).filter(user_id.is_null()), SortType::TopAll => { match from_user_id { diff --git a/server/src/websocket_server/server.rs b/server/src/websocket_server/server.rs index b2416951..aaeae132 100644 --- a/server/src/websocket_server/server.rs +++ b/server/src/websocket_server/server.rs @@ -573,6 +573,7 @@ impl ChatServer { fn check_rate_limit_full(&mut self, addr: usize, rate: i32, per: i32) -> Result<(), Error> { if let Some(info) = self.sessions.get(&addr) { if let Some(rate_limit) = self.rate_limits.get_mut(&info.ip) { + // The initial value if rate_limit.allowance == -2f64 { rate_limit.allowance = rate as f64; }; @@ -625,7 +626,7 @@ impl Handler<Connect> for ChatServer { // register session with random id let id = self.rng.gen::<usize>(); - println!("{} Joined", &msg.ip); + println!("{} joined", &msg.ip); self.sessions.insert(id, SessionInfo { addr: msg.addr, |