2013-11-28 00:31:09 -05:00
< ? php
2014-02-18 16:59:07 -05:00
/**
* Shimmie Installer
2014-02-22 15:36:52 -05:00
*
2014-02-18 16:59:07 -05:00
* @ package Shimmie
2015-08-09 12:14:28 +01:00
* @ copyright Copyright ( c ) 2007 - 2015 , Shish et al .
2016-05-19 16:07:20 +01:00
* @ author Shish [ webmaster at shishnet . org ], jgen [ jeffgenovy at gmail . com ]
2014-02-18 17:01:35 -05:00
* @ link http :// code . shishnet . org / shimmie2 /
2014-02-18 16:59:07 -05:00
* @ license http :// opensource . org / licenses / gpl - 2.0 . php GNU General Public License v2
2019-05-28 17:59:38 +01:00
*
2015-08-09 12:14:28 +01:00
* Initialise the database , check that folder
* permissions are set properly .
*
2016-05-19 15:40:44 +01:00
* This file should be independent of the database
2015-08-09 12:14:28 +01:00
* and other such things that aren ' t ready yet
2014-02-18 16:59:07 -05:00
*/
2013-11-28 00:31:09 -05:00
// TODO: Rewrite the entire installer and make it more readable.
ob_start ();
2015-08-09 15:40:20 +01:00
date_default_timezone_set ( 'UTC' );
2019-06-25 16:15:49 -05:00
define ( " DATABASE_TIMEOUT " , 10000 );
2013-11-28 00:31:09 -05:00
?>
2012-06-26 23:37:29 +01:00
<! DOCTYPE html >
< html >
2008-01-26 13:14:30 +00:00
< head >
2008-01-27 15:33:59 +00:00
< title > Shimmie Installation </ title >
2018-11-11 17:38:32 +00:00
< link rel = " shortcut icon " href = " ext/handle_static/static/favicon.ico " >
2018-11-07 00:08:26 +00:00
< link rel = " stylesheet " href = " lib/shimmie.css " type = " text/css " >
2018-11-07 14:01:14 +00:00
< script type = " text/javascript " src = " vendor/bower-asset/jquery/dist/jquery.min.js " ></ script >
2008-01-26 13:14:30 +00:00
</ head >
< body >
2019-05-28 17:59:38 +01:00
< ? php if ( false ) { ?>
2012-06-26 23:37:29 +01:00
< div id = " installer " >
2008-01-26 13:14:30 +00:00
< h1 > Install Error </ h1 >
2016-05-19 16:29:55 +01:00
< div class = " container " >
< p > Shimmie needs to be run via a web server with PHP support -- you
appear to be either opening the file from your hard disk , or your
web server is mis - configured and doesn ' t know how to handle PHP files .</ p >
< p > If you ' ve installed a web server on your desktop PC , you probably
want to visit < a href = " http://localhost/ " > the local web server </ a >.< br />< br />
</ p >
</ div >
2008-01-26 13:14:30 +00:00
</ div >
2016-05-19 16:50:05 +01:00
< pre style = " display:none " >
2019-05-28 17:59:38 +01:00
< ? php } elseif ( ! file_exists ( " vendor/ " )) { ?>
2016-05-19 17:11:03 +01:00
< div id = " installer " >
< h1 > Install Error </ h1 >
< h3 > Warning : Composer vendor folder does not exist !</ h3 >
< div class = " container " >
< p > Shimmie is unable to find the composer vendor directory .< br >
Have you followed the composer setup instructions found in the < a href = " https://github.com/shish/shimmie2#installation-development " > README </ a > ? </>
< p > If you are not intending to do any development with Shimmie , it is highly recommend you use one of the pre - packaged releases found on < a href = " https://github.com/shish/shimmie2/releases " > Github </ a > instead .</ p >
</ div >
</ div >
< pre style = " display:none " >
2008-01-26 13:14:30 +00:00
< ? php }
2008-01-27 15:33:59 +00:00
2012-02-09 15:33:40 -05:00
// Pull in necessary files
2019-07-07 15:50:02 +01:00
require_once " vendor/autoload.php " ;
2019-07-07 15:57:06 +01:00
$_tracer = new EventTracer ();
2018-11-07 00:08:26 +00:00
require_once " core/exceptions.php " ;
require_once " core/cacheengine.php " ;
require_once " core/dbengine.php " ;
require_once " core/database.php " ;
2012-02-09 15:33:40 -05:00
2019-05-28 17:59:38 +01:00
if ( is_readable ( " data/config/shimmie.conf.php " )) {
die ( " Shimmie is already installed. " );
}
2007-04-16 11:58:25 +00:00
do_install ();
// utilities {{{
2019-05-28 17:59:38 +01:00
// TODO: Can some of these be pushed into "core/???.inc.php" ?
function check_gd_version () : int
{
$gdversion = 0 ;
if ( function_exists ( 'gd_info' )) {
$gd_info = gd_info ();
if ( substr_count ( $gd_info [ 'GD Version' ], '2.' )) {
$gdversion = 2 ;
} elseif ( substr_count ( $gd_info [ 'GD Version' ], '1.' )) {
$gdversion = 1 ;
}
}
return $gdversion ;
2007-04-16 11:58:25 +00:00
}
2008-01-27 15:33:59 +00:00
2019-05-28 17:59:38 +01:00
function check_im_version () : int
{
$convert_check = exec ( " convert " );
2016-05-19 17:17:04 +01:00
2019-05-28 17:59:38 +01:00
return ( empty ( $convert_check ) ? 0 : 1 );
2008-01-27 15:33:59 +00:00
}
2007-04-16 11:58:25 +00:00
// }}}
2013-11-28 00:31:09 -05:00
2019-05-28 17:59:38 +01:00
function do_install ()
{ // {{{
if ( file_exists ( " data/config/auto_install.conf.php " )) {
require_once " data/config/auto_install.conf.php " ;
2019-06-20 10:42:32 -05:00
} elseif ( @ $_POST [ " database_type " ] == DatabaseDriver :: SQLITE ) {
2019-05-28 17:59:38 +01:00
$id = bin2hex ( random_bytes ( 5 ));
define ( 'DATABASE_DSN' , " sqlite:data/shimmie. { $id } .sqlite " );
} elseif ( isset ( $_POST [ 'database_type' ]) && isset ( $_POST [ 'database_host' ]) && isset ( $_POST [ 'database_user' ]) && isset ( $_POST [ 'database_name' ])) {
define ( 'DATABASE_DSN' , " { $_POST [ 'database_type' ] } :user= { $_POST [ 'database_user' ] } ;password= { $_POST [ 'database_password' ] } ;host= { $_POST [ 'database_host' ] } ;dbname= { $_POST [ 'database_name' ] } " );
} else {
ask_questions ();
return ;
}
define ( " CACHE_DSN " , null );
define ( " DATABASE_KA " , true );
install_process ();
2008-01-27 16:25:17 +00:00
} // }}}
2013-11-28 00:31:09 -05:00
2019-05-28 17:59:38 +01:00
function ask_questions ()
{ // {{{
$warnings = [];
$errors = [];
2009-07-15 22:17:53 +01:00
2019-05-28 17:59:38 +01:00
if ( check_gd_version () == 0 && check_im_version () == 0 ) {
$errors [] = "
2016-05-19 17:49:35 +01:00
No thumbnailers could be found - install the imagemagick
2018-11-05 17:45:19 +00:00
tools ( or the PHP - GD library , if imagemagick is unavailable ) .
2012-03-09 22:27:12 +00:00
" ;
2019-05-28 17:59:38 +01:00
} elseif ( check_im_version () == 0 ) {
$warnings [] = "
2012-06-26 23:37:29 +01:00
The 'convert' command ( from the imagemagick package )
could not be found - PHP - GD can be used instead , but
the size of thumbnails will be limited .
2012-03-09 22:27:12 +00:00
" ;
2019-05-28 17:59:38 +01:00
}
2009-07-15 22:17:53 +01:00
2019-05-28 17:59:38 +01:00
if ( ! function_exists ( 'mb_strlen' )) {
$errors [] = "
2018-11-05 17:45:19 +00:00
The mbstring PHP extension is missing - multibyte languages
( eg non - english languages ) may not work right .
" ;
2019-05-28 17:59:38 +01:00
}
$drivers = PDO :: getAvailableDrivers ();
if (
2019-06-20 10:42:32 -05:00
! in_array ( DatabaseDriver :: MYSQL , $drivers ) &&
! in_array ( DatabaseDriver :: PGSQL , $drivers ) &&
! in_array ( DatabaseDriver :: SQLITE , $drivers )
2019-05-28 17:59:38 +01:00
) {
$errors [] = "
2012-06-26 23:37:29 +01:00
No database connection library could be found ; shimmie needs
2012-06-26 23:51:05 +01:00
PDO with either Postgres , MySQL , or SQLite drivers
2012-06-26 23:37:29 +01:00
" ;
2019-05-28 17:59:38 +01:00
}
2007-04-16 11:58:25 +00:00
2019-06-20 10:42:32 -05:00
$db_m = in_array ( DatabaseDriver :: MYSQL , $drivers ) ? '<option value="' . DatabaseDriver :: MYSQL . '">MySQL</option>' : " " ;
$db_p = in_array ( DatabaseDriver :: PGSQL , $drivers ) ? '<option value="' . DatabaseDriver :: PGSQL . '">PostgreSQL</option>' : " " ;
$db_s = in_array ( DatabaseDriver :: SQLITE , $drivers ) ? '<option value="' . DatabaseDriver :: SQLITE . '">SQLite</option>' : " " ;
2012-06-26 23:37:29 +01:00
2019-05-28 17:59:38 +01:00
$warn_msg = $warnings ? " <h3>Warnings</h3> " . implode ( " \n <p> " , $warnings ) : " " ;
$err_msg = $errors ? " <h3>Errors</h3> " . implode ( " \n <p> " , $errors ) : " " ;
2012-06-26 23:37:29 +01:00
2019-05-28 17:59:38 +01:00
print <<< EOD
2012-06-26 23:37:29 +01:00
< div id = " installer " >
2008-01-26 13:14:30 +00:00
< h1 > Shimmie Installer </ h1 >
2016-05-19 16:29:55 +01:00
< div class = " container " >
$warn_msg
$err_msg
< h3 > Database Install </ h3 >
2018-11-07 00:08:26 +00:00
< form action = " index.php " method = " POST " >
2016-05-19 16:29:55 +01:00
< center >
< table class = 'form' >
< tr >
< th > Type :</ th >
< td >< select name = " database_type " id = " database_type " onchange = " update_qs(); " >
$db_m
$db_p
$db_s
</ select ></ td >
</ tr >
< tr class = " dbconf mysql pgsql " >
< th > Host :</ th >
< td >< input type = " text " name = " database_host " size = " 40 " value = " localhost " ></ td >
</ tr >
< tr class = " dbconf mysql pgsql " >
< th > Username :</ th >
< td >< input type = " text " name = " database_user " size = " 40 " ></ td >
</ tr >
< tr class = " dbconf mysql pgsql " >
< th > Password :</ th >
< td >< input type = " password " name = " database_password " size = " 40 " ></ td >
</ tr >
2018-11-07 16:48:07 +00:00
< tr class = " dbconf mysql pgsql " >
2016-05-19 16:29:55 +01:00
< th > DB & nbsp ; Name :</ th >
< td >< input type = " text " name = " database_name " size = " 40 " value = " shimmie " ></ td >
</ tr >
< tr >< td colspan = " 2 " >< input type = " submit " value = " Go! " ></ td ></ tr >
</ table >
</ center >
< script >
$ ( function () {
update_qs ();
});
function update_qs () {
$ ( " .dbconf " ) . hide ();
var seldb = $ ( " #database_type " ) . val () || " none " ;
$ ( " . " + seldb ) . show ();
}
</ script >
</ form >
< h3 > Help </ h3 >
< p class = " dbconf mysql pgsql " >
Please make sure the database you have chosen exists and is empty .< br >
The username provided must have access to create tables within the database .
</ p >
< p class = " dbconf sqlite " >
For SQLite the database name will be a filename on disk , relative to
where shimmie was installed .
</ p >
< p class = " dbconf none " >
Drivers can generally be downloaded with your OS package manager ;
2018-11-07 00:08:26 +00:00
for Debian / Ubuntu you want php - pgsql , php - mysql , or php - sqlite .
2016-05-19 16:29:55 +01:00
</ p >
</ div >
2008-01-26 13:14:30 +00:00
</ div >
2007-04-16 11:58:25 +00:00
EOD ;
2008-01-27 16:25:17 +00:00
} // }}}
2013-11-28 00:31:09 -05:00
/**
* This is where the install really takes place .
*/
2019-05-28 17:59:38 +01:00
function install_process ()
{ // {{{
build_dirs ();
create_tables ();
insert_defaults ();
write_config ();
2007-04-16 11:58:25 +00:00
} // }}}
2013-11-28 00:31:09 -05:00
2019-05-28 17:59:38 +01:00
function create_tables ()
{ // {{{
try {
$db = new Database ();
2014-02-22 15:36:52 -05:00
2019-05-28 17:59:38 +01:00
if ( $db -> count_tables () > 0 ) {
print <<< EOD
2013-11-28 00:31:09 -05:00
< div id = " installer " >
< h1 > Shimmie Installer </ h1 >
2016-05-19 17:11:03 +01:00
< h3 > Warning : The Database schema is not empty !</ h3 >
2016-05-19 16:29:55 +01:00
< div class = " container " >
< p > Please ensure that the database you are installing Shimmie with is empty before continuing .</ p >
< p > Once you have emptied the database of any tables , please hit 'refresh' to continue .</ p >
< br />< br />
</ div >
2013-11-28 00:31:09 -05:00
</ div >
EOD ;
2019-05-28 17:59:38 +01:00
exit ( 2 );
}
2014-02-22 15:36:52 -05:00
2019-05-28 17:59:38 +01:00
$db -> create_table ( " aliases " , "
2014-02-22 22:04:14 -05:00
oldtag VARCHAR ( 128 ) NOT NULL ,
2009-01-22 04:05:55 -08:00
newtag VARCHAR ( 128 ) NOT NULL ,
2014-02-22 22:04:14 -05:00
PRIMARY KEY ( oldtag )
2011-02-21 22:06:55 -05:00
" );
2019-05-28 17:59:38 +01:00
$db -> execute ( " CREATE INDEX aliases_newtag_idx ON aliases(newtag) " , []);
2016-05-19 16:29:55 +01:00
2019-05-28 17:59:38 +01:00
$db -> create_table ( " config " , "
2014-02-22 22:04:14 -05:00
name VARCHAR ( 128 ) NOT NULL ,
value TEXT ,
PRIMARY KEY ( name )
2011-02-21 22:06:55 -05:00
" );
2019-05-28 17:59:38 +01:00
$db -> create_table ( " users " , "
2009-01-22 05:03:51 -08:00
id SCORE_AIPK ,
2009-01-22 05:42:44 -08:00
name VARCHAR ( 32 ) UNIQUE NOT NULL ,
2014-05-24 00:28:57 +01:00
pass VARCHAR ( 250 ),
2009-07-15 23:29:14 +01:00
joindate SCORE_DATETIME NOT NULL DEFAULT SCORE_NOW ,
2012-02-21 18:37:36 +00:00
class VARCHAR ( 32 ) NOT NULL DEFAULT 'user' ,
2014-02-22 22:04:14 -05:00
email VARCHAR ( 128 )
2011-02-21 22:06:55 -05:00
" );
2019-05-28 17:59:38 +01:00
$db -> execute ( " CREATE INDEX users_name_idx ON users(name) " , []);
2016-05-19 16:29:55 +01:00
2019-05-28 17:59:38 +01:00
$db -> create_table ( " images " , "
2009-01-22 04:05:55 -08:00
id SCORE_AIPK ,
2009-01-22 05:03:51 -08:00
owner_id INTEGER NOT NULL ,
2009-01-22 04:05:55 -08:00
owner_ip SCORE_INET NOT NULL ,
filename VARCHAR ( 64 ) NOT NULL ,
filesize INTEGER NOT NULL ,
2009-01-22 05:42:44 -08:00
hash CHAR ( 32 ) UNIQUE NOT NULL ,
2009-01-22 04:05:55 -08:00
ext CHAR ( 4 ) NOT NULL ,
source VARCHAR ( 255 ),
width INTEGER NOT NULL ,
height INTEGER NOT NULL ,
2009-07-15 23:29:14 +01:00
posted SCORE_DATETIME NOT NULL DEFAULT SCORE_NOW ,
2009-01-24 03:59:51 -08:00
locked SCORE_BOOL NOT NULL DEFAULT SCORE_BOOL_N ,
2012-03-11 01:52:25 +00:00
FOREIGN KEY ( owner_id ) REFERENCES users ( id ) ON DELETE RESTRICT
2011-02-21 22:06:55 -05:00
" );
2019-05-28 17:59:38 +01:00
$db -> execute ( " CREATE INDEX images_owner_id_idx ON images(owner_id) " , []);
$db -> execute ( " CREATE INDEX images_width_idx ON images(width) " , []);
$db -> execute ( " CREATE INDEX images_height_idx ON images(height) " , []);
$db -> execute ( " CREATE INDEX images_hash_idx ON images(hash) " , []);
2016-05-19 16:29:55 +01:00
2019-05-28 17:59:38 +01:00
$db -> create_table ( " tags " , "
2009-01-22 04:05:55 -08:00
id SCORE_AIPK ,
2009-01-22 05:42:44 -08:00
tag VARCHAR ( 64 ) UNIQUE NOT NULL ,
2014-02-22 22:06:33 -05:00
count INTEGER NOT NULL DEFAULT 0
2011-02-21 22:06:55 -05:00
" );
2019-05-28 17:59:38 +01:00
$db -> execute ( " CREATE INDEX tags_tag_idx ON tags(tag) " , []);
2016-05-19 16:29:55 +01:00
2019-05-28 17:59:38 +01:00
$db -> create_table ( " image_tags " , "
2009-01-22 05:03:51 -08:00
image_id INTEGER NOT NULL ,
tag_id INTEGER NOT NULL ,
2009-01-22 05:42:44 -08:00
UNIQUE ( image_id , tag_id ),
2012-03-11 01:52:25 +00:00
FOREIGN KEY ( image_id ) REFERENCES images ( id ) ON DELETE CASCADE ,
FOREIGN KEY ( tag_id ) REFERENCES tags ( id ) ON DELETE CASCADE
2011-02-21 22:06:55 -05:00
" );
2019-05-28 17:59:38 +01:00
$db -> execute ( " CREATE INDEX images_tags_image_id_idx ON image_tags(image_id) " , []);
$db -> execute ( " CREATE INDEX images_tags_tag_id_idx ON image_tags(tag_id) " , []);
$db -> execute ( " INSERT INTO config(name, value) VALUES('db_version', 11) " );
$db -> commit ();
} catch ( PDOException $e ) {
handle_db_errors ( true , " An error occurred while trying to create the database tables necessary for Shimmie. " , $e -> getMessage (), 3 );
} catch ( Exception $e ) {
handle_db_errors ( false , " An unknown error occurred while trying to insert data into the database. " , $e -> getMessage (), 4 );
}
2011-02-21 22:06:55 -05:00
} // }}}
2013-11-28 00:31:09 -05:00
2019-05-28 17:59:38 +01:00
function insert_defaults ()
{ // {{{
try {
$db = new Database ();
$db -> execute ( " INSERT INTO users(name, pass, joindate, class) VALUES(:name, :pass, now(), :class) " , [ " name " => 'Anonymous' , " pass " => null , " class " => 'anonymous' ]);
$db -> execute ( " INSERT INTO config(name, value) VALUES(:name, :value) " , [ " name " => 'anon_id' , " value " => $db -> get_last_insert_id ( 'users_id_seq' )]);
if ( check_im_version () > 0 ) {
$db -> execute ( " INSERT INTO config(name, value) VALUES(:name, :value) " , [ " name " => 'thumb_engine' , " value " => 'convert' ]);
}
$db -> commit ();
} catch ( PDOException $e ) {
handle_db_errors ( true , " An error occurred while trying to insert data into the database. " , $e -> getMessage (), 5 );
} catch ( Exception $e ) {
handle_db_errors ( false , " An unknown error occurred while trying to insert data into the database. " , $e -> getMessage (), 6 );
}
2008-01-27 16:25:17 +00:00
} // }}}
2013-11-28 00:31:09 -05:00
2019-05-28 17:59:38 +01:00
function build_dirs ()
{ // {{{
2019-10-02 09:03:14 +01:00
$data_exists = file_exists ( " data " ) || mkdir ( " data " );
$data_writable = is_writable ( " data " ) || chmod ( " data " , 0755 );
2019-05-28 17:59:38 +01:00
2019-10-02 09:03:14 +01:00
if ( ! $data_exists || ! $data_writable ) {
2019-05-28 17:59:38 +01:00
print "
2013-11-28 00:31:09 -05:00
< div id = 'installer' >
< h1 > Shimmie Installer </ h1 >
< h3 > Directory Permissions Error :</ h3 >
2016-05-19 17:11:03 +01:00
< div class = 'container' >
2018-11-07 16:06:10 +00:00
< p > Shimmie needs to have a 'data' folder in its directory , writable by the PHP user .</ p >
< p > If you see this error , if probably means the folder is owned by you , and it needs to be writable by the web server .</ p >
2016-05-19 17:11:03 +01:00
< p > PHP reports that it is currently running as user : " . $_ENV["USER"] . " ( " . $_SERVER["USER"] . " ) </ p >
2018-11-07 16:06:10 +00:00
< p > Once you have created this folder and / or changed the ownership of the shimmie folder , hit 'refresh' to continue .</ p >
2016-05-19 17:11:03 +01:00
< br />< br />
</ div >
2013-11-28 00:31:09 -05:00
</ div >
2012-03-09 22:27:12 +00:00
" ;
2019-05-28 17:59:38 +01:00
exit ( 7 );
}
2007-04-16 11:58:25 +00:00
} // }}}
2013-11-28 00:31:09 -05:00
2019-05-28 17:59:38 +01:00
function write_config ()
{ // {{{
$file_content = '<' . '?php' . " \n " .
" define('DATABASE_DSN', ' " . DATABASE_DSN . " '); \n " .
'?' . '>' ;
2014-02-22 15:36:52 -05:00
2019-05-28 17:59:38 +01:00
if ( ! file_exists ( " data/config " )) {
mkdir ( " data/config " , 0755 , true );
}
2014-02-22 15:36:52 -05:00
2019-05-28 17:59:38 +01:00
if ( file_put_contents ( " data/config/shimmie.conf.php " , $file_content , LOCK_EX )) {
header ( " Location: index.php " );
print <<< EOD
2015-08-09 12:14:28 +01:00
< div id = " installer " >
< h1 > Shimmie Installer </ h1 >
< h3 > Things are OK \o /</ h3 >
2016-05-19 17:11:03 +01:00
< div class = " container " >
< p > If you aren ' t redirected , < a href = " index.php " > click here to Continue </ a >.
</ div >
2015-08-09 12:14:28 +01:00
</ div >
EOD ;
2019-05-28 17:59:38 +01:00
} else {
$h_file_content = htmlentities ( $file_content );
print <<< EOD
2013-11-28 00:31:09 -05:00
< div id = " installer " >
< h1 > Shimmie Installer </ h1 >
< h3 > File Permissions Error :</ h3 >
2016-05-19 17:11:03 +01:00
< div class = " container " >
The web server isn ' t allowed to write to the config file ; please copy
the text below , save it as 'data/config/shimmie.conf.php' , and upload it into the shimmie
folder manually . Make sure that when you save it , there is no whitespace
before the " <?php " or after the " ?> "
< p >< textarea cols = " 80 " rows = " 2 " > $h_file_content </ textarea >
< p > Once done , < a href = " index.php " > click here to Continue </ a >.
< br />< br />
</ div >
2013-11-28 00:31:09 -05:00
</ div >
2007-04-16 11:58:25 +00:00
EOD ;
2019-05-28 17:59:38 +01:00
}
echo " \n " ;
2007-04-16 11:58:25 +00:00
} // }}}
2016-05-19 16:29:55 +01:00
2019-05-28 17:59:38 +01:00
function handle_db_errors ( bool $isPDO , string $errorMessage1 , string $errorMessage2 , int $exitCode )
{
$errorMessage1Extra = ( $isPDO ? " Please check and ensure that the database configuration options are all correct. " : " Please check the server log files for more information. " );
print <<< EOD
2016-05-19 16:29:55 +01:00
< div id = " installer " >
< h1 > Shimmie Installer </ h1 >
2016-05-19 17:11:03 +01:00
< h3 > Unknown Error :</ h3 >
2016-05-19 16:29:55 +01:00
< div class = " container " >
< p > { $errorMessage1 } </ p >
< p > { $errorMessage1Extra } </ p >
< p > { $errorMessage2 } </ p >
</ div >
</ div >
EOD ;
2019-05-28 17:59:38 +01:00
exit ( $exitCode );
2016-05-19 16:29:55 +01:00
}
2007-04-16 11:58:25 +00:00
?>
2008-01-27 15:33:59 +00:00
</ body >
</ html >