Add detection for invalid CLI configuration for settings page

This change will log all failures that prevent the CLI cronjob from happening to the database and display a warning to administrators when an error happened.

To test:

1. Configure some invalid CLI php.ini settings
2. Enable the CLI cronjob and run php cron.php
3. See the errors printed and also in the admin page
4. Configure the CLI settings correctly
5. Errors should be gone.

Fixes https://github.com/owncloud/core/issues/13994
This commit is contained in:
Lukas Reschke 2015-02-27 20:04:52 +01:00
parent 13b0b7dfaf
commit b6d8a48ce1
3 changed files with 39 additions and 1 deletions

View file

@ -575,15 +575,30 @@ class OC {
$errors = OC_Util::checkServer(\OC::$server->getConfig()); $errors = OC_Util::checkServer(\OC::$server->getConfig());
if (count($errors) > 0) { if (count($errors) > 0) {
if (self::$CLI) { if (self::$CLI) {
// Convert l10n string into regular string for usage in database
$staticErrors = [];
$i = 0;
foreach ($errors as $error) { foreach ($errors as $error) {
echo $error['error'] . "\n"; echo $error['error'] . "\n";
echo $error['hint'] . "\n\n"; echo $error['hint'] . "\n\n";
$staticErrors[$i]['error'] = (string) $error['error'];
$staticErrors[$i]['hint'] = (string) $error['hint'];
$i++;
} }
try {
\OC::$server->getConfig()->setAppValue('core', 'cronErrors', json_encode($staticErrors));
} catch(\Exception $e) {
echo('Writing to database failed');
}
exit();
} else { } else {
OC_Response::setStatus(OC_Response::STATUS_SERVICE_UNAVAILABLE); OC_Response::setStatus(OC_Response::STATUS_SERVICE_UNAVAILABLE);
OC_Template::printGuestPage('', 'error', array('errors' => $errors)); OC_Template::printGuestPage('', 'error', array('errors' => $errors));
exit;
} }
exit; } elseif(self::$CLI && \OC::$server->getConfig()->getSystemValue('installed', false)) {
\OC::$server->getConfig()->deleteAppValue('core', 'cronErrors');
} }
//try to set the session lifetime //try to set the session lifetime

View file

@ -80,6 +80,7 @@ $template->assign('allowMailNotification', $appConfig->getValue('core', 'shareap
$template->assign('onlyShareWithGroupMembers', \OC\Share\Share::shareWithGroupMembersOnly()); $template->assign('onlyShareWithGroupMembers', \OC\Share\Share::shareWithGroupMembersOnly());
$databaseOverload = (strpos(\OCP\Config::getSystemValue('dbtype'), 'sqlite') !== false); $databaseOverload = (strpos(\OCP\Config::getSystemValue('dbtype'), 'sqlite') !== false);
$template->assign('databaseOverload', $databaseOverload); $template->assign('databaseOverload', $databaseOverload);
$template->assign('cronErrors', $appConfig->getValue('core', 'cronErrors'));
// warn if Windows is used // warn if Windows is used
$template->assign('WindowsWarning', OC_Util::runningOnWindows()); $template->assign('WindowsWarning', OC_Util::runningOnWindows());

View file

@ -212,7 +212,29 @@ if ($_['suggestedOverwriteCliUrl']) {
</div> </div>
<?php <?php
} }
if ($_['cronErrors']) {
?>
<div class="section">
<h2><?php p($l->t('Cronjob encountered misconfiguration'));?></h2>
<span class="connectionwarning">
<?php p($l->t('It was not possible to execute the cronjob via CLI. The following technical errors have appeared:')); ?>
<br/>
<ol>
<?php foreach(json_decode($_['cronErrors']) as $error) { if(isset($error->error)) {?>
<li><?php p($error->error) ?></li>
<ul><li><?php p($error->hint) ?></li></ul>
<?php }};?>
</ol>
</span>
</div>
<?php
}
?> ?>
<div id="postsetupchecks" class="section"> <div id="postsetupchecks" class="section">
<h2><?php p($l->t('Configuration Checks'));?></h2> <h2><?php p($l->t('Configuration Checks'));?></h2>
<div class="loading"></div> <div class="loading"></div>