aboutsummaryrefslogtreecommitdiff
path: root/lib/MasterServer/Database/Pg/dbBeacon.pm
diff options
context:
space:
mode:
authorDarkelarious <darkelarious@333networks.com>2016-11-19 20:56:04 +0100
committerDarkelarious <darkelarious@333networks.com>2016-11-19 20:56:04 +0100
commitc3f8d65a4fb1f5674557ee67cf7f74369df86ad1 (patch)
tree92aab2a394bda28da0ed7c7c75e633fdf386fc71 /lib/MasterServer/Database/Pg/dbBeacon.pm
parent1de3da4b8027508a91144639455c934fd6ccb9b7 (diff)
downloadMasterServer-Perl-c3f8d65a4fb1f5674557ee67cf7f74369df86ad1.tar.gz
MasterServer-Perl-c3f8d65a4fb1f5674557ee67cf7f74369df86ad1.zip
Massive improvements on efficiency, robustness, security, reliability and more
Diffstat (limited to 'lib/MasterServer/Database/Pg/dbBeacon.pm')
-rwxr-xr-xlib/MasterServer/Database/Pg/dbBeacon.pm203
1 files changed, 0 insertions, 203 deletions
diff --git a/lib/MasterServer/Database/Pg/dbBeacon.pm b/lib/MasterServer/Database/Pg/dbBeacon.pm
deleted file mode 100755
index 735eaf9..0000000
--- a/lib/MasterServer/Database/Pg/dbBeacon.pm
+++ /dev/null
@@ -1,203 +0,0 @@
-
-package MasterServer::Database::Pg::dbBeacon;
-
-use strict;
-use warnings;
-use Exporter 'import';
-
-our @EXPORT = qw| add_beacon
- add_pending
- remove_pending
- get_pending_beacon
- get_pending_info
- get_next_pending |;
-
-################################################################################
-## Update beacon in serverlist or pending list. Add if beacon does not exist in
-## either list. Return 0,1,2 if success in adding or -1 on error.
-################################################################################
-sub add_beacon {
- my ($self, $ip, $beaconport, $heartbeat, $gamename, $secure) = @_;
-
- # if address is in list, update the timestamp
- my $u = $self->{dbh}->do(
- "UPDATE serverlist
- SET beacon = NOW(),
- updated = NOW(),
- gamename = ?,
- b333ms = TRUE
- WHERE ip = ?
- AND port = ?",
- undef, lc $gamename, $ip, $heartbeat);
-
- # notify
- $self->log("update", "beacon heartbeat for $ip:$heartbeat") if ($u > 0);
-
- # if serverlist was updated return 0
- return 0 if ($u > 0);
-
- # if it is already in the pending list, update it with a new challenge
- $u = $self->{dbh}->do(
- "UPDATE pending
- SET added = NOW(),
- beaconport = ?,
- gamename = ?,
- secure = ?
- WHERE ip = ?
- AND heartbeat = ?",
- undef, $beaconport, lc $gamename, $secure, $ip, $heartbeat);
-
- # notify
- $self->log("update", "beacon heartbeat $ip:$beaconport pending $gamename:$heartbeat") if ($u > 0);
-
- # beacon was already in pending list and was updated
- return 1 if ($u > 0);
-
- # if not found, add it
- $u = $self->{dbh}->do(
- "INSERT INTO pending (
- ip,
- beaconport,
- heartbeat,
- gamename,
- secure)
- SELECT ?, ?, ?, ?, ?",
- undef, $ip, $beaconport, $heartbeat, lc $gamename, $secure);
-
- # notify
- $self->log("add", "beacon heartbeat $ip:$beaconport pending $gamename:$heartbeat") if ($u > 0);
-
- # it was added to pending
- return 2 if ($u > 0);
-
- # or else report error
- $self->log("error", "an error occurred adding beacon $ip:$beaconport with $gamename:$heartbeat to the pending list");
- return -1;
-}
-
-################################################################################
-## Add an address to the database that was obtained via a method other than
-## an udp beacon. Return 0,1,2 if success in adding or -1 on error.
-################################################################################
-sub add_pending {
- my ($self, $ip, $port, $gamename, $secure) = @_;
-
- # if address is in list, update the timestamp
- my $u = $self->{dbh}->do(
- "UPDATE serverlist
- SET updated = NOW()
- WHERE ip = ?
- AND port = ?",
- undef, $ip, $port);
-
- # notify
- $self->log("update", "updated serverlist with $ip:$port") if ($u > 0);
-
- # if updated, return 0
- return 0 if ($u > 0);
-
- # if it is already in the pending list, update it with a new challenge
- $u = $self->{dbh}->do(
- "UPDATE pending
- SET added = NOW(),
- secure = ?
- WHERE ip = ?
- AND heartbeat = ?",
- undef, $secure, $ip, $port);
-
- # notify
- $self->log("update", "updated pending with $ip:$port") if ($u > 0);
-
- # return 1 if updated
- return 1 if ($u > 0);
-
- # if not found, add it
- $u = $self->{dbh}->do(
- "INSERT INTO pending (
- ip,
- heartbeat,
- gamename,
- secure)
- SELECT ?, ?, ?, ?",
- undef, $ip, $port, $gamename, $secure);
-
- # notify
- $self->log("add", "$ip:$port added pending $gamename") if ($u > 0);
-
- # return 2 if added new
- return 2 if ($u > 0);
-
- # else
- return -1;
-}
-
-################################################################################
-## Remove an entry from the pending list. Returns 0 if removed or -1 in case
-## of error(s).
-################################################################################
-sub remove_pending {
- my ($self, $id) = @_;
-
- # if address is in list, update the timestamp
- my $u = $self->{dbh}->do(
- "DELETE FROM pending
- WHERE id = ?",
- undef, $id);
-
- # notify
- $self->log("delete", "removed pending id $id from pending") if ($u > 0);
-
- # it was removed from pending
- return 2 if ($u > 0);
-
- # or else report error
- $self->log("error", "error deleting server $id from pending");
- return -1;
-}
-
-################################################################################
-## Get pending server by ip, beacon port. Returns * or undef
-################################################################################
-sub get_pending_beacon {
- my ($self, $ip, $port) = @_;
-
- # if address is in list, update the timestamp
- return $self->{dbh}->selectall_arrayref(
- "SELECT * FROM pending
- WHERE ip = ?
- AND beaconport = ?",
- undef, $ip, $port)->[0];
-}
-
-################################################################################
-## Get pending server by ip, heartbeat port. Returns * or undef
-################################################################################
-sub get_pending_info {
- my ($self, $ip, $port) = @_;
-
- # if address is in list, update the timestamp
- return $self->{dbh}->selectall_arrayref(
- "SELECT * FROM pending
- WHERE ip = ?
- AND heartbeat = ?",
- undef, $ip, $port)->[0];
-}
-
-################################################################################
-## Get server info from any entry with an id higher than the provided one. The
-## server is added to pending at least 15 seconds ago. Returns info or undef.
-################################################################################
-sub get_next_pending {
- my ($self, $id) = @_;
-
- # get 1 pending id that is older than 15s
- return $self->{dbh}->selectall_arrayref(
- "SELECT id, ip, heartbeat, secure FROM pending
- WHERE added < (NOW() - INTERVAL '15 SECONDS')
- AND id > ?
- ORDER BY id ASC LIMIT 1",
- undef, $id)->[0];
-}
-
-
-1;