aboutsummaryrefslogtreecommitdiff
path: root/util/master
diff options
context:
space:
mode:
Diffstat (limited to 'util/master')
-rw-r--r--util/master/index.html1
-rw-r--r--util/master/list.js111
-rwxr-xr-xutil/master/master.cgi21
-rw-r--r--util/master/style.css6
4 files changed, 97 insertions, 42 deletions
diff --git a/util/master/index.html b/util/master/index.html
index 328dd8934..ad908fca8 100644
--- a/util/master/index.html
+++ b/util/master/index.html
@@ -8,4 +8,5 @@
<body><div id="servers_table"></div></body>
</html>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
+<script>//var master = {root: 'http://servers.minetest.net/', limit:10, clients_min:1, no_flags:1, no_ping:1, no_uptime:1};</script>
<script src="list.js"></script>
diff --git a/util/master/list.js b/util/master/list.js
index a17458fb4..b5974619a 100644
--- a/util/master/list.js
+++ b/util/master/list.js
@@ -1,7 +1,13 @@
var master_root, output_to;
+var master;
+if (!master) master = {
+ root: master_root,
+ output: output_to
+};
function e(s) {
if (typeof s === "undefined") s = '';
+ if (typeof s === "number") return s;
return s.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;'); //mc"
}
@@ -41,55 +47,88 @@ function human_time(t, abs) {
function success(r) {
if (!r || !r.list) return;
- var h = '<table class="mts_table"><tr class="mts_head"><th>ip[:port]</th><th>clients/max</th><th>version gameid mapgen</th><th>name</th><th>description</th><th>flags</th><th>uptime</th><th>ping</th></tr>';
+ var h = '';
+ if (!master.no_total && r.total)
+ h += '<div class="mts_total">Now players: ' + r.total.clients + ' servers: ' + r.total.servers + '</div>';
+ if (!master.no_total_max && r.total_max)
+ h += '<div class="mts_total_max">Max players: ' + r.total_max.clients + ' servers: ' + r.total_max.servers + '</div>';
+ h += '<table class="mts_table">';
+ if (r.list.length) {
+ h += '<tr class="mts_head">';
+ if (!master.no_address) h += '<th>ip[:port]</th>';
+ if (!master.no_clients) h += '<th>players/max</th>';
+ if (!master.no_version) h += '<th>version gameid mapgen</th>';
+ if (!master.no_name) h += '<th>name</th>';
+ if (!master.no_description) h += '<th>description</th>';
+ if (!master.no_flags) h += '<th>flags</th>';
+ if (!master.no_uptime) h += '<th>uptime age</th>';
+ if (!master.no_ping) h += '<th>ping</th>';
+ h += '</tr>';
+ }
+ var count = 0;
for (var i = 0; i < r.list.length; ++i) {
+ if (++count > master.limit && master.limit) break;
var s = r.list[i];
if (!s) continue;
+ if (master.clients_min && s.clients < master.clients_min) continue;
if (/:/.test(s.address)) s.address = '[' + s.address + ']';
h += '<tr class="mts_row">';
- h += '<td class="mts_address">' + e(s.address) + (s.port != 30000 ? (':' + e(s.port)) : '') + '</td>';
- h += '<td class="mts_clients">' + e(s.clients) + (s.clients_max ? '/' + e(s.clients_max) : '') + (s.clients_top ? ', ' + e(s.clients_top) : '') + '</td>';
+ if (!master.no_address) h += '<td class="mts_address">' + e(s.address) + (s.port != 30000 ? (':' + e(s.port)) : '') + '</td>';
+ if (!master.no_clients) {
+ h += '<td class="mts_clients' + (s.clients && s.clients_list ? ' mts_is_clients' : '') + '">';
+ if (!master.no_clients_list && s.clients && s.clients_list) {
+ h += '<div class="mts_clients_list">Players (' + e(s.clients) + '):<br/>';
+ for (var ii in s.clients_list)
+ h += e(s.clients_list[ii]) + '<br/>';
+ h += '</div>';
+ }
+ h += e(s.clients) + (s.clients_max ? '/' + e(s.clients_max) : '') + (s.clients_top ? ', ' + e(s.clients_top) : '') + '</td>';
+ }
var mods = 0;
- if (s.mods && jQuery.isArray(s.mods)) {
+ if (s.mods && jQuery.isArray(s.mods))
mods = s.mods.length;
- }
- h += '<td class="mts_version' + (mods ? ' mts_ismods' : '') + '">' + e(s.version) + ' ' + e(s.gameid) + ' ' + e(s.mapgen);
- if (mods) {
- h += '<div class="mts_mods">Mods ('+mods+'):<br/>';
- for (m in s.mods) {
- h += s.mods[m] + '<br/>';
+ if (!master.no_version) {
+ h += '<td class="mts_version' + (mods ? ' mts_is_mods' : '') + '">' + e(s.version) + ' ' + e(s.gameid) + ' ' + e(s.mapgen);
+ if (!master.no_mods && mods) {
+ h += '<div class="mts_mods">Mods (' + mods + '):<br/>';
+ for (var ii in s.mods)
+ h += e(s.mods[ii]) + '<br/>';
+ h += '</div>';
}
- h += '</div>';
+ h += '</td>';
+ }
+ if (!master.no_name) {
+ h += '<td class="mts_url">';
+ if (s.url) h += '<a href="' + e(s.url) + '">';
+ h += e(s.name || s.url);
+ if (s.url) h += '</a>';
+ h += '</td>';
+ }
+ if (!master.no_description) h += '<td class="mts_description">' + e(s.description) + '</td>';
+ if (!master.no_flags) {
+ h += '<td class="mts_flags">' +
+ (s.password ? 'Pwd ' : '') +
+ (s.creative ? 'Cre ' : '') +
+ (s.damage ? 'Dmg ' : '') +
+ (s.pvp ? 'Pvp ' : '') +
+ (s.dedicated ? 'Ded ' : '') +
+ (s.rollback ? 'Rol ' : '') +
+ (s.liquid_finite ? 'Liq ' : '') +
+ '</td>';
}
-
- h += '</td>';
-
- h += '<td class="mts_url">';
- if (s.url) h += '<a href="' + e(s.url) + '">';
- h += e(s.name || s.url);
- if (s.url) h += '</a>';
- h += '</td>';
- h += '<td class="mts_description">' + e(s.description) + '</td>';
- h += '<td class="mts_flags">' +
- (s.password ? 'Pwd ' : '') +
- (s.creative ? 'Cre ' : '') +
- (s.damage ? 'Dmg ' : '') +
- (s.pvp ? 'Pvp ' : '') +
- (s.dedicated ? 'Ded ' : '') +
- (s.rollback ? 'Rol ' : '') +
- (s.liquid_finite ? 'Liq ' : '') +
- '</td>';
if (!s.start || s.start < 0) s.start = 0;
- h += '<td class="mts_time">' + (s.uptime ? human_time(s.uptime, 1) : s.start ? human_time(s.start) : '') + '</td>';
- h += '<td class="mts_ping">' + (s.ping ? parseFloat(s.ping).toFixed(3) * 1000 : '') + '</td>';
+ if (!master.no_uptime) h += '<td class="mts_uptime">' + (s.uptime ? human_time(s.uptime, 1) : s.start ? human_time(s.start) : '') + (s.game_time ? ' ' + human_time(s.game_time, 1) : '') + '</td>';
+ if (!master.no_ping) h += '<td class="mts_ping">' + (s.ping ? parseFloat(s.ping).toFixed(3) * 1000 : '') + '</td>';
h += '</tr>';
}
- h += '</table>'
- jQuery(output_to || '#servers_table').html(h);
+ h += '</table>';
+ if (master.clients_min || master.limit)
+ h += '<a href="#" onclick="delete master.limit;delete master.clients_min; get(1);">more...</a>';
+ jQuery(master.output || '#servers_table').html(h);
}
-function get() {
- jQuery.getJSON((master_root || '') + 'list', success);
- setTimeout(get, 60000);
+function get(refresh) {
+ jQuery.getJSON((master.root || '') + 'list', success);
+ if (!refresh && !master.no_refresh) setTimeout(get, 60000);
}
get();
diff --git a/util/master/master.cgi b/util/master/master.cgi
index bf627a989..a916827fe 100755
--- a/util/master/master.cgi
+++ b/util/master/master.cgi
@@ -3,7 +3,7 @@
=info
install:
cpan JSON JSON::XS
- touch list_full list
+ touch list_full list log.log
chmod a+rw list_full list log.log
freebsd:
@@ -48,6 +48,7 @@ use strict;
no strict qw(refs);
use warnings "NONFATAL" => "all";
no warnings qw(uninitialized);
+no if $] >= 5.017011, warnings => 'experimental::smartmatch';
use utf8;
use Socket;
BEGIN {
@@ -72,7 +73,7 @@ our %config = (
list_full => $root_path . 'list_full',
list_pub => $root_path . 'list',
log => $root_path . 'log.log',
- time_purge => 86400 * 30,
+ time_purge => 86400 * 1,
time_alive => 650,
source_check => 1,
ping_timeout => 3,
@@ -190,11 +191,13 @@ sub request (;$) {
$param->{$_} = $j->{$_} for keys %$j;
delete $param->{json};
}
+ #printlog 'recv', Dumper $param;
if (%$param) {
s/^false$// for values %$param;
$param->{ip} = $r->{REMOTE_ADDR};
$param->{ip} =~ s/^::ffff://;
for (@{$config{blacklist}}) {
+ #printlog("blacklist", $param->{ip} ~~ $_) if $config{debug};
return if $param->{ip} ~~ $_;
}
$param->{address} ||= $param->{ip};
@@ -223,6 +226,7 @@ sub request (;$) {
$param->{ping} = $duration if $pingret;
printlog " PING t=$config{ping_timeout}, $param->{address}:$param->{port} = ( $pingret, $duration, $ip )" if $config{debug};
}
+ return if !$param->{ping};
}
my $list = read_json($config{list_full}) || {};
printlog "readed[$config{list_full}] list size=", scalar @{$list->{list}};
@@ -232,6 +236,7 @@ sub request (;$) {
$param->{time} ||= int time;
$param->{start} = $param->{action} ~~ 'start' ? $param->{time} : $old->{start} || $param->{time};
delete $param->{start} if $param->{off};
+ $param->{clients} ||= scalar @{$param->{clients_list}} if ref $param->{clients_list} eq 'ARRAY';
$param->{first} ||= $old->{first} || $old->{time} || $param->{time};
$param->{clients_top} = $old->{clients_top} if $old->{clients_top} > $param->{clients};
$param->{clients_top} ||= $param->{clients} || 0;
@@ -239,9 +244,12 @@ sub request (;$) {
for (qw(dedicated rollback liquid_finite mapgen mods)) {
$param->{$_} ||= $old->{$_} if $old->{$_} and !($param->{action} ~~ 'start');
}
+ $param->{pop_n} = $old->{pop_n} + 1;
+ $param->{pop_c} = $old->{pop_c} + $param->{clients};
+ $param->{pop_v} = $param->{pop_c} / $param->{pop_n};
delete $param->{action};
$listk->{$param->{key}} = $param;
- #printlog Dumper $param;
+ #printlog 'write', Dumper $param if $config{debug};
$list->{list} = [grep { $_->{time} > time - $config{time_purge} } values %$listk];
file_rewrite($config{list_full}, JSON->new->encode($list));
printlog "writed[$config{list_full}] list size=", scalar @{$list->{list}} if $config{debug};
@@ -250,6 +258,13 @@ sub request (;$) {
grep { $_->{time} > time - $config{time_alive} and !$_->{off} and (!$config{ping} or !$config{pingable} or $_->{ping}) }
@{$list->{list}}
];
+ $list->{total} = {clients => 0, servers => 0};
+ for (@{$list->{list}}) {
+ $list->{total}{clients} += $_->{clients};
+ ++$list->{total}{servers};
+ }
+ $list->{total_max}{clients} = $list->{total}{clients} if $list->{total_max}{clients} < $list->{total}{clients};
+ $list->{total_max}{servers} = $list->{total}{servers} if $list->{total_max}{servers} < $list->{total}{servers};
file_rewrite($config{list_pub}, JSON->new->encode($list));
printlog "writed[$config{list_pub}] list size=", scalar @{$list->{list}} if $config{debug};
}
diff --git a/util/master/style.css b/util/master/style.css
index c92c56f6e..cff041216 100644
--- a/util/master/style.css
+++ b/util/master/style.css
@@ -13,7 +13,7 @@ div#table table {
width: 100%;
}
-.mts_mods {
+.mts_mods, .mts_clients_list {
visibility: hidden;
border:gray solid 1px;
position:absolute;
@@ -22,11 +22,11 @@ div#table table {
padding:.5em;
}
-.mts_version:hover .mts_mods {
+.mts_version:hover .mts_mods, .mts_clients:hover .mts_clients_list {
visibility: visible;
}
-.mts_version.mts_ismods {
+.mts_version.mts_is_mods, .mts_clients.mts_is_clients {
text-decoration:underline;
text-decoration-style:dashed;
}