Optimized @players collection from json
This commit was merged in pull request #45.
This commit is contained in:
@@ -17,20 +17,15 @@ class StaticsController < ApplicationController
|
|||||||
end
|
end
|
||||||
|
|
||||||
def online
|
def online
|
||||||
@players = {}
|
@players = []
|
||||||
@count = 0
|
@count = 0
|
||||||
begin
|
begin
|
||||||
json = JSON.parse(File.read("/etc/minecraft/redstoner/plugins/ModuleLoader/players.json"))
|
json = JSON.parse(File.read("/etc/minecraft/redstoner/plugins/ModuleLoader/players.json"))["players"].reject{|p| !mod? && p["vanished"] == "true"}
|
||||||
rescue
|
rescue
|
||||||
flash.now[:alert] = "The server is currently offline."
|
flash.now[:alert] = "The server is currently offline."
|
||||||
else
|
else
|
||||||
json["players"].each do |p|
|
json.each do |p|
|
||||||
next if p["vanished"] == "true" && !mod?
|
@players.push(User.find_by(uuid: p["UUID"].tr("-", "")) || User.new(name: p["name"], ign: p["name"], uuid: p["UUID"].tr("-", ""), role: Role.get("normal"), badge: Badge.get("none"), confirmed: true))
|
||||||
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
|
||||||
end
|
end
|
||||||
@players.sort_by!(&:role).reverse!
|
@players.sort_by!(&:role).reverse!
|
||||||
|
|||||||
Reference in New Issue
Block a user