-
Notifications
You must be signed in to change notification settings - Fork 51
/
upgrade.pl
174 lines (139 loc) · 4.83 KB
/
upgrade.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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
#!/usr/bin/perl -w
=head1 NAME
upgrade.pl - installation script to gather upgrade information
=head1 VERSION
$Revision: 1.3 $
=head1 DATE
$Date: 2002-06-25 21:50:41 $
=head1 DESCRIPTION
This script is called by "make upgrade" to prepare for an upgrade.
Gathers configuration information from the user and install.db if
available. Outputs to the various .db files used by later stages of
the install.
=head1 AUTHOR
Sam Tregar <stregar@about-inc.com>
=head1 SEE ALSO
L<Bric::Admin>
=cut
use strict;
use FindBin;
use lib "$FindBin::Bin/lib";
use Bric::Inst qw(:all);
use File::Spec::Functions qw(:ALL);
use Data::Dumper;
# make sure we're root, otherwise uninformative errors result
unless ($> == 0) {
print "This process must (usually) be run as root.\n";
exit 1 unless ask_yesno("Continue as non-root user? [yes] ", 1);
}
# setup default root
our %UPGRADE = ( BRICOLAGE_ROOT => $ENV{BRICOLAGE_ROOT} ||
'/usr/local/bricolage' );
our $INSTALL;
# determine version being installed
use lib './lib';
require "lib/Bric.pm";
our $VERSION = $Bric::VERSION;
print "\n\n==> Setting-up Bricolage Upgrade Process <==\n\n";
get_bricolage_root();
read_install_db();
check_version();
confirm_paths();
output_dbs();
print "\n\n==> Finished Setting-up Bricolage Upgrade Process <==\n\n";
# find the bricolage to update
sub get_bricolage_root {
ask_confirm("Bricolage Root Directory to Upgrade?",
\$UPGRADE{BRICOLAGE_ROOT});
# verify that we have a Bricolage install here
hard_fail("No Bricolage installation found in $UPGRADE{BRICOLAGE_ROOT}.\n")
unless -e catfile($UPGRADE{BRICOLAGE_ROOT}, "conf", "bricolage.conf");
# verify that this Bricolage was installed with "make install"
hard_fail("The Bricolage Installation found in $UPGRADE{BRICOLAGE_ROOT}\n",
"was installed manually and cannot be automatically upgraded.")
unless -e catfile($UPGRADE{BRICOLAGE_ROOT}, "conf", "install.db");
}
# read the install.db file from the chosen bricolage root
sub read_install_db {
my $install_file = catfile($UPGRADE{BRICOLAGE_ROOT}, "conf", "install.db");
if (-e $install_file) {
# read it in if it exists
do $install_file or die "Failed to read $install_file : $!";
}
}
# check that the version number exists in the version database, note
# the versions need to upgrade to current version
sub check_version {
my @todo;
# make sure we're not trying to install the same version twice
if ($INSTALL->{VERSION} eq $VERSION) {
print <<END;
The installed version ("$VERSION") is the same as this version! "make
upgrade" is only designed to work to upgrade from one version to
another. Please use "make install if you wish to overwrite your
current install.
END
exit 1 unless ask_yesno("Continue with upgrade? [no] ", 0);
@todo = ($VERSION);
} else {
# read in versions.txt
my @versions;
open(VER, "inst/versions.txt") or die "Cannot open inst/versions.txt : $!";
while (<VER>) {
chomp;
next if /^#/ or /^\s*$/;
push @versions, $_;
}
close VER;
# find this version
my $found;
for my $i (0 .. $#versions) {
if ($versions[$i] eq $INSTALL->{VERSION}) {
$found = 1;
@todo = @versions[$i + 1 .. $#versions];
last;
}
}
# didn't find the version?
hard_fail(<<END) unless $found;
Couldn't find version "$INSTALL->{VERSION}" in inst/versions.txt. Are
you trying to install an older version over a newer one? That won't
work.
END
}
# save todo list for later
$UPGRADE{TODO} = \@todo;
# note the plan of action
print "Found existing version $INSTALL->{VERSION}.\n";
print "Will run database upgrade scripts for version(s) ",
join(', ', @todo), "\n"
if @todo;
}
# confirm paths listed in install.db
sub confirm_paths {
print "\nPlease confirm the Bricolage target directories.\n\n";
ask_confirm("Bricolage Perl Module Directory",
\$INSTALL->{CONFIG}{MODULE_DIR});
ask_confirm("Bricolage Executable Directory",
\$INSTALL->{CONFIG}{BIN_DIR});
ask_confirm("Bricolage Man-Page Directory",
\$INSTALL->{CONFIG}{MAN_DIR});
ask_confirm("Mason Component Directory",
\$INSTALL->{CONFIG}{MASON_COMP_ROOT});
}
# output .db files used by installation steps
sub output_dbs {
# fake up the .dbs from %INSTALL
my %dbs = ( PG => "postgres.db",
CONFIG => "config.db",
AP => "apache.db" );
while ( my ($key, $file) = each %dbs) {
open(FILE, ">$file") or die "Unable to open $file : $!";
print FILE Data::Dumper->Dump([$INSTALL->{$key}], [$key]);
close(FILE);
}
# output upgrade.db
open(FILE, ">upgrade.db") or die "Unable to open upgrade.db : $!";
print FILE Data::Dumper->Dump([\%UPGRADE], ["UPGRADE"]);
close(FILE);
}