push some upcoming changes (still holding back db changes b/c of version jump to rc2)
Signed-off-by: Michael Kaufmann (d00p) <d00p@froxlor.org>
This commit is contained in:
@@ -29,6 +29,14 @@ return array(
|
|||||||
'default' => '/etc/cron.d/froxlor',
|
'default' => '/etc/cron.d/froxlor',
|
||||||
'save_method' => 'storeSettingField',
|
'save_method' => 'storeSettingField',
|
||||||
),
|
),
|
||||||
|
'system_send_cron_errors' => array(
|
||||||
|
'label' => $lng['serversettings']['system_send_cron_errors'],
|
||||||
|
'settinggroup' => 'system',
|
||||||
|
'varname' => 'send_cron_errors',
|
||||||
|
'type' => 'bool',
|
||||||
|
'default' => false,
|
||||||
|
'save_method' => 'storeSettingField',
|
||||||
|
),
|
||||||
'system_croncmdline' => array(
|
'system_croncmdline' => array(
|
||||||
'label' => $lng['serversettings']['system_croncmdline'],
|
'label' => $lng['serversettings']['system_croncmdline'],
|
||||||
'settinggroup' => 'system',
|
'settinggroup' => 'system',
|
||||||
|
|||||||
@@ -679,4 +679,11 @@ function parseAndOutputPreconfig(&$has_preconfig, &$return, $current_version) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (versionInUpdate($current_version, '0.9.33-rc2')) {
|
||||||
|
$has_preconfig = true;
|
||||||
|
$description = 'You can chose whether you want to receive an e-mail on cronjob errors. Keep in mind that this can lead to an e-mail being sent every 5 minutes.<br /><br />';
|
||||||
|
$question = '<strong>Do you want to receive cron-errors via mail? (default: no):</strong> ';
|
||||||
|
$question.= makeyesno('system_send_cron_errors', '1', '0', '0').'<br />';
|
||||||
|
eval("\$return.=\"" . getTemplate("update/preconfigitem") . "\";");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -32,12 +32,14 @@ if (function_exists("date_default_timezone_set")
|
|||||||
}
|
}
|
||||||
|
|
||||||
$basename = basename($_SERVER['PHP_SELF'], '.php');
|
$basename = basename($_SERVER['PHP_SELF'], '.php');
|
||||||
|
$crontype = "";
|
||||||
if (isset($argv) && is_array($argv) && count($argv) > 1) {
|
if (isset($argv) && is_array($argv) && count($argv) > 1) {
|
||||||
for($x=1;$x < count($argv);$x++) {
|
for($x=1;$x < count($argv);$x++) {
|
||||||
if (substr(strtolower($argv[$x]), 0, 2) == '--'
|
if (substr(strtolower($argv[$x]), 0, 2) == '--'
|
||||||
&& strlen($argv[$x]) > 3
|
&& strlen($argv[$x]) > 3
|
||||||
) {
|
) {
|
||||||
$basename .= "-".substr(strtolower($argv[$x]), 2);
|
$crontype = substr(strtolower($argv[$x]), 2);
|
||||||
|
$basename .= "-".$crontype;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -52,57 +54,15 @@ $lockfile = $lockdir . $lockfName;
|
|||||||
// froxlor installation isn't in /var/www/froxlor
|
// froxlor installation isn't in /var/www/froxlor
|
||||||
define('FROXLOR_INSTALL_DIR', dirname(dirname(__FILE__)));
|
define('FROXLOR_INSTALL_DIR', dirname(dirname(__FILE__)));
|
||||||
|
|
||||||
|
|
||||||
// create and open the lockfile!
|
// create and open the lockfile!
|
||||||
$keepLockFile = false;
|
$keepLockFile = false;
|
||||||
$debugHandler = fopen($lockfile, 'w');
|
$debugHandler = fopen($lockfile, 'w');
|
||||||
fwrite($debugHandler, 'Setting Lockfile to ' . $lockfile . "\n");
|
fwrite($debugHandler, 'Setting Lockfile to ' . $lockfile . "\n");
|
||||||
fwrite($debugHandler, 'Setting Froxlor installation path to ' . FROXLOR_INSTALL_DIR . "\n");
|
fwrite($debugHandler, 'Setting Froxlor installation path to ' . FROXLOR_INSTALL_DIR . "\n");
|
||||||
|
|
||||||
// open the lockfile directory and scan for existing lockfiles
|
if (!file_exists(FROXLOR_INSTALL_DIR . '/lib/userdata.inc.php')) {
|
||||||
$lockDirHandle = opendir($lockdir);
|
die("Froxlor does not seem to be installed yet - skipping cronjob");
|
||||||
|
|
||||||
while ($fName = readdir($lockDirHandle)) {
|
|
||||||
|
|
||||||
if ($lockFilename == substr($fName, 0, strlen($lockFilename))
|
|
||||||
&& $lockfName != $fName
|
|
||||||
) {
|
|
||||||
// Check if last run jailed out with an exception
|
|
||||||
$croncontent = file($lockdir . $fName);
|
|
||||||
$lastline = $croncontent[(count($croncontent) - 1)];
|
|
||||||
|
|
||||||
if ($lastline == '=== Keep lockfile because of exception ===') {
|
|
||||||
fclose($debugHandler);
|
|
||||||
unlink($lockfile);
|
|
||||||
die('Last cron jailed out with an exception. Exiting...' . "\n" . 'Take a look into the contents of ' . $lockdir . $fName . '* for more information!' . "\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if cron is running or has died.
|
|
||||||
$check_pid = substr(strstr($fName, "-"), 1);
|
|
||||||
system("kill -CHLD " . (int)$check_pid . " 1> /dev/null 2> /dev/null", $check_pid_return);
|
|
||||||
|
|
||||||
if ($check_pid_return == 1) {
|
|
||||||
// Result: Existing lockfile/pid isnt running
|
|
||||||
// Most likely it has died
|
|
||||||
//
|
|
||||||
// Action: Remove it and continue
|
|
||||||
//
|
|
||||||
fwrite($debugHandler, 'Previous cronjob didn\'t exit clean. PID: ' . $check_pid . "\n");
|
|
||||||
fwrite($debugHandler, 'Removing lockfile: ' . $lockdir . $fName . "\n");
|
|
||||||
unlink($lockdir . $fName);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
// Result: A Cronscript with this pid
|
|
||||||
// is still running
|
|
||||||
// Action: remove my own Lock and die
|
|
||||||
//
|
|
||||||
// close the current lockfile
|
|
||||||
fclose($debugHandler);
|
|
||||||
|
|
||||||
// ... and delete it
|
|
||||||
unlink($lockfile);
|
|
||||||
die('There is already a Cronjob in progress. Exiting...' . "\n" . 'Take a look into the contents of ' . $lockdir . $lockFilename . '* for more information!' . "\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Includes the Usersettings eg. MySQL-Username/Passwort etc.
|
// Includes the Usersettings eg. MySQL-Username/Passwort etc.
|
||||||
@@ -139,6 +99,53 @@ try {
|
|||||||
|
|
||||||
fwrite($debugHandler, 'Database-connection established' . "\n");
|
fwrite($debugHandler, 'Database-connection established' . "\n");
|
||||||
|
|
||||||
|
// open the lockfile directory and scan for existing lockfiles
|
||||||
|
$lockDirHandle = opendir($lockdir);
|
||||||
|
|
||||||
|
while ($fName = readdir($lockDirHandle)) {
|
||||||
|
|
||||||
|
if ($lockFilename == substr($fName, 0, strlen($lockFilename))
|
||||||
|
&& $lockfName != $fName
|
||||||
|
) {
|
||||||
|
// Check if last run jailed out with an exception
|
||||||
|
$croncontent = file($lockdir . $fName);
|
||||||
|
$lastline = $croncontent[(count($croncontent) - 1)];
|
||||||
|
|
||||||
|
if ($lastline == '=== Keep lockfile because of exception ===') {
|
||||||
|
fclose($debugHandler);
|
||||||
|
unlink($lockfile);
|
||||||
|
dieWithMail('Last cron jailed out with an exception. Exiting...' . "\n" . 'Take a look into the contents of ' . $lockdir . $fName . '* for more information!' . "\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if cron is running or has died.
|
||||||
|
$check_pid = substr(strstr($fName, "-"), 1);
|
||||||
|
system("kill -CHLD " . (int)$check_pid . " 1> /dev/null 2> /dev/null", $check_pid_return);
|
||||||
|
|
||||||
|
if ($check_pid_return == 1) {
|
||||||
|
// Result: Existing lockfile/pid isnt running
|
||||||
|
// Most likely it has died
|
||||||
|
//
|
||||||
|
// Action: Remove it and continue
|
||||||
|
//
|
||||||
|
fwrite($debugHandler, 'Previous cronjob didn\'t exit clean. PID: ' . $check_pid . "\n");
|
||||||
|
fwrite($debugHandler, 'Removing lockfile: ' . $lockdir . $fName . "\n");
|
||||||
|
unlink($lockdir . $fName);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
// Result: A Cronscript with this pid
|
||||||
|
// is still running
|
||||||
|
// Action: remove my own Lock and die
|
||||||
|
//
|
||||||
|
// close the current lockfile
|
||||||
|
fclose($debugHandler);
|
||||||
|
|
||||||
|
// ... and delete it
|
||||||
|
unlink($lockfile);
|
||||||
|
dieWithMail('There is already a Cronjob for '.$crontype.' in progress. Exiting...' . "\n" . 'Take a look into the contents of ' . $lockdir . $lockFilename . '* for more information!' . "\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* if using fcgid or fpm for froxlor-vhost itself, we have to check
|
* if using fcgid or fpm for froxlor-vhost itself, we have to check
|
||||||
* whether the permission of the files are still correct
|
* whether the permission of the files are still correct
|
||||||
@@ -185,7 +192,7 @@ if (Settings::Get('panel.version') == null
|
|||||||
$errormessage.= "Possible reason: Froxlor update\n";
|
$errormessage.= "Possible reason: Froxlor update\n";
|
||||||
$errormessage.= "Information: Current version in database: ".Settings::Get('panel.version')." - version of Froxlor files: ".$version."\n";
|
$errormessage.= "Information: Current version in database: ".Settings::Get('panel.version')." - version of Froxlor files: ".$version."\n";
|
||||||
$errormessage.= "Solution: Please visit your Foxlor admin interface for further information.\n";
|
$errormessage.= "Solution: Please visit your Foxlor admin interface for further information.\n";
|
||||||
die($errormessage);
|
dieWithMail($errormessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Settings::Get('system.cron_allowautoupdate') == 1) {
|
if (Settings::Get('system.cron_allowautoupdate') == 1) {
|
||||||
|
|||||||
69
lib/functions/output/function.dieWithMail.php
Normal file
69
lib/functions/output/function.dieWithMail.php
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This file is part of the Froxlor project.
|
||||||
|
* Copyright (c) 2010 the Froxlor Team (see authors).
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the COPYING
|
||||||
|
* file that was distributed with this source code. You can also view the
|
||||||
|
* COPYING file online at http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
*
|
||||||
|
* @copyright (c) the authors
|
||||||
|
* @author Michael Kaufmann <mkaufmann@nutime.de>
|
||||||
|
* @author Froxlor team <team@froxlor.org> (2010-)
|
||||||
|
* @license GPLv2 http://files.froxlor.org/misc/COPYING.txt
|
||||||
|
* @package Cron
|
||||||
|
*
|
||||||
|
* @since 0.9.33
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cronjob function to end a cronjob in a critical condition
|
||||||
|
* but not without sending a notification mail to the admin
|
||||||
|
*
|
||||||
|
* @param string $message
|
||||||
|
* @param string $subject
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
function dieWithMail($message, $subject = "[froxlor] Cronjob error") {
|
||||||
|
|
||||||
|
if (Settings::Get('system.send_cron_errors') == '1') {
|
||||||
|
|
||||||
|
$_mail = new PHPMailer(true);
|
||||||
|
$_mail->CharSet = "UTF-8";
|
||||||
|
|
||||||
|
if (PHPMailer::ValidateAddress(Settings::Get('panel.adminmail')) !== false) {
|
||||||
|
// set return-to address and custom sender-name, see #76
|
||||||
|
$_mail->SetFrom(Settings::Get('panel.adminmail'), Settings::Get('panel.adminmail_defname'));
|
||||||
|
if (Settings::Get('panel.adminmail_return') != '') {
|
||||||
|
$_mail->AddReplyTo(Settings::Get('panel.adminmail_return'), Settings::Get('panel.adminmail_defname'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$_mailerror = false;
|
||||||
|
try {
|
||||||
|
$_mail->Subject = $subject;
|
||||||
|
$_mail->AltBody = $message;
|
||||||
|
$_mail->MsgHTML(nl2br($message));
|
||||||
|
$_mail->AddAddress(Settings::Get('panel.adminmail'), Settings::Get('panel.adminmail_defname'));
|
||||||
|
$_mail->Send();
|
||||||
|
} catch (phpmailerException $e) {
|
||||||
|
$mailerr_msg = $e->errorMessage();
|
||||||
|
$_mailerror = true;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
$mailerr_msg = $e->getMessage();
|
||||||
|
$_mailerror = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
$_mail->ClearAddresses();
|
||||||
|
|
||||||
|
if ($_mailerror) {
|
||||||
|
echo 'Error sending mail: ' . $mailerr_msg . "\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
die($message);
|
||||||
|
|
||||||
|
}
|
||||||
@@ -1836,3 +1836,5 @@ $lng['domains']['import_description'] = 'Detailed information about the structur
|
|||||||
$lng['usersettings']['custom_notes']['title'] = 'Custom notes';
|
$lng['usersettings']['custom_notes']['title'] = 'Custom notes';
|
||||||
$lng['usersettings']['custom_notes']['description'] = 'Feel free to put any notes you want/need in here. They will show up in the admin/customer overview for the corresponding user.';
|
$lng['usersettings']['custom_notes']['description'] = 'Feel free to put any notes you want/need in here. They will show up in the admin/customer overview for the corresponding user.';
|
||||||
$lng['usersettings']['custom_notes']['show'] = 'Show your notes on the dashboard of the user';
|
$lng['usersettings']['custom_notes']['show'] = 'Show your notes on the dashboard of the user';
|
||||||
|
$lng['serversettings']['system_send_cron_errors']['title'] = 'Send cron-errors to froxlor-admin via e-mail';
|
||||||
|
$lng['serversettings']['system_send_cron_errors']['description'] = 'Chose whether you want to receive an e-mail on cronjob errors. Keep in mind that this can lead to an e-mail being sent every 5 minutes depending on the error and your cronjob settings.';
|
||||||
|
|||||||
@@ -1563,3 +1563,5 @@ $lng['domains']['import_description'] = 'Detaillierte Informationen über den Au
|
|||||||
$lng['usersettings']['custom_notes']['title'] = 'Eigene Notizen';
|
$lng['usersettings']['custom_notes']['title'] = 'Eigene Notizen';
|
||||||
$lng['usersettings']['custom_notes']['description'] = 'Hier können Notizen je nach Lust und Laune eingetragen werden. Diese werden in der Administrator/Kunden-Übersicht bei dem jeweiligen Benutzer angezeigt.';
|
$lng['usersettings']['custom_notes']['description'] = 'Hier können Notizen je nach Lust und Laune eingetragen werden. Diese werden in der Administrator/Kunden-Übersicht bei dem jeweiligen Benutzer angezeigt.';
|
||||||
$lng['usersettings']['custom_notes']['show'] = 'Zeige die Notizen auf dem Dashboard des Benutzers';
|
$lng['usersettings']['custom_notes']['show'] = 'Zeige die Notizen auf dem Dashboard des Benutzers';
|
||||||
|
$lng['serversettings']['system_send_cron_errors']['title'] = 'Sende Cron-Fehler via E-Mail an den Froxlor-Admin';
|
||||||
|
$lng['serversettings']['system_send_cron_errors']['description'] = 'Gib an, ob bei einem Cron-Fehler eine E-Mail versendet werden soll. Beachte das es je nach Fehler und Cronjob-Einstellungen dazu kommen kann, dass diese E-Mail alle 5 Minuten gesendet wird.';
|
||||||
|
|||||||
Reference in New Issue
Block a user