This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/install.php

474 lines
14 KiB
PHP
Raw Normal View History

<?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
* @copyright Copyright (c) 2007-2014, Shish et al.
* @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
*
2014-02-18 16:59:07 -05:00
*/
// TODO: Rewrite the entire installer and make it more readable.
ob_start();
/*
<!--
- install.php (c) Shish et all. 2007-2013
-
- Initialise the database, check that folder
- permissions are set properly.
-
- This file should be independant of the database
- and other such things that aren't ready yet
-->
*/
?>
2012-06-26 23:37:29 +01:00
<!DOCTYPE html>
<html>
<!-- Shimmie (c) Shish et all. 2007-2013 -->
<head>
<title>Shimmie Installation</title>
2012-06-26 23:37:29 +01:00
<link rel="shortcut icon" href="favicon.ico" />
2012-03-31 13:56:06 +01:00
<link rel='stylesheet' href='lib/shimmie.css' type='text/css'>
<script type="text/javascript" src="lib/jquery-1.7.1.min.js"></script>
</head>
<body>
<?php if(false) { ?>
2012-06-26 23:37:29 +01:00
<div id="installer">
<h1>Install Error</h1>
<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>
<div style="display: none;">
<PLAINTEXT>
<?php }
assert_options(ASSERT_ACTIVE, 1);
assert_options(ASSERT_BAIL, 1);
/*
2014-02-22 15:36:52 -05:00
* Compute the path to the folder containing "install.php" and
* store it as the 'Shimmie Root' folder for later on.
*
* Example:
* __SHIMMIE_ROOT__ = '/var/www/shimmie2/'
*
*/
2012-03-31 16:28:54 +01:00
define('__SHIMMIE_ROOT__', trim(remove_trailing_slash(dirname(__FILE__))) . '/');
// Pull in necessary files
require_once __SHIMMIE_ROOT__."core/util.inc.php";
2012-03-09 18:03:10 +00:00
require_once __SHIMMIE_ROOT__."core/exceptions.class.php";
require_once __SHIMMIE_ROOT__."core/database.class.php";
if(is_readable("data/config/shimmie.conf.php")) die("Shimmie is already installed.");
do_install();
// utilities {{{
// TODO: Can some of these be pushed into "core/util.inc.php" ?
/**
* Strips off any kind of slash at the end so as to normalise the path.
* @param string $path Path to normalise.
* @return string Path without trailing slash.
*/
function remove_trailing_slash($path) {
if ((substr($path, -1) === '/') || (substr($path, -1) === '\\')) {
return substr($path, 0, -1);
} else {
return $path;
}
}
function check_gd_version() {
$gdversion = 0;
if (function_exists('gd_info')){
$gd_info = gd_info();
if (substr_count($gd_info['GD Version'], '2.')) {
$gdversion = 2;
} else if (substr_count($gd_info['GD Version'], '1.')) {
$gdversion = 1;
}
}
return $gdversion;
}
function check_im_version() {
if(!ini_get('safe_mode')) {
$convert_check = exec("convert");
}
return (empty($convert_check) ? 0 : 1);
}
2010-03-15 05:30:37 +00:00
function eok($name, $value) {
echo "<br>$name ... ";
if($value) {
echo "<font color='green'>ok</font>\n";
}
else {
echo "<font color='red'>failed</font>\n";
}
}
// }}}
function do_install() { // {{{
2012-06-26 23:37:29 +01:00
if(file_exists("data/config/auto_install.conf.php")) {
require_once "data/config/auto_install.conf.php";
2011-02-21 22:06:55 -05:00
install_process();
2009-01-22 05:02:22 -08:00
}
2012-06-26 23:37:29 +01:00
else if(@$_POST["database_type"] == "sqlite" && isset($_POST["database_name"])) {
define('DATABASE_DSN', "sqlite:{$_POST["database_name"]}");
define("DATABASE_KA", true); // Keep database connection alive
2012-06-26 23:37:29 +01:00
install_process();
}
else if(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']}");
define("DATABASE_KA", true); // Keep database connection alive
2012-02-13 21:09:34 +00:00
install_process();
}
else {
2012-06-26 23:37:29 +01:00
ask_questions();
}
} // }}}
2012-06-26 23:37:29 +01:00
function ask_questions() { // {{{
$warnings = array();
$errors = array();
2009-07-15 22:17:53 +01:00
if(check_gd_version() == 0 && check_im_version() == 0) {
2012-06-26 23:37:29 +01:00
$errors[] = "
No thumbnailers cound be found - install the imagemagick
tools (or the PHP-GD library, of imagemagick is unavailable).
2012-03-09 22:27:12 +00:00
";
}
2012-06-26 23:37:29 +01:00
else if(check_im_version() == 0) {
$warnings[] = "
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
";
2009-07-15 22:17:53 +01:00
}
2012-06-26 23:51:05 +01:00
$drivers = PDO::getAvailableDrivers();
2012-06-26 23:37:29 +01:00
if(
2012-06-26 23:51:05 +01:00
!in_array("mysql", $drivers) &&
!in_array("pgsql", $drivers) &&
2012-06-26 23:51:05 +01:00
!in_array("sqlite", $drivers)
2012-06-26 23:37:29 +01:00
) {
$errors[] = "
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
";
}
2012-06-26 23:51:05 +01:00
$db_m = in_array("mysql", $drivers) ? '<option value="mysql">MySQL</option>' : "";
$db_p = in_array("pgsql", $drivers) ? '<option value="pgsql">PostgreSQL</option>' : "";
$db_s = in_array("sqlite", $drivers) ? '<option value="sqlite">SQLite</option>' : "";
2012-06-26 23:37:29 +01:00
$warn_msg = $warnings ? "<h3>Warnings</h3>".implode("\n<br>", $warnings) : "";
$err_msg = $errors ? "<h3>Errors</h3>".implode("\n<br>", $errors) : "";
print <<<EOD
2012-06-26 23:37:29 +01:00
<div id="installer">
<h1>Shimmie Installer</h1>
2012-06-26 23:37:29 +01:00
$warn_msg
$err_msg
2011-02-21 22:06:55 -05:00
<h3>Database Install</h3>
<form action="install.php" method="POST">
<center>
2012-03-31 13:56:06 +01:00
<table class='form'>
2011-02-21 22:06:55 -05:00
<tr>
2012-03-31 13:56:06 +01:00
<th>Type:</th>
2012-06-26 23:37:29 +01:00
<td><select name="database_type" id="database_type" onchange="update_qs();">
$db_m
$db_p
$db_s
</select></td>
2011-02-21 22:06:55 -05:00
</tr>
2012-06-26 23:37:29 +01:00
<tr class="dbconf mysql pgsql">
2012-03-31 13:56:06 +01:00
<th>Host:</th>
2011-02-21 22:06:55 -05:00
<td><input type="text" name="database_host" size="40" value="localhost"></td>
</tr>
2012-06-26 23:37:29 +01:00
<tr class="dbconf mysql pgsql">
2012-03-31 13:56:06 +01:00
<th>Username:</th>
2011-02-21 22:06:55 -05:00
<td><input type="text" name="database_user" size="40"></td>
</tr>
2012-06-26 23:37:29 +01:00
<tr class="dbconf mysql pgsql">
2012-03-31 13:56:06 +01:00
<th>Password:</th>
2011-02-21 22:06:55 -05:00
<td><input type="password" name="database_password" size="40"></td>
</tr>
2012-06-26 23:37:29 +01:00
<tr class="dbconf mysql pgsql sqlite">
<th>DB&nbsp;Name:</th>
2011-02-21 22:06:55 -05:00
<td><input type="text" name="database_name" size="40" value="shimmie"></td>
</tr>
2012-06-26 23:37:29 +01:00
<tr><td colspan="2"><input type="submit" value="Go!"></td></tr>
</table>
</center>
2012-06-26 23:37:29 +01:00
<script>
$(function() {
update_qs();
});
function update_qs() {
$(".dbconf").hide();
var seldb = $("#database_type").val() || "none";
2012-06-26 23:37:29 +01:00
$("."+seldb).show();
}
</script>
</form>
<h3>Help</h3>
2014-02-22 15:36:52 -05:00
2012-06-26 23:37:29 +01:00
<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;
for Debian / Ubuntu you want php5-pgsql, php5-mysql, or php5-sqlite.
</p>
2014-02-22 15:36:52 -05:00
</div>
EOD;
} // }}}
/**
* This is where the install really takes place.
*/
2011-02-21 22:06:55 -05:00
function install_process() { // {{{
2010-03-15 04:31:28 +00:00
build_dirs();
2011-02-21 22:06:55 -05:00
create_tables();
insert_defaults();
write_config();
2014-02-22 15:36:52 -05:00
2009-01-22 01:39:44 -08:00
header("Location: index.php");
} // }}}
2011-02-21 22:06:55 -05:00
function create_tables() { // {{{
try {
$db = new Database();
2014-02-22 15:36:52 -05:00
2012-04-18 00:55:39 -04:00
if ( $db->count_tables() > 0 ) {
print <<<EOD
<div id="installer">
<h1>Shimmie Installer</h1>
<h3>Warning: The Database schema is not empty!</h3>
<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>
EOD;
exit;
}
2014-02-22 15:36:52 -05:00
2011-02-21 22:06:55 -05:00
$db->create_table("aliases", "
oldtag VARCHAR(128) NOT NULL,
2009-01-22 04:05:55 -08:00
newtag VARCHAR(128) NOT NULL,
PRIMARY KEY (oldtag)
2011-02-21 22:06:55 -05:00
");
$db->execute("CREATE INDEX aliases_newtag_idx ON aliases(newtag)", array());
2011-02-21 22:06:55 -05:00
$db->create_table("config", "
name VARCHAR(128) NOT NULL,
value TEXT,
PRIMARY KEY (name)
2011-02-21 22:06:55 -05:00
");
$db->create_table("users", "
id SCORE_AIPK,
2009-01-22 05:42:44 -08:00
name VARCHAR(32) UNIQUE NOT NULL,
pass CHAR(32),
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',
email VARCHAR(128)
2011-02-21 22:06:55 -05:00
");
$db->execute("CREATE INDEX users_name_idx ON users(name)", array());
2011-02-21 22:06:55 -05:00
$db->create_table("images", "
2009-01-22 04:05:55 -08:00
id SCORE_AIPK,
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,
FOREIGN KEY (owner_id) REFERENCES users(id) ON DELETE RESTRICT
2011-02-21 22:06:55 -05:00
");
$db->execute("CREATE INDEX images_owner_id_idx ON images(owner_id)", array());
$db->execute("CREATE INDEX images_width_idx ON images(width)", array());
$db->execute("CREATE INDEX images_height_idx ON images(height)", array());
$db->execute("CREATE INDEX images_hash_idx ON images(hash)", array());
2011-02-21 22:06:55 -05: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
");
$db->execute("CREATE INDEX tags_tag_idx ON tags(tag)", array());
2011-02-21 22:06:55 -05:00
$db->create_table("image_tags", "
image_id INTEGER NOT NULL,
tag_id INTEGER NOT NULL,
2009-01-22 05:42:44 -08:00
UNIQUE(image_id, tag_id),
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
");
$db->execute("CREATE INDEX images_tags_image_id_idx ON image_tags(image_id)", array());
$db->execute("CREATE INDEX images_tags_tag_id_idx ON image_tags(tag_id)", array());
2012-02-22 13:58:55 +00:00
$db->execute("INSERT INTO config(name, value) VALUES('db_version', 11)");
2012-06-27 00:08:51 +01:00
$db->commit();
}
catch(PDOException $e)
{
print <<<EOD
<div id="installer">
<h1>Shimmie Installer</h1>
<h3>Database Error:</h3>
<p>An error occured while trying to create the database tables necessary for Shimmie.</p>
<p>Please check and ensure that the database configuration options are all correct.</p>
<br/><br/>
</div>
EOD;
exit($e->getMessage());
}
catch (Exception $e)
{
print <<<EOD
<div id="installer">
<h1>Shimmie Installer</h1>
<h3>Unknown Error:</h3>
<p>An unknown error occured while trying to create the database tables necessary for Shimmie.</p>
<p>Please check the server log files for more information.</p>
<br/><br/>
</div>
EOD;
2011-02-21 22:06:55 -05:00
exit($e->getMessage());
}
2014-02-22 15:36:52 -05:00
2011-02-21 22:06:55 -05:00
} // }}}
2011-02-21 22:06:55 -05:00
function insert_defaults() { // {{{
try {
$db = new Database();
2014-02-22 15:36:52 -05:00
2012-02-21 18:37:36 +00:00
$db->execute("INSERT INTO users(name, pass, joindate, class) VALUES(:name, :pass, now(), :class)", Array("name" => 'Anonymous', "pass" => null, "class" => 'anonymous'));
$db->execute("INSERT INTO config(name, value) VALUES(:name, :value)", Array("name" => 'anon_id', "value" => $db->get_last_insert_id('users_id_seq')));
if(check_im_version() > 0) {
2011-02-21 22:06:55 -05:00
$db->execute("INSERT INTO config(name, value) VALUES(:name, :value)", Array("name" => 'thumb_engine', "value" => 'convert'));
}
2012-06-27 00:08:51 +01:00
$db->commit();
2011-02-21 22:06:55 -05:00
}
catch(PDOException $e)
{
print <<<EOD
<div id="installer">
<h1>Shimmie Installer</h1>
<h3>Database Error:</h3>
<p>An error occured while trying to insert data into the database.</p>
<p>Please check and ensure that the database configuration options are all correct.</p>
<br/><br/>
</div>
EOD;
exit($e->getMessage());
}
catch (Exception $e)
{
print <<<EOD
<div id="installer">
<h1>Shimmie Installer</h1>
<h3>Unknown Error:</h3>
<p>An unknown error occured while trying to insert data into the database.</p>
<p>Please check the server log files for more information.</p>
<br/><br/>
</div>
EOD;
2011-02-21 22:06:55 -05:00
exit($e->getMessage());
}
} // }}}
function build_dirs() { // {{{
2010-03-15 04:31:28 +00:00
// *try* and make default dirs. Ignore any errors --
// if something is amiss, we'll tell the user later
if(!file_exists("images")) @mkdir("images");
if(!file_exists("thumbs")) @mkdir("thumbs");
if(!file_exists("data") ) @mkdir("data");
if(!is_writable("images")) @chmod("images", 0755);
if(!is_writable("thumbs")) @chmod("thumbs", 0755);
if(!is_writable("data") ) @chmod("data", 0755);
// Clear file status cache before checking again.
clearstatcache();
2014-02-22 15:36:52 -05:00
if(
2012-03-09 22:27:12 +00:00
!file_exists("images") || !file_exists("thumbs") || !file_exists("data") ||
!is_writable("images") || !is_writable("thumbs") || !is_writable("data")
) {
2012-03-09 22:27:12 +00:00
print "
<div id='installer'>
<h1>Shimmie Installer</h1>
<h3>Directory Permissions Error:</h3>
<p>Shimmie needs to make three folders in it's directory, '<i>images</i>', '<i>thumbs</i>', and '<i>data</i>', and they need to be writable by the PHP user.</p>
<p>If you see this error, if probably means the folders are owned by you, and they need to be writable by the web server.</p>
2012-03-09 22:27:12 +00:00
<p>PHP reports that it is currently running as user: ".$_ENV["USER"]." (". $_SERVER["USER"] .")</p>
<p>Once you have created these folders and / or changed the ownership of the shimmie folder, hit 'refresh' to continue.</p>
<br/><br/>
</div>
2012-03-09 22:27:12 +00:00
";
exit;
}
} // }}}
2011-02-21 22:06:55 -05:00
function write_config() { // {{{
$file_content = '<' . '?php' . "\n" .
2012-02-13 21:09:34 +00:00
"define('DATABASE_DSN', '".DATABASE_DSN."');\n" .
'?' . '>';
2014-02-22 15:36:52 -05:00
2012-03-30 18:03:55 +01:00
if(!file_exists("data/config")) {
mkdir("data/config", 0755, true);
}
2014-02-22 15:36:52 -05:00
if(!file_put_contents("data/config/shimmie.conf.php", $file_content, LOCK_EX)) {
2014-02-18 23:26:42 -05:00
$h_file_content = htmlentities($file_content);
print <<<EOD
<div id="installer">
<h1>Shimmie Installer</h1>
<h3>File Permissions Error:</h3>
2012-03-09 22:27:12 +00:00
The web server isn't allowed to write to the config file; please copy
2012-03-30 18:03:55 +01:00
the text below, save it as 'data/config/shimmie.conf.php', and upload it into the shimmie
2012-03-09 22:27:12 +00:00
folder manually. Make sure that when you save it, there is no whitespace
before the "&lt;?php" or after the "?&gt;"
2012-03-09 22:27:12 +00:00
<p><textarea cols="80" rows="2">$file_content</textarea>
2014-02-22 15:36:52 -05:00
<p>Once done, <a href="index.php">Click here to Continue</a>.
<br/><br/>
</div>
EOD;
exit;
}
} // }}}
?>
</body>
</html>