fix extendedgitgraph live output
This commit is contained in:
@@ -2,21 +2,41 @@
|
|||||||
|
|
||||||
global $CONFIG;
|
global $CONFIG;
|
||||||
|
|
||||||
if (session_status() !== PHP_SESSION_ACTIVE) session_start();
|
if ($CONFIG['extendedgitgraph']['output_file'])
|
||||||
|
|
||||||
$svar = $CONFIG['extendedgitgraph']['session_var'];
|
|
||||||
|
|
||||||
if (isset($_GET['clear'])) if (key_exists($svar, $_SESSION)) $_SESSION[$svar] = '';
|
|
||||||
|
|
||||||
if (key_exists($svar, $_SESSION))
|
|
||||||
{
|
{
|
||||||
if ($_SESSION[$svar] === '') echo '[[ NO OUTPUT ]]';
|
$lfile = $CONFIG['extendedgitgraph']['output_filepath'];
|
||||||
else echo $_SESSION[$svar] === '';
|
|
||||||
|
if (file_exists($lfile))
|
||||||
|
{
|
||||||
|
$data = file_get_contents($lfile);
|
||||||
|
|
||||||
|
if ($data === '') echo '[[ EMPTY ]]';
|
||||||
|
else echo $data;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
echo '[[ FILE NOT FOUND ]]';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ($CONFIG['extendedgitgraph']['output_file'])
|
||||||
|
{
|
||||||
|
if (session_status() !== PHP_SESSION_ACTIVE) session_start();
|
||||||
|
|
||||||
|
$svar = $CONFIG['extendedgitgraph']['session_var'];
|
||||||
|
|
||||||
|
if (isset($_GET['clear'])) if (key_exists($svar, $_SESSION)) $_SESSION[$svar] = '';
|
||||||
|
|
||||||
|
if (key_exists($svar, $_SESSION))
|
||||||
|
{
|
||||||
|
if ($_SESSION[$svar] === '') echo '[[ NO OUTPUT ]]';
|
||||||
|
else echo $_SESSION[$svar];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
echo '[[ NO SESSION STARTED ]]';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
echo '[[ NO SESSION STARTED ]]';
|
echo '[[ NO USEFUL LOGGER CONFIGURED ]]';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return;
|
|
@@ -25,3 +25,5 @@ $content = "REQUEST: " . $uri . "\r\n\r\n" .
|
|||||||
"OUTPUT: " . $std . "\r\n\r\n";
|
"OUTPUT: " . $std . "\r\n\r\n";
|
||||||
|
|
||||||
sendMail("Webhook '$hook' triggered", $content, 'virtualadmin@mikescher.de', 'webserver-info@mikescher.com');
|
sendMail("Webhook '$hook' triggered", $content, 'virtualadmin@mikescher.de', 'webserver-info@mikescher.com');
|
||||||
|
|
||||||
|
echo "{ 'status': 'ok', 'message': 'Webhook '$hook' triggered' }";
|
1
www/extern/egg/ExtendedGitGraph2.php
vendored
1
www/extern/egg/ExtendedGitGraph2.php
vendored
@@ -30,6 +30,7 @@ class ExtendedGitGraph2 implements ILogger
|
|||||||
if ($config['output_session']) $this->logger []= new SessionLogger($config['session_var']);
|
if ($config['output_session']) $this->logger []= new SessionLogger($config['session_var']);
|
||||||
if ($config['output_stdout']) $this->logger []= new OutputLogger();
|
if ($config['output_stdout']) $this->logger []= new OutputLogger();
|
||||||
if ($config['output_logfile']) $this->logger []= new FileLogger($config['logfile'], $config['logfile_count']);
|
if ($config['output_logfile']) $this->logger []= new FileLogger($config['logfile'], $config['logfile_count']);
|
||||||
|
if ($config['output_file']) $this->logger []= new SingleFileLogger($config['output_filepath']);
|
||||||
|
|
||||||
$this->sources = [];
|
$this->sources = [];
|
||||||
|
|
||||||
|
22
www/extern/egg/Logger.php
vendored
22
www/extern/egg/Logger.php
vendored
@@ -42,6 +42,26 @@ class FileLogger implements ILogger
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class SingleFileLogger implements ILogger
|
||||||
|
{
|
||||||
|
/** @var string $path */
|
||||||
|
private $path;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string $filename
|
||||||
|
*/
|
||||||
|
public function __construct($filename)
|
||||||
|
{
|
||||||
|
$this->path = $filename;
|
||||||
|
file_put_contents($this->path, '', FILE_TEXT);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function proclog($text)
|
||||||
|
{
|
||||||
|
file_put_contents($this->path, $text . PHP_EOL , FILE_APPEND | LOCK_EX);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
class SessionLogger implements ILogger
|
class SessionLogger implements ILogger
|
||||||
{
|
{
|
||||||
/** @var string $sessionvar */
|
/** @var string $sessionvar */
|
||||||
@@ -64,6 +84,8 @@ class SessionLogger implements ILogger
|
|||||||
{
|
{
|
||||||
if (session_status() === PHP_SESSION_DISABLED) return;
|
if (session_status() === PHP_SESSION_DISABLED) return;
|
||||||
|
|
||||||
|
if (session_status() !== PHP_SESSION_ACTIVE) session_start();
|
||||||
|
if (session_status() !== PHP_SESSION_ACTIVE) session_start();
|
||||||
$_SESSION[$this->sessionvar] .= $text . "\r\n";
|
$_SESSION[$this->sessionvar] .= $text . "\r\n";
|
||||||
session_commit();
|
session_commit();
|
||||||
}
|
}
|
||||||
|
@@ -76,7 +76,6 @@ $API_OPTIONS = [];
|
|||||||
foreach ($_GET as $k => $v) $API_OPTIONS[strtolower($k)] = $v;
|
foreach ($_GET as $k => $v) $API_OPTIONS[strtolower($k)] = $v;
|
||||||
foreach ($OPTIONS['_urlparams'] as $k => $v) $API_OPTIONS[strtolower($k)] = $v;
|
foreach ($OPTIONS['_urlparams'] as $k => $v) $API_OPTIONS[strtolower($k)] = $v;
|
||||||
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
/** @noinspection PhpIncludeInspection */
|
/** @noinspection PhpIncludeInspection */
|
||||||
@@ -86,4 +85,13 @@ catch (exception $e)
|
|||||||
{
|
{
|
||||||
print("API Command failed with exception");
|
print("API Command failed with exception");
|
||||||
print($e);
|
print($e);
|
||||||
|
|
||||||
|
$content =
|
||||||
|
"REQUEST: " . var_export($_REQUEST) . "\r\n\r\n" .
|
||||||
|
"IP: " . get_client_ip() . "\r\n\r\n" .
|
||||||
|
"ERROR: " . $e . "\r\n\r\n";
|
||||||
|
|
||||||
|
sendMail("Website API call failed", $content, 'virtualadmin@mikescher.de', 'webserver-info@mikescher.com');
|
||||||
|
|
||||||
|
httpDie(500, 'Error.');
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user