2017-12-14 11:38:51 -05:00
|
|
|
#!/usr/bin/env php
|
2017-11-19 16:21:54 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @file scripts/dbstructure.php
|
|
|
|
* @brief Does database updates from the command line
|
|
|
|
*/
|
|
|
|
|
|
|
|
require_once 'include/dbstructure.php';
|
|
|
|
|
|
|
|
use Friendica\App;
|
2017-12-01 03:35:05 -05:00
|
|
|
use Friendica\Core\Config;
|
2017-11-19 16:21:54 -05:00
|
|
|
|
|
|
|
$a = new App(dirname(__DIR__));
|
|
|
|
|
|
|
|
@include ".htconfig.php";
|
|
|
|
require_once "include/dba.php";
|
|
|
|
dba::connect($db_host, $db_user, $db_pass, $db_data);
|
|
|
|
unset($db_host, $db_user, $db_pass, $db_data);
|
|
|
|
|
|
|
|
if ($_SERVER["argc"] == 2) {
|
|
|
|
switch ($_SERVER["argv"][1]) {
|
|
|
|
case "dryrun":
|
|
|
|
update_structure(true, false);
|
|
|
|
return;
|
|
|
|
case "update":
|
|
|
|
update_structure(true, true);
|
|
|
|
|
|
|
|
$build = Config::get('system','build');
|
|
|
|
if (!x($build)) {
|
|
|
|
Config::set('system', 'build', DB_UPDATE_VERSION);
|
|
|
|
$build = DB_UPDATE_VERSION;
|
|
|
|
}
|
|
|
|
|
|
|
|
$stored = intval($build);
|
|
|
|
$current = intval(DB_UPDATE_VERSION);
|
|
|
|
|
|
|
|
// run any left update_nnnn functions in update.php
|
|
|
|
for ($x = $stored; $x < $current; $x ++) {
|
|
|
|
$r = run_update_function($x);
|
|
|
|
if (!$r) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Config::set('system','build',DB_UPDATE_VERSION);
|
|
|
|
return;
|
|
|
|
case "dumpsql":
|
|
|
|
print_structure(db_definition());
|
|
|
|
return;
|
|
|
|
case "toinnodb":
|
|
|
|
convert_to_innodb();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// print help
|
|
|
|
echo $_SERVER["argv"][0]." <command>\n";
|
|
|
|
echo "\n";
|
|
|
|
echo "Commands:\n";
|
|
|
|
echo "dryrun show database update schema queries without running them\n";
|
|
|
|
echo "update update database schema\n";
|
|
|
|
echo "dumpsql dump database schema\n";
|
|
|
|
echo "toinnodb convert all tables from MyISAM to InnoDB\n";
|
|
|
|
killme();
|
|
|
|
|