139 lines
5.5 KiB
Perl
139 lines
5.5 KiB
Perl
package BurguillosInfo::DB::Migrations;
|
|
|
|
use v5.34.1;
|
|
|
|
use strict;
|
|
use warnings;
|
|
use utf8;
|
|
|
|
use feature 'signatures';
|
|
|
|
sub MIGRATIONS {
|
|
return (
|
|
'CREATE TABLE options (
|
|
name TEXT PRIMARY KEY,
|
|
value TEXT
|
|
)',
|
|
'CREATE EXTENSION IF NOT EXISTS "uuid-ossp"',
|
|
'CREATE TABLE paths (
|
|
path TEXT PRIMARY KEY,
|
|
first_seen timestamp DEFAULT NOW()
|
|
)',
|
|
'CREATE TABLE requests (
|
|
uuid UUID DEFAULT uuid_generate_v4(),
|
|
remote_address TEXT NOT NULL,
|
|
user_agent TEXT NOT NULL,
|
|
params JSON NOT NULL,
|
|
date timestamp DEFAULT NOW(),
|
|
path TEXT,
|
|
FOREIGN KEY (path) REFERENCES paths(path)
|
|
)',
|
|
'ALTER TABLE paths ADD COLUMN last_seen TIMESTAMP;',
|
|
'ALTER TABLE paths ALTER COLUMN last_seen SET DEFAULT NOW();',
|
|
'ALTER TABLE requests ADD PRIMARY KEY (uuid)',
|
|
'CREATE INDEX request_extra_index on requests (date, path);',
|
|
'ALTER TABLE requests ADD COLUMN referer text;',
|
|
'CREATE INDEX request_referer_index on requests (referer);',
|
|
'ALTER TABLE requests ADD COLUMN country TEXT;',
|
|
'CREATE INDEX request_country_index on requests (country);',
|
|
'ALTER TABLE requests ADD COLUMN subdivision TEXT;',
|
|
'CREATE INDEX request_subdivision_index on requests (subdivision);',
|
|
\&_populate_locations,
|
|
\&_populate_locations,
|
|
\&_populate_locations,
|
|
\&_populate_locations,
|
|
\&_populate_locations,
|
|
'CREATE TABLE farmacia_guardia (
|
|
uuid UUID DEFAULT uuid_generate_v4() PRIMARY KEY,
|
|
date timestamp NOT NULL,
|
|
id_farmacia TEXT NOT NULL
|
|
);',
|
|
'CREATE INDEX farmacia_guardia_index on farmacia_guardia (date, id_farmacia, uuid);',
|
|
'CREATE TABLE conquer_user (
|
|
uuid UUID NOT NULL PRIMARY KEY,
|
|
username TEXT NOT NULL UNIQUE,
|
|
encrypted_password TEXT NOT NULL,
|
|
last_activity TIMESTAMP NOT NULL DEFAULT NOW(),
|
|
is_admin BOOLEAN NOT NULL DEFAULT false,
|
|
registration_date TIMESTAMP NOT NULL DEFAULT NOW()
|
|
);',
|
|
'CREATE TABLE conquer_node (
|
|
uuid UUID NOT NULL PRIMARY KEY,
|
|
name TEXT NOT NULL,
|
|
type TEXT NOT NULL,
|
|
coordinate_1 REAL NOT NULL,
|
|
coordinate_2 REAL NOT NULL,
|
|
description TEXT NOT NULL
|
|
);',
|
|
'CREATE INDEX index_conquer_node_coordinate_1 on conquer_node (coordinate_1);',
|
|
'CREATE INDEX index_conquer_node_coordinate_2 on conquer_node (coordinate_2);',
|
|
'ALTER TABLE conquer_user ADD COLUMN last_coordinate_1 REAL NOT NULL DEFAULT 0;',
|
|
'ALTER TABLE conquer_user ALTER COLUMN last_coordinate_1 DROP DEFAULT;',
|
|
'ALTER TABLE conquer_user ADD COLUMN last_coordinate_2 REAL NOT NULL DEFAULT 0;',
|
|
'ALTER TABLE conquer_user ALTER COLUMN last_coordinate_2 DROP DEFAULT;',
|
|
'CREATE TABLE conquer_teams (
|
|
uuid UUID NOT NULL PRIMARY KEY,
|
|
name TEXT NOT NULL,
|
|
description TEXT NOT NULL DEFAULT \'\',
|
|
points INTEGER NOT NULL DEFAULT 0
|
|
);',
|
|
'ALTER TABLE conquer_user ADD COLUMN team UUID REFERENCES conquer_teams (uuid);',
|
|
'ALTER TABLE conquer_node ADD COLUMN team UUID REFERENCES conquer_teams (uuid);',
|
|
'ALTER TABLE conquer_teams ADD COLUMN color TEXT NOT NULL DEFAULT \'#000\';',
|
|
'ALTER TABLE conquer_teams ALTER COLUMN color SET DEFAULT \'#555\';',
|
|
'ALTER TABLE conquer_teams ALTER COLUMN color SET DEFAULT \'#aaa\';',
|
|
'CREATE EXTENSION IF NOT EXISTS postgis;',
|
|
'ALTER TABLE conquer_node ADD COLUMN geometry GEOMETRY NULL;',
|
|
'UPDATE conquer_node SET geometry=ST_MakePoint(coordinate_1, coordinate_2);',
|
|
'ALTER TABLE conquer_node ALTER COLUMN geometry SET NOT NULL;',
|
|
'ALTER TABLE conquer_node DROP COLUMN coordinate_1;',
|
|
'ALTER TABLE conquer_node DROP COLUMN coordinate_2;',
|
|
'ALTER TABLE conquer_user ADD COLUMN experience INTEGER NOT NULL DEFAULT 125;',
|
|
'ALTER TABLE conquer_user ADD COLUMN current_hp INTEGER NOT NULL DEFAULT 999;',
|
|
'CREATE TABLE conquer_user_current_enemy (
|
|
uuid UUID NOT NULL PRIMARY KEY,
|
|
"user" UUID NOT NULL REFERENCES conquer_user(uuid),
|
|
species INTEGER NOT NULL,
|
|
is_battled BOOLEAN DEFAULT false,
|
|
is_selected_to_battle BOOLEAN DEFAULT false,
|
|
level INTEGER NOT NULL
|
|
);',
|
|
'ALTER TABLE conquer_user_current_enemy ALTER COLUMN species TYPE TEXT;',
|
|
);
|
|
}
|
|
|
|
sub _populate_locations ($dbh) {
|
|
# This subroutine crashes the migrations.
|
|
# require BurguillosInfo;
|
|
# require BurguillosInfo::Tracking;
|
|
# my $tracking = BurguillosInfo::Tracking->new( BurguillosInfo->new );
|
|
# my $page = 0;
|
|
# while (1) {
|
|
# last if !_update_request_page( $dbh, $tracking, $page );
|
|
# $page += 100;
|
|
# }
|
|
}
|
|
|
|
sub _update_request_page ( $dbh, $tracking, $page ) {
|
|
my $data = $dbh->selectall_arrayref( <<"EOF", { Slice => {} }, $page );
|
|
SELECT uuid, remote_address
|
|
FROM requests
|
|
WHERE date > NOW() - interval '1 month'
|
|
AND country IS NULL
|
|
AND subdivision IS NULL
|
|
ORDER BY date desc
|
|
OFFSET $page
|
|
LIMIT ?;
|
|
EOF
|
|
if ( !@$data ) {
|
|
return;
|
|
}
|
|
for my $request (@$data) {
|
|
my ( $uuid, $remote_address ) = $request->@{ 'uuid', 'remote_address' };
|
|
$tracking->update_country_and_subdivision( $dbh, $uuid,
|
|
$remote_address );
|
|
}
|
|
return 1;
|
|
}
|
|
1;
|