2 changed files with 348 additions and 1 deletions
@ -0,0 +1,347 @@ |
|||
<?php |
|||
|
|||
// install.php |
|||
// Basic installer written by Alpha. |
|||
|
|||
// TODO: |
|||
// * The installer should create the database |
|||
// * Error checking |
|||
// * General cleanup |
|||
// * Skin |
|||
|
|||
// Debug |
|||
error_reporting(E_ALL); |
|||
ini_set("display_errors", 1); |
|||
|
|||
function htmlclean ($string) { |
|||
return htmlentities($string,ENT_QUOTES); |
|||
} |
|||
|
|||
if (file_exists('inc/instance-config.php')) { |
|||
echo "<h1>Error:</h1>"; |
|||
echo "<p>inc/instance-config.php already exists. Please delete it before trying to re-install.</p>"; |
|||
die(); |
|||
} |
|||
|
|||
$default_values = array( |
|||
// Database stuff |
|||
array( |
|||
'output' => "<h2>Database settings</h2>\n". |
|||
"<p>Please change the following to reflect the setup of your database.</p>" |
|||
), |
|||
array( |
|||
'name' => 'DB_TYPE', |
|||
'html' => 'dropdown', |
|||
'values' => array('mysql'=>'MySQL'), |
|||
'comment' => 'Database engine:' |
|||
), |
|||
array( |
|||
'name' => 'DB_SERVER', |
|||
'html' => 'text', |
|||
'values' => 'localhost', |
|||
'comment' => 'Database hostname:' |
|||
), |
|||
array( |
|||
'name' => 'DB_USER', |
|||
'html' => 'text', |
|||
'values' => 'root', |
|||
'comment' => 'Database username:' |
|||
), |
|||
array( |
|||
'name' => 'DB_PASSWORD', |
|||
'html' => 'password', |
|||
'values' => '', |
|||
'comment' => 'Database password:' |
|||
), |
|||
array( |
|||
'name' => 'DB_DATABASE', |
|||
'html' => 'text', |
|||
'values' => 'tinyboard', |
|||
'comment' => 'Database name (please create this database beforehand):' |
|||
), |
|||
|
|||
// General Config |
|||
array( |
|||
'output' => "<h2>General Config</h2>\n". |
|||
"<p>General board configuration.</p>" |
|||
), |
|||
array( |
|||
'name' => 'LURKTIME', |
|||
'html' => 'text', |
|||
'values' => '30', |
|||
'comment' => 'How many seconds before you can post, after the first visit:' |
|||
), |
|||
array( |
|||
'name' => 'MAX_BODY', |
|||
'html' => 'text', |
|||
'values' => '1800', |
|||
'comment' => 'Max body length:' |
|||
), |
|||
array( |
|||
'name' => 'THREADS_PER_PAGE', |
|||
'html' => 'text', |
|||
'values' => '10', |
|||
'comment' => 'Threads per page:' |
|||
), |
|||
array( |
|||
'name' => 'MAX_PAGES', |
|||
'html' => 'text', |
|||
'values' => '5', |
|||
'comment' => 'Max pages:' |
|||
), |
|||
array( |
|||
'name' => 'THREADS_PREVIEW', |
|||
'html' => 'text', |
|||
'values' => '5', |
|||
'comment' => 'Threads Preview:' |
|||
), |
|||
array( |
|||
'name' => 'VERBOSE_ERRORS', |
|||
'html' => 'bool', |
|||
'values' => true, |
|||
'comment' => 'Turns \'display_errors\' on. Not recommended for production.:' |
|||
), |
|||
|
|||
// Image Config |
|||
array( |
|||
'output' => "<h2>Image Config</h2>\n". |
|||
"<p>Image configuration.</p>" |
|||
), |
|||
array( |
|||
'name' => 'THUMB_WIDTH', |
|||
'html' => 'text', |
|||
'values' => '200', |
|||
'comment' => 'Maximum thumbnail width:' |
|||
), |
|||
array( |
|||
'name' => 'THUMB_HEIGHT', |
|||
'html' => 'text', |
|||
'values' => '200', |
|||
'comment' => 'Maximum thumbnail height:' |
|||
), |
|||
array( |
|||
'name' => 'MAX_FILESIZE', |
|||
'html' => 'text', |
|||
'values' => '10485760', |
|||
'comment' => 'Maximum file size (in bytes; default: 10MB):' |
|||
), |
|||
array( |
|||
'name' => 'MAX_WIDTH', |
|||
'html' => 'text', |
|||
'values' => '10000', |
|||
'comment' => 'Maximum image width:' |
|||
), |
|||
array( |
|||
'name' => 'MAX_HEIGHT', |
|||
'html' => 'text', |
|||
'values' => '10000', |
|||
'comment' => 'Maximum image height:' |
|||
), |
|||
array( |
|||
'name' => 'ALLOW_ZIP', |
|||
'html' => 'bool', |
|||
'values' => false, |
|||
'comment' => 'When you upload a ZIP as a file, all the images inside the archive '. |
|||
'get dumped into the thread as replies. (Extremely beta and not recommended yet.)' |
|||
), |
|||
array( |
|||
'name' => 'REDRAW_IMAGE', |
|||
'html' => 'bool', |
|||
'values' => false, |
|||
'comment' => 'Redraw the image using GD functions to strip any excess data (WARNING: VERY BETA).' |
|||
), |
|||
array( |
|||
'name' => 'SHOW_RATIO', |
|||
'html' => 'bool', |
|||
'values' => true, |
|||
'comment' => 'Display the aspect ratio in a post\'s file info.' |
|||
), |
|||
|
|||
// Cookies |
|||
array( |
|||
'output' => "<h2>Cookies</h2>\n". |
|||
"<p>The following deals with cookie setup. ". |
|||
"You probably don't need to change it.</p>" |
|||
), |
|||
array( |
|||
'name' => 'SESS_COOKIE', |
|||
'html' => 'text', |
|||
'values' => 'imgboard', |
|||
'comment' => 'Name of the session cookie:' |
|||
), |
|||
array( |
|||
'name' => 'TIME_COOKIE', |
|||
'html' => 'text', |
|||
'values' => 'arrived', |
|||
'comment' => 'Name of the time cookie:' |
|||
), |
|||
array( |
|||
'name' => 'HASH_COOKIE', |
|||
'html' => 'text', |
|||
'values' => 'hash', |
|||
'comment' => 'Name of the hash cookie:' |
|||
), |
|||
array( |
|||
'name' => 'MOD_COOKIE', |
|||
'html' => 'text', |
|||
'values' => 'mod', |
|||
'comment' => 'Name of the moderator cookie:' |
|||
), |
|||
array( |
|||
'name' => 'JAIL_COOKIES', |
|||
'html' => 'text', |
|||
'values' => 'true', |
|||
'comment' => 'Where to set the \'path\' parameter to ROOT when creating cookies. Recommended.:' |
|||
), |
|||
array( |
|||
'name' => 'COOKIE_EXPIRE', |
|||
'html' => 'text', |
|||
'values' => '15778463', |
|||
'comment' => 'How long should the cookies last (in seconds; default 6 months):' |
|||
), |
|||
array( |
|||
'name' => 'SALT', |
|||
'html' => 'text', |
|||
'values' => md5(rand(0,100)), |
|||
'comment' => 'Make this something long and random for security:' |
|||
), |
|||
|
|||
); |
|||
|
|||
$sql = array( |
|||
'SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";', |
|||
'CREATE TABLE IF NOT EXISTS `boards` ( |
|||
`id` smallint(6) NOT NULL AUTO_INCREMENT, |
|||
`uri` varchar(8) NOT NULL, |
|||
`title` varchar(20) NOT NULL, |
|||
`subtitle` varchar(40) DEFAULT NULL, |
|||
PRIMARY KEY (`id`), |
|||
UNIQUE KEY `uri` (`uri`), |
|||
UNIQUE KEY `id` (`id`) |
|||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ;', |
|||
'INSERT INTO `boards` (`id`, `uri`, `title`, `subtitle`) VALUES |
|||
(1, \'b\', \'Beta\', \'In development.\');', |
|||
'CREATE TABLE IF NOT EXISTS `posts_b` ( |
|||
`id` int(11) NOT NULL AUTO_INCREMENT, |
|||
`thread` int(11) DEFAULT NULL, |
|||
`subject` varchar(40) NOT NULL, |
|||
`email` varchar(30) NOT NULL, |
|||
`name` varchar(25) NOT NULL, |
|||
`trip` varchar(15) DEFAULT NULL, |
|||
`body` text NOT NULL, |
|||
`time` int(11) NOT NULL, |
|||
`bump` int(11) DEFAULT NULL, |
|||
`thumb` varchar(50) DEFAULT NULL, |
|||
`thumbwidth` int(11) DEFAULT NULL, |
|||
`thumbheight` int(11) DEFAULT NULL, |
|||
`file` varchar(50) DEFAULT NULL, |
|||
`filewidth` int(11) DEFAULT NULL, |
|||
`fileheight` int(11) DEFAULT NULL, |
|||
`filesize` int(11) DEFAULT NULL, |
|||
`filename` varchar(30) DEFAULT NULL, |
|||
`filehash` varchar(32) DEFAULT NULL, |
|||
`password` varchar(20) DEFAULT NULL, |
|||
`ip` varchar(15) NOT NULL, |
|||
`sticky` int(1) NOT NULL, |
|||
UNIQUE KEY `id` (`id`) |
|||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;', |
|||
'CREATE TABLE IF NOT EXISTS `mods` ( |
|||
`id` smallint(6) NOT NULL AUTO_INCREMENT, |
|||
`username` varchar(30) NOT NULL, |
|||
`password` char(40) NOT NULL COMMENT \'SHA1\', |
|||
`type` smallint(1) NOT NULL COMMENT \'0: janitor, 1: mod, 2: admin\', |
|||
PRIMARY KEY (`id`), |
|||
UNIQUE KEY `id` (`id`,`username`) |
|||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ;', |
|||
'INSERT INTO `mods` (`id`, `username`, `password`, `type`) VALUES |
|||
(1, \'admin\', \'5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8\', 2);', |
|||
'CREATE TABLE IF NOT EXISTS `bans` ( |
|||
`ip` varchar( 15 ) NOT NULL , |
|||
`mod` int NOT NULL COMMENT \'which mod made the ban\', |
|||
`set` int NOT NULL, |
|||
`expires` int NULL, |
|||
`reason` text NULL |
|||
) ENGINE = InnoDB;', |
|||
); |
|||
|
|||
if (isset($_POST['submit'])) { |
|||
$date = date('H:i jS F Y (e)'); |
|||
$config_file = "<?php\n// Installer Generated Config File\n// Created at $date\n";
|
|||
foreach ($default_values as $value) { |
|||
if (isset($value['output'])) { |
|||
continue; |
|||
} |
|||
if (isset($_POST[$value['name']])) { |
|||
$x = $_POST[$value['name']]; |
|||
} else { |
|||
if (is_array($value['values'])) { |
|||
$x = $value['values'][0]; |
|||
} else { |
|||
$x = $value['values']; |
|||
} |
|||
} |
|||
if ($value['html'] != 'bool') { |
|||
$x = "'$x'"; |
|||
} |
|||
$config_file .= "define('".$value['name']."',$x,true);\n"; |
|||
} |
|||
file_put_contents('inc/instance-config.php',$config_file); |
|||
|
|||
require 'inc/functions.php'; |
|||
require 'inc/display.php'; |
|||
require 'inc/instance-config.php'; |
|||
require 'inc/config.php'; |
|||
require 'inc/template.php'; |
|||
require 'inc/database.php'; |
|||
|
|||
sql_open(); |
|||
foreach ($sql as $query) { |
|||
query($query); |
|||
} |
|||
|
|||
echo "<h1>Install Complete.</h1>"; |
|||
die(); |
|||
} |
|||
|
|||
echo "<form action=\"install.php\" method=\"POST\">"; |
|||
foreach ($default_values as $value) { |
|||
if (isset($value['output'])) { |
|||
echo $value['output']; |
|||
continue; |
|||
} |
|||
if (isset($value['error'])) { |
|||
echo "<p>Error: ".htmlclean($value['error'])."</p>\n"; |
|||
} |
|||
echo "<p>".$value['comment']." "; |
|||
switch ($value['html']) { |
|||
case 'text': |
|||
echo "<input type=\"text\" id=\"".htmlclean($value['name'])."\" name=\"".htmlclean($value['name'])."\" value=\"".htmlclean($value['values'])."\" />"; |
|||
break; |
|||
case 'password': |
|||
echo "<input type=\"password\" id=\"".htmlclean($value['name'])."\" name=\"".htmlclean($value['name'])."\" value=\"".htmlclean($value['values'])."\" />"; |
|||
break; |
|||
case 'dropdown': |
|||
echo "<select name=\"".htmlclean($value['name'])."\" id=\"".htmlclean($value['name'])."\">\n"; |
|||
foreach ($value['values'] as $option => $human) { |
|||
echo "<option value=\"".htmlclean($option)."\">".htmlclean($human)."</option>"; |
|||
} |
|||
echo "</select>\n"; |
|||
break; |
|||
case 'bool': |
|||
if ($value['values']) { |
|||
echo "<input type=\"radio\" id=\"".htmlclean($value['name'])."\" value=\"true\" name=\"".htmlclean($value['name'])."\" checked />True<br />"; |
|||
echo "<input type=\"radio\" id=\"".htmlclean($value['name'])."\" value=\"false\" name=\"".htmlclean($value['name'])."\" />False<br />"; |
|||
} else { |
|||
echo "<input type=\"radio\" id=\"".htmlclean($value['name'])."\" value=\"true\" name=\"".htmlclean($value['name'])."\" />True<br />"; |
|||
echo "<input type=\"radio\" id=\"".htmlclean($value['name'])."\" value=\"false\" name=\"".htmlclean($value['name'])."\" checked />False<br />"; |
|||
} |
|||
break; |
|||
default: |
|||
die('Internal Error. You have found a bug.'); |
|||
} |
|||
echo "</p>\n"; |
|||
} |
|||
echo "<p><input type=\"submit\" name=\"submit\" value=\"Install\" /></p>\n"; |
|||
echo "</form>"; |
|||
|
|||
?> |
Loading…
Reference in new issue