diff options
author | Logan Fick <logaldeveloper@protonmail.com> | 2017-10-28 15:25:39 -0400 |
---|---|---|
committer | Logan Fick <logaldeveloper@protonmail.com> | 2017-10-28 15:25:39 -0400 |
commit | ea4799fc285c1bebaabfb72c176583b05edd9def (patch) | |
tree | 2817421caa6459c78d691a008e844302354a8918 | |
parent | 0093daedd9b028ae633d773b540d807238448589 (diff) |
Made Who's Playing page hide vanished users from non-staff ranks.
-rw-r--r-- | app/controllers/statics_controller.rb | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/app/controllers/statics_controller.rb b/app/controllers/statics_controller.rb index c624c32..3a46ac1 100644 --- a/app/controllers/statics_controller.rb +++ b/app/controllers/statics_controller.rb @@ -17,15 +17,23 @@ class StaticsController < ApplicationController end def online + @players = {} + @count = 0 begin json = JSON.parse(File.read("/etc/minecraft/redstoner/plugins/ModuleLoader/players.json")) rescue flash.now[:alert] = "The server is currently offline." - @players = {} - @count = 0 else - @players = json["players"].collect!{ |p| User.find_by(uuid: p["UUID"].tr("-", "")) or User.new(name: p["name"], ign: p["name"], uuid: p["UUID"].tr("-", ""), role: Role.get("normal"), badge: Badge.get("none"), confirmed: true) }.sort_by!(&:role).reverse! - @count = json["amount"] + json["players"].each do |p| + next if p["vanished"] == "true" && !mod? + if User.find_by(uuid: p["UUID"].tr("-", "")) + @players.push(User.find_by(uuid: p["UUID"].tr("-", ""))) + else + @players.push(User.new(name: p["name"], ign: p["name"], uuid: p["UUID"].tr("-", ""), role: Role.get("normal"), badge: Badge.get("none"), confirmed: true)) + end + end end + @players.sort_by!(&:role).reverse! + @count = @players.count end end |