librenms/build-base.php

59 lines
1.6 KiB
PHP
Raw Normal View History

#!/usr/bin/env php
<?php
chdir(__DIR__); // cwd to the directory containing this script
2014-01-13 17:43:58 +00:00
// MYSQL Check - FIXME
// 1 UNKNOWN
include 'config.php';
if (!isset($sql_file)) {
2015-07-13 18:10:26 +00:00
$sql_file = 'build.sql';
}
2015-07-13 18:10:26 +00:00
$sql_fh = fopen($sql_file, 'r');
if ($sql_fh === false) {
echo 'ERROR: Cannot open SQL build script '.$sql_file."\n";
exit(1);
}
$database_link = mysqli_connect('p:'.$config['db_host'], $config['db_user'], $config['db_pass']);
2015-08-15 17:37:20 +00:00
if ($database_link === false) {
echo 'ERROR: Cannot connect to database: '.mysqli_error($database_link)."\n";
2015-07-13 18:10:26 +00:00
exit(1);
}
2015-08-15 17:37:20 +00:00
$select = mysqli_select_db($database_link, $config['db_name']);
2015-07-13 18:10:26 +00:00
if ($select === false) {
2015-08-15 17:37:20 +00:00
echo 'ERROR: Cannot select database: '.mysqli_error($database_link)."\n";
2015-07-13 18:10:26 +00:00
exit(1);
}
$limit = 0;
2015-07-13 18:10:26 +00:00
while (!feof($sql_fh)) {
$line = fgetss($sql_fh);
if (isset($_SESSION['stage'])) {
$limit++;
if (isset($_SESSION['offset']) && $limit < $_REQUEST['offset']) {
continue;
} elseif (time()-$_SESSION['last'] > 45) {
$_SESSION['offset'] = $limit;
2015-09-01 23:13:14 +00:00
$GLOBALS['refresh'] = '<b>Installing, please wait..</b><sub>'.date('r').'</sub><script>window.location.href = "install.php?offset='.$limit.'";</script>';
return;
} else {
echo 'Step #'.$limit.' ...'.PHP_EOL;
}
}
2015-07-13 18:10:26 +00:00
if (!empty($line)) {
2015-08-15 17:37:20 +00:00
$creation = mysqli_query($database_link, $line);
2015-09-01 22:38:48 +00:00
if (!$creation) {
2015-08-15 17:37:20 +00:00
echo 'WARNING: Cannot execute query ('.$line.'): '.mysqli_error($database_link)."\n";
2015-07-13 18:10:26 +00:00
}
}
}
fclose($sql_fh);
require 'includes/sql-schema/update.php';