mirror of
https://github.com/ShaYmez/FreeSTAR-Status-Engine.git
synced 2024-11-05 19:01:17 -05:00
188 lines
9.0 KiB
PHP
188 lines
9.0 KiB
PHP
<?php
|
|
require_once("template.php");
|
|
define("WEB_URL", "."); //Website name
|
|
define("NAME", _('Status page')); //Website name
|
|
require_once("classes/locale-negotiator.php");
|
|
|
|
$negotiator = new LocaleNegotiator("en_GB");
|
|
$message = "";
|
|
if (!isset($_SESSION['locale'])||isset($_GET['lang']))
|
|
{
|
|
$override = ((isset($_GET['lang']))?$_GET['lang']:null);
|
|
$best_match = $negotiator->negotiate($override);
|
|
$_SESSION['locale'] = $best_match;
|
|
setlocale(LC_ALL, $_SESSION['locale'].".UTF-8");
|
|
|
|
bindtextdomain("server-status", __DIR__ . "/locale/");
|
|
bind_textdomain_codeset($_SESSION['locale'], "utf-8");
|
|
textdomain("server-status");
|
|
}
|
|
|
|
if (isset($_POST['server']))
|
|
{
|
|
$mysqli = new mysqli($_POST['server'],$_POST['dbuser'],$_POST['dbpassword'],$_POST['database']);
|
|
|
|
if ($mysqli->connect_errno) {
|
|
$message .= sprintf(_("Connection failed: %s\n"), $mysqli->connect_error);
|
|
}
|
|
|
|
if (isset($_POST['url']) && filter_var($_POST['url'], FILTER_VALIDATE_URL) === false)
|
|
{
|
|
$message .= _("Please set valid url!");
|
|
}
|
|
|
|
//Ostatní má checky existence ve funkci pro pridani
|
|
if (0 == strlen(trim($_POST['servername']))){
|
|
$messages[] = _("Server name");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['url']))){
|
|
$messages[] = _("Url");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['mailer']))){
|
|
$messages[] = _("Mailer name");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['mailer_email']))){
|
|
$messages[] = _("Mailer email");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['server']))){
|
|
$messages[] = _("Database server");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['database']))){
|
|
$messages[] = _("Database name");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['dbuser']))){
|
|
$messages[] = _("Database user");
|
|
}
|
|
|
|
if (0 == strlen(trim($_POST['dbpassword'])))
|
|
{
|
|
$messages[] = _("Database password");
|
|
}
|
|
if (isset($messages))
|
|
{
|
|
$message .= _("Please set");
|
|
$message .= implode(", ", $messages);
|
|
}
|
|
}
|
|
|
|
if(isset($_POST['server']) && empty($message))
|
|
{
|
|
define("MAILER_NAME", $_POST['mailer']);
|
|
define("MAILER_ADDRESS", $_POST['mailer_email']);
|
|
define("INSTALL_OVERRIDE", true);
|
|
|
|
//No need to include config, as we have connection from testing it... :)
|
|
//There may be better way to do this...
|
|
$sql = file_get_contents("install.sql");
|
|
$array = explode(";", $sql);
|
|
|
|
foreach ($array as $value) {
|
|
$val = trim($value);
|
|
if (empty($val))
|
|
{
|
|
continue;
|
|
}
|
|
$q_res = $mysqli->query($value);
|
|
if ($q_res === false)
|
|
{
|
|
$message = sprintf(_("Error while creating database. Please check permission for your account or MYSQL version.<br>Error: %s"), $mysqli->error);
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (empty($message))
|
|
{
|
|
require_once("classes/constellation.php");
|
|
|
|
User::add();
|
|
}
|
|
|
|
if (empty($message))
|
|
{
|
|
//Create config
|
|
$config = file_get_contents("config.php.template");
|
|
$config = str_replace("##name##", $_POST['servername'], $config);
|
|
$config = str_replace("##url##", $_POST['url'], $config);
|
|
$config = str_replace("##mailer##", $_POST['mailer'], $config);
|
|
$config = str_replace("##mailer_email##", $_POST['mailer_email'], $config);
|
|
$config = str_replace("##server##", $_POST['server'], $config);
|
|
$config = str_replace("##database##", $_POST['database'], $config);
|
|
$config = str_replace("##user##", $_POST['dbuser'], $config);
|
|
$config = str_replace("##password##", $_POST['dbpassword'], $config);
|
|
$config = str_replace("##name##", $_POST['servername'], $config);
|
|
file_put_contents("config.php", $config);
|
|
|
|
unlink("config.php.template");
|
|
unlink("install.sql");
|
|
unlink(__FILE__);
|
|
|
|
header("Location: ".WEB_URL);
|
|
}
|
|
}
|
|
Template::render_header(_("Install"));
|
|
?>
|
|
<h1 class="text-center"><?php echo _("Installation");?></h1>
|
|
<?php
|
|
if (!empty($message))
|
|
{
|
|
?>
|
|
<p class="alert alert-danger"><?php echo $message; ?></p>
|
|
<?php
|
|
}
|
|
?>
|
|
<form method="post" action="." class="clearfix install">
|
|
<section class="install-section clearfix">
|
|
<h2><?php echo _("Website details");?></h2>
|
|
<summary><?php echo _("We need a name for your status page and a url, so we can mail users link for forgotten password etc.");?></summary>
|
|
|
|
<div class="form-group clearfix">
|
|
<div class="col-sm-6"><label for="servername"><?php echo _("Name");?>: </label><input type="text" name="servername" value="<?php echo ((isset($_POST['servername']))?htmlspecialchars($_POST['servername'], ENT_QUOTES):'');?>" id="servername" placeholder="<?php echo _("Name");?>" class="form-control" required></div>
|
|
<div class="col-sm-6"><label for="url"><?php echo _("Url");?>: </label><input type="url" name="url" value="<?php echo ((isset($_POST['url']))?htmlspecialchars($_POST['url'], ENT_QUOTES):'');?>" id="url" placeholder="<?php echo _("Url");?>" class="form-control" required></div>
|
|
</div>
|
|
<summary><?php echo _("Also an email address for mailer would be nice :)");?></summary>
|
|
<div class="form-group clearfix">
|
|
<div class="col-sm-6"><label for="mailer"><?php echo _("Name");?>: </label><input type="text" name="mailer" value="<?php echo ((isset($_POST['mailer']))?htmlspecialchars($_POST['mailer'], ENT_QUOTES):'');?>" id="mailer" placeholder="<?php echo _("Name");?>" class="form-control" required></div>
|
|
<div class="col-sm-6"><label for="mailer_email"><?php echo _("Email");?>: </label><input type="email" name="mailer_email" value="<?php echo ((isset($_POST['mailer_email']))?htmlspecialchars($_POST['mailer_email'], ENT_QUOTES):'');?>" id="mailer_email" placeholder="<?php echo _("Email");?>" class="form-control" required></div>
|
|
</div>
|
|
</section>
|
|
<section class="install-section clearfix">
|
|
<h2><?php echo _("Database connection");?></h2>
|
|
<summary><?php echo _("We need database connection to be able to create tables. Please check that your account has the permission needed to do that.");?></summary>
|
|
|
|
<div class="form-group clearfix">
|
|
<div class="col-sm-6"><label for="server"><?php echo _("Server");?>: </label><input type="text" name="server" value="<?php echo ((isset($_POST['server']))?htmlspecialchars($_POST['server'], ENT_QUOTES):'');?>" id="server" placeholder="<?php echo _("Server");?>" class="form-control" required></div>
|
|
<div class="col-sm-6"><label for="database"><?php echo _("Database");?>: </label><input type="text" name="database" value="<?php echo ((isset($_POST['database']))?htmlspecialchars($_POST['database'], ENT_QUOTES):'');?>" id="database" placeholder="<?php echo _("Database");?>" class="form-control" required></div>
|
|
</div>
|
|
<div class="form-group clearfix">
|
|
<div class="col-sm-6"><label for="dbuser"><?php echo _("User");?>: </label><input type="text" name="dbuser" value="<?php echo ((isset($_POST['dbuser']))?htmlspecialchars($_POST['dbuser'], ENT_QUOTES):'');?>" id="dbuser" placeholder="<?php echo _("User");?>" class="form-control" required></div>
|
|
<div class="col-sm-6"><label for="dbpassword"><?php echo _("Password");?>: </label><input type="password" name="dbpassword" value="<?php echo ((isset($_POST['dbpassword']))?htmlspecialchars($_POST['dbpassword'], ENT_QUOTES):'');?>" id="dbpassword" placeholder="<?php echo _("Password");?>" class="form-control" required></div>
|
|
</div>
|
|
</section>
|
|
<section class="install-section clearfix">
|
|
<h2><?php echo _("User");?></h2>
|
|
<summary><?php echo _("And finally, we need info to create a new user. You don't have to provide it, but then... No status page admin...");?></summary>
|
|
<div class="form-group">
|
|
<div class="col-sm-6"><label for="name"><?php echo _("Name");?>: </label><input type="text" maxlength="50" name="name" value="<?php echo ((isset($_POST['name']))?htmlspecialchars($_POST['name'], ENT_QUOTES):'');?>" id="name" placeholder="<?php echo _("Name");?>" class="form-control" required></div>
|
|
<div class="col-sm-6"><label for="surname"><?php echo _("Surname");?>: </label><input type="text" maxlength="50" name="surname" value="<?php echo ((isset($_POST['surname']))?htmlspecialchars($_POST['surname'], ENT_QUOTES):'');?>" id="surname" placeholder="<?php echo _("Surname");?>" class="form-control" required></div>
|
|
</div>
|
|
<div class="form-group">
|
|
<div class="col-sm-6"><label for="username"><?php echo _("Username");?>:</label><input type="text" maxlength="50" name="username" value="<?php echo ((isset($_POST['username']))?htmlspecialchars($_POST['username'], ENT_QUOTES):'');?>" id="username" placeholder="<?php echo _("Username");?>" class="form-control" required></div>
|
|
<div class="col-sm-6"><label for="email"><?php echo _("Email");?>:</label><input type="email" maxlength="60" name="email" value="<?php echo ((isset($_POST['email']))?htmlspecialchars($_POST['email'], ENT_QUOTES):'');?>" id="email" placeholder="<?php echo _("Email");?>" class="form-control" required><input type="hidden" name="permission" value="0"></div>
|
|
</div>
|
|
<div class="form-group">
|
|
<div class="col-sm-6"><label for="password"><?php echo _("Password");?>:</label><input type="password" name="password" value="<?php echo ((isset($_POST['password']))?htmlspecialchars($_POST['password'], ENT_QUOTES):'');?>" id="password" placeholder="<?php echo _("Password");?>" class="form-control" required></div>
|
|
<div class="col-sm-6">
|
|
<input type="hidden" value="0" name="permission">
|
|
<button type="submit" class="btn btn-success pull-right"><?php echo _("Run install!");?></button>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
</form>
|
|
<?php
|
|
Template::render_footer();
|