forked from elliotchance/mbzdb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
update.pl
executable file
·113 lines (96 loc) · 2.65 KB
/
update.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#!/usr/bin/perl
use LWP::UserAgent;
use DBI;
# FLAGS
$f_quiet = 0;
$f_info = 0;
$f_onlypending = 0;
$f_skiptorep = 0;
$f_truncatetables = 0;
require "settings.pl";
require "settings_$g_db_rdbms.pl";
require "languages/$g_language.pl";
require "backend/$g_db_rdbms.pl";
require "src/functions.pl";
mbz_create_folders();
# require plugin files
foreach my $plugin (@g_active_plugins) {
require "plugins/$plugin.pl";
}
# PROCESS FLAGS
foreach $ARG (@ARGV) {
@parts = split("=", $ARG);
if($parts[0] eq "-q" || $parts[0] eq "--quiet") {
$f_quiet = 1;
} elsif($parts[0] eq "-i" || $parts[0] eq "--info") {
$f_info = 1;
} elsif($parts[0] eq "-t" || $parts[0] eq "--truncate") {
$f_truncatetables = 1;
} elsif($parts[0] eq "-p" || $parts[0] eq "--onlypending") {
$f_onlypending = 1;
} elsif($parts[0] eq "-g" || $parts[0] eq "--skiptorep") {
$f_skiptorep = int($parts[1]);
} elsif($parts[0] eq "-h" || $parts[0] eq "--help") {
mbz_show_update_help();
exit(0);
} else {
die "Unknown option '$parts[0]'\n";
}
}
# TRUNCATE TABLES
if($f_truncatetables == 1) {
mbz_do_sql("TRUNCATE $g_pending");
mbz_do_sql("TRUNCATE $g_pendingdata");
print "Table truncate successful.\n";
exit(0);
}
BEGIN:
# GET CURRENT REPLICATION AND SCHEMA
my $rep = mbz_get_current_replication();
#my $schema = $row[1];
# CHANGE REPLICATION NUMBER
if($f_skiptorep > 0) {
print "CHANGING REPLICATION NUMBER: $f_skiptorep\n";
print "Moving ";
if($rep > $f_skiptorep) {
print "BACKWARD ";
} else {
print "FORWARD ";
}
print abs($f_skiptorep - $rep) . " replications.\n";
mbz_do_sql("UPDATE replication_control SET current_replication_sequence=$f_skiptorep");
print "Done\n";
exit(0);
}
# FIND IF THERE ARE PENDING TRANSACTIONS
$sth = $dbh->prepare("SELECT count(1) from " . mbz_escape_entity($g_pending));
$sth->execute();
@row = $sth->fetchrow_array();
if($f_info) {
print "\nCurrent replication : " . ($rep + 1);
$sql = "SELECT * from replication_control";
my $sth2 = $dbh->prepare($sql);
$sth2->execute;
my @row2 = $sth2->fetchrow_array();
print "\nLast replication finished : " . $row2[3];
print "\nPending transactions : $row[0]\n\n";
exit(0);
}
print "\nCurrent replication is $rep\n\n";
$id = int($rep) + 1;
print "Looking for previous pending changes... $row[0] pending\n\n";
if($row[0] == 0 && !$f_info) {
exit(0) if($f_onlypending);
if(!mbz_download_replication($id)) {
print "\nReplication $id could not be found on the server\n\n";
exit(0);
}
mbz_unzip_replication($id);
mbz_load_pending($id);
}
# run the pending edits
print localtime() . ": Processing Transactions...\n";
mbz_run_transactions();
print "Finished\n";
goto BEGIN if(!$f_info);
1;