2010-10-24 03:12:37 +04:00
|
|
|
<?php
|
|
|
|
|
2016-09-14 04:16:46 +03:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
function getCmdOpt($aArg, $aSpec, &$aResult, $bExitOnError = false, $bExitOnUnknown = false)
|
|
|
|
{
|
|
|
|
$aQuick = array();
|
|
|
|
$aCounts = array();
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-08 04:16:22 +03:00
|
|
|
foreach ($aSpec as $aLine) {
|
|
|
|
if (is_array($aLine)) {
|
2016-09-04 04:19:48 +03:00
|
|
|
if ($aLine[0]) $aQuick['--'.$aLine[0]] = $aLine;
|
|
|
|
if ($aLine[1]) $aQuick['-'.$aLine[1]] = $aLine;
|
|
|
|
$aCounts[$aLine[0]] = 0;
|
|
|
|
}
|
|
|
|
}
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
$aResult = array();
|
|
|
|
$bUnknown = false;
|
2018-03-22 14:36:24 +03:00
|
|
|
$iSize = count($aArg);
|
2016-09-08 04:16:22 +03:00
|
|
|
for ($i = 1; $i < $iSize; $i++) {
|
|
|
|
if (isset($aQuick[$aArg[$i]])) {
|
2016-09-04 04:19:48 +03:00
|
|
|
$aLine = $aQuick[$aArg[$i]];
|
|
|
|
$aCounts[$aLine[0]]++;
|
|
|
|
$xVal = null;
|
2016-09-08 04:16:22 +03:00
|
|
|
if ($aLine[4] == $aLine[5]) {
|
|
|
|
if ($aLine[4]) {
|
2016-09-04 04:19:48 +03:00
|
|
|
$xVal = array();
|
2016-09-08 04:16:22 +03:00
|
|
|
for ($n = $aLine[4]; $i < $iSize && $n; $n--) {
|
2016-09-04 04:19:48 +03:00
|
|
|
$i++;
|
|
|
|
if ($i >= $iSize || $aArg[$i][0] == '-') showUsage($aSpec, $bExitOnError, 'Parameter of \''.$aLine[0].'\' is missing');
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-08 04:16:22 +03:00
|
|
|
switch ($aLine[6]) {
|
|
|
|
case 'realpath':
|
|
|
|
$xVal[] = realpath($aArg[$i]);
|
|
|
|
break;
|
|
|
|
case 'realdir':
|
|
|
|
$sPath = realpath(dirname($aArg[$i]));
|
|
|
|
if ($sPath) {
|
|
|
|
$xVal[] = $sPath . '/' . basename($aArg[$i]);
|
|
|
|
} else {
|
|
|
|
$xVal[] = $sPath;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'bool':
|
|
|
|
$xVal[] = (bool)$aArg[$i];
|
|
|
|
break;
|
|
|
|
case 'int':
|
|
|
|
$xVal[] = (int)$aArg[$i];
|
|
|
|
break;
|
|
|
|
case 'float':
|
|
|
|
$xVal[] = (float)$aArg[$i];
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$xVal[] = $aArg[$i];
|
|
|
|
break;
|
2016-09-04 04:19:48 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($aLine[4] == 1) $xVal = $xVal[0];
|
2016-09-08 04:16:22 +03:00
|
|
|
} else {
|
2016-09-04 04:19:48 +03:00
|
|
|
$xVal = true;
|
|
|
|
}
|
2016-09-08 04:16:22 +03:00
|
|
|
} else {
|
2016-09-04 04:19:48 +03:00
|
|
|
fail('Variable numbers of params not yet supported');
|
|
|
|
}
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-08 04:16:22 +03:00
|
|
|
if ($aLine[3] > 1) {
|
2016-09-04 04:19:48 +03:00
|
|
|
if (!array_key_exists($aLine[0], $aResult)) $aResult[$aLine[0]] = array();
|
|
|
|
$aResult[$aLine[0]][] = $xVal;
|
2016-09-08 04:16:22 +03:00
|
|
|
} else {
|
2016-09-04 04:19:48 +03:00
|
|
|
$aResult[$aLine[0]] = $xVal;
|
|
|
|
}
|
2016-09-08 04:16:22 +03:00
|
|
|
} else {
|
2016-09-04 04:19:48 +03:00
|
|
|
$bUnknown = $aArg[$i];
|
|
|
|
}
|
|
|
|
}
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
if (array_key_exists('help', $aResult)) showUsage($aSpec);
|
|
|
|
if ($bUnknown && $bExitOnUnknown) showUsage($aSpec, $bExitOnError, 'Unknown option \''.$bUnknown.'\'');
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-08 04:16:22 +03:00
|
|
|
foreach ($aSpec as $aLine) {
|
|
|
|
if (is_array($aLine)) {
|
2016-09-04 04:19:48 +03:00
|
|
|
if ($aCounts[$aLine[0]] < $aLine[2]) showUsage($aSpec, $bExitOnError, 'Option \''.$aLine[0].'\' is missing');
|
|
|
|
if ($aCounts[$aLine[0]] > $aLine[3]) showUsage($aSpec, $bExitOnError, 'Option \''.$aLine[0].'\' is pressent too many times');
|
2016-09-08 04:16:22 +03:00
|
|
|
switch ($aLine[6]) {
|
|
|
|
case 'bool':
|
|
|
|
if (!array_key_exists($aLine[0], $aResult))
|
|
|
|
$aResult[$aLine[0]] = false;
|
|
|
|
break;
|
2016-09-04 04:19:48 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $bUnknown;
|
|
|
|
}
|
2010-10-24 03:12:37 +04:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
function showUsage($aSpec, $bExit = false, $sError = false)
|
|
|
|
{
|
2016-09-08 04:16:22 +03:00
|
|
|
if ($sError) {
|
2016-09-04 04:19:48 +03:00
|
|
|
echo basename($_SERVER['argv'][0]).': '.$sError."\n";
|
|
|
|
echo 'Try `'.basename($_SERVER['argv'][0]).' --help` for more information.'."\n";
|
|
|
|
exit;
|
|
|
|
}
|
2017-10-26 22:21:21 +03:00
|
|
|
echo 'Usage: '.basename($_SERVER['argv'][0])."\n";
|
2016-09-04 04:19:48 +03:00
|
|
|
$bFirst = true;
|
2016-09-08 04:16:22 +03:00
|
|
|
foreach ($aSpec as $aLine) {
|
|
|
|
if (is_array($aLine)) {
|
|
|
|
if ($bFirst) {
|
2016-09-04 04:19:48 +03:00
|
|
|
$bFirst = false;
|
|
|
|
echo "\n";
|
|
|
|
}
|
|
|
|
$aNames = array();
|
|
|
|
if ($aLine[1]) $aNames[] = '-'.$aLine[1];
|
|
|
|
if ($aLine[0]) $aNames[] = '--'.$aLine[0];
|
2016-09-11 06:22:51 +03:00
|
|
|
$sName = join(', ', $aNames);
|
|
|
|
echo ' '.$sName.str_repeat(' ', 30-strlen($sName)).$aLine[7]."\n";
|
2016-09-08 04:16:22 +03:00
|
|
|
} else {
|
2016-09-04 04:19:48 +03:00
|
|
|
echo $aLine."\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
exit;
|
|
|
|
}
|
2016-06-09 01:24:18 +03:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
function chksql($oSql, $sMsg = false)
|
|
|
|
{
|
2016-09-08 04:16:22 +03:00
|
|
|
if (PEAR::isError($oSql)) {
|
2016-09-04 04:19:48 +03:00
|
|
|
fail($sMsg || $oSql->getMessage(), $oSql->userinfo);
|
|
|
|
}
|
2016-06-09 01:24:18 +03:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
return $oSql;
|
|
|
|
}
|
2017-09-17 12:06:52 +03:00
|
|
|
|
|
|
|
function info($sMsg)
|
|
|
|
{
|
|
|
|
echo date('Y-m-d H:i:s == ').$sMsg."\n";
|
|
|
|
}
|
|
|
|
|
2018-04-13 14:18:29 +03:00
|
|
|
$aWarnings = array();
|
2017-09-17 12:06:52 +03:00
|
|
|
|
2017-10-03 11:16:17 +03:00
|
|
|
|
2017-09-17 12:06:52 +03:00
|
|
|
function warn($sMsg)
|
|
|
|
{
|
|
|
|
$GLOBALS['aWarnings'][] = $sMsg;
|
|
|
|
echo date('Y-m-d H:i:s == ').'WARNING: '.$sMsg."\n";
|
|
|
|
}
|
|
|
|
|
2017-10-03 11:16:17 +03:00
|
|
|
|
2017-09-17 12:06:52 +03:00
|
|
|
function repeatWarnings()
|
|
|
|
{
|
|
|
|
foreach ($GLOBALS['aWarnings'] as $sMsg) {
|
|
|
|
echo ' * ',$sMsg."\n";
|
|
|
|
}
|
|
|
|
}
|
2017-10-03 11:16:17 +03:00
|
|
|
|
|
|
|
|
|
|
|
function runSQLScript($sScript, $bfatal = true, $bVerbose = false, $bIgnoreErrors = false)
|
|
|
|
{
|
|
|
|
// Convert database DSN to psql parameters
|
|
|
|
$aDSNInfo = DB::parseDSN(CONST_Database_DSN);
|
|
|
|
if (!isset($aDSNInfo['port']) || !$aDSNInfo['port']) $aDSNInfo['port'] = 5432;
|
|
|
|
$sCMD = 'psql -p '.$aDSNInfo['port'].' -d '.$aDSNInfo['database'];
|
2018-07-18 02:18:33 +03:00
|
|
|
if (isset($aDSNInfo['hostspec']) && $aDSNInfo['hostspec']) {
|
|
|
|
$sCMD .= ' -h ' . $aDSNInfo['hostspec'];
|
|
|
|
}
|
|
|
|
if (isset($aDSNInfo['username']) && $aDSNInfo['username']) {
|
|
|
|
$sCMD .= ' -U ' . $aDSNInfo['username'];
|
|
|
|
}
|
|
|
|
$procenv = null;
|
|
|
|
if (isset($aDSNInfo['password']) && $aDSNInfo['password']) {
|
|
|
|
$procenv = array_merge(array('PGPASSWORD' => $aDSNInfo['password']), $_ENV);
|
|
|
|
}
|
2017-10-03 11:16:17 +03:00
|
|
|
if (!$bVerbose) {
|
|
|
|
$sCMD .= ' -q';
|
|
|
|
}
|
|
|
|
if ($bfatal && !$bIgnoreErrors) {
|
|
|
|
$sCMD .= ' -v ON_ERROR_STOP=1';
|
|
|
|
}
|
|
|
|
$aDescriptors = array(
|
|
|
|
0 => array('pipe', 'r'),
|
|
|
|
1 => STDOUT,
|
|
|
|
2 => STDERR
|
|
|
|
);
|
|
|
|
$ahPipes = null;
|
2018-07-18 02:18:33 +03:00
|
|
|
$hProcess = @proc_open($sCMD, $aDescriptors, $ahPipes, null, $procenv);
|
2017-10-03 11:16:17 +03:00
|
|
|
if (!is_resource($hProcess)) {
|
|
|
|
fail('unable to start pgsql');
|
|
|
|
}
|
|
|
|
|
|
|
|
while (strlen($sScript)) {
|
|
|
|
$written = fwrite($ahPipes[0], $sScript);
|
|
|
|
if ($written <= 0) break;
|
|
|
|
$sScript = substr($sScript, $written);
|
|
|
|
}
|
|
|
|
fclose($ahPipes[0]);
|
|
|
|
$iReturn = proc_close($hProcess);
|
|
|
|
if ($bfatal && $iReturn > 0) {
|
|
|
|
fail("pgsql returned with error code ($iReturn)");
|
|
|
|
}
|
|
|
|
}
|
2018-07-21 06:06:09 +03:00
|
|
|
|
|
|
|
|
|
|
|
function runWithEnv($cmd, $env)
|
|
|
|
{
|
|
|
|
$fds = array(0 => array('pipe', 'r'),
|
|
|
|
1 => STDOUT,
|
|
|
|
2 => STDERR);
|
|
|
|
$pipes = null;
|
|
|
|
$proc = @proc_open($cmd, $fds, $pipes, null, $env);
|
|
|
|
if (!is_resource($proc)) {
|
|
|
|
fail('unable to run command:' . $cmd);
|
|
|
|
}
|
|
|
|
|
|
|
|
fclose($pipes[0]); // no stdin
|
|
|
|
|
|
|
|
$stat = proc_close($proc);
|
|
|
|
return $stat;
|
|
|
|
}
|