This commit is contained in:
Frédéric FRANCE 2021-02-12 08:49:29 +01:00
parent 60ae50abb3
commit fa72021ca8
No known key found for this signature in database
GPG Key ID: 06809324E4B2ABC1
2 changed files with 84 additions and 12 deletions

View File

@ -50,8 +50,19 @@ class Cronjob extends CommonObject
*/ */
public $entity; public $entity;
/**
* @var string Job type
*/
public $jobtype; public $jobtype;
/**
* @var string|int Date for last cron object update
*/
public $tms = ''; public $tms = '';
/**
* @var string|int Date for cron job create
*/
public $datec = ''; public $datec = '';
/** /**
@ -59,6 +70,9 @@ class Cronjob extends CommonObject
*/ */
public $label; public $label;
/**
* @var string Job command
*/
public $command; public $command;
public $classesname; public $classesname;
public $objectname; public $objectname;
@ -67,20 +81,50 @@ class Cronjob extends CommonObject
public $md5params; public $md5params;
public $module_name; public $module_name;
public $priority; public $priority;
/** /**
* @var string|int Date for last job execution * @var string|int Date for last job execution
*/ */
public $datelastrun = ''; public $datelastrun = '';
/** /**
* @var string|int Date for next job execution * @var string|int Date for next job execution
*/ */
public $datenextrun = ''; public $datenextrun = '';
/**
* @var string|int Date for end job execution
*/
public $dateend = ''; public $dateend = '';
/**
* @var string|int Date for first start job execution
*/
public $datestart = ''; public $datestart = '';
/**
* @var string|int Date for last result job execution
*/
public $datelastresult = ''; public $datelastresult = '';
/**
* @var string Last result from end job execution
*/
public $lastresult; public $lastresult;
/**
* @var string Last output from end job execution
*/
public $lastoutput; public $lastoutput;
/**
* @var string Unit frequency of job execution
*/
public $unitfrequency; public $unitfrequency;
/**
* @var int Frequency of job execution
*/
public $frequency; public $frequency;
/** /**
@ -88,6 +132,9 @@ class Cronjob extends CommonObject
*/ */
public $status; public $status;
/**
* @var int Is job processing
*/
public $processing; public $processing;
/** /**
@ -100,9 +147,25 @@ class Cronjob extends CommonObject
*/ */
public $fk_user_mod; public $fk_user_mod;
/**
* @var int Number of run job execution
*/
public $nbrun; public $nbrun;
/**
* @var int Maximum run job execution
*/
public $maxrun;
/**
* @var string Libname
*/
public $libname; public $libname;
public $test; // A test condition to know if job is visible/qualified
/**
* @var string A test condition to know if job is visible/qualified
*/
public $test;
const STATUS_DISABLED = 0; const STATUS_DISABLED = 0;
const STATUS_ENABLED = 1; const STATUS_ENABLED = 1;
@ -152,7 +215,12 @@ class Cronjob extends CommonObject
if (isset($this->frequency)) $this->frequency = trim($this->frequency); if (isset($this->frequency)) $this->frequency = trim($this->frequency);
if (isset($this->status)) $this->status = trim($this->status); if (isset($this->status)) $this->status = trim($this->status);
if (isset($this->note_private)) $this->note_private = trim($this->note_private); if (isset($this->note_private)) $this->note_private = trim($this->note_private);
if (isset($this->nbrun)) $this->nbrun = trim($this->nbrun); if (isset($this->nbrun)) {
$this->nbrun = (int) $this->nbrun;
}
if (isset($this->maxrun)) {
$this->maxrun = (int) $this->maxrun;
}
if (isset($this->libname)) $this->libname = trim($this->libname); if (isset($this->libname)) $this->libname = trim($this->libname);
if (isset($this->test)) $this->test = trim($this->test); if (isset($this->test)) $this->test = trim($this->test);
@ -262,7 +330,10 @@ class Cronjob extends CommonObject
dol_syslog(get_class($this)."::create", LOG_DEBUG); dol_syslog(get_class($this)."::create", LOG_DEBUG);
$resql = $this->db->query($sql); $resql = $this->db->query($sql);
if (!$resql) { $error++; $this->errors[] = "Error ".$this->db->lasterror(); } if (!$resql) {
$error++;
$this->errors[] = "Error ".$this->db->lasterror();
}
if (!$error) if (!$error)
{ {
@ -1253,8 +1324,7 @@ class Cronjob extends CommonObject
} }
$result = $this->update($user); $result = $this->update($user);
if ($result < 0) if ($result < 0) {
{
dol_syslog(get_class($this)."::reprogram_jobs ".$this->error, LOG_ERR); dol_syslog(get_class($this)."::reprogram_jobs ".$this->error, LOG_ERR);
return -1; return -1;
} }
@ -1289,14 +1359,16 @@ class Cronjob extends CommonObject
$this->labelStatus = array(); // Force reset o array because label depends on other fields $this->labelStatus = array(); // Force reset o array because label depends on other fields
$this->labelStatusShort = array(); $this->labelStatusShort = array();
if (empty($this->labelStatus) || empty($this->labelStatusShort)) if (empty($this->labelStatus) || empty($this->labelStatusShort)) {
{
global $langs; global $langs;
$langs->load('users'); $langs->load('users');
$moretext = ''; $moretext = '';
if ($processing) $moretext = ' ('.$langs->trans("Running").')'; if ($processing) {
elseif ($lastresult) $moretext .= ' ('.$langs->trans("Error").')'; $moretext = ' ('.$langs->trans("Running").')';
} elseif ($lastresult) {
$moretext .= ' ('.$langs->trans("Error").')';
}
$this->labelStatus[self::STATUS_DISABLED] = $langs->trans('Disabled').$moretext; $this->labelStatus[self::STATUS_DISABLED] = $langs->trans('Disabled').$moretext;
$this->labelStatus[self::STATUS_ENABLED] = $langs->trans('Scheduled').$moretext; $this->labelStatus[self::STATUS_ENABLED] = $langs->trans('Scheduled').$moretext;

View File

@ -1701,8 +1701,7 @@ if (is_array($listofmodules) && count($listofmodules) > 0) {
foreach ($objMod->config_page_url as $page) foreach ($objMod->config_page_url as $page)
{ {
$urlpage = $page; $urlpage = $page;
if ($i++) if ($i++) {
{
$linktoenabledisable .= ' <a href="'.$urlpage.'" title="'.$langs->trans($page).'">'.img_picto(ucfirst($page), "setup").'</a>'; $linktoenabledisable .= ' <a href="'.$urlpage.'" title="'.$langs->trans($page).'">'.img_picto(ucfirst($page), "setup").'</a>';
// print '<a href="'.$page.'">'.ucfirst($page).'</a>&nbsp;'; // print '<a href="'.$page.'">'.ucfirst($page).'</a>&nbsp;';
} else { } else {
@ -1711,7 +1710,8 @@ if (is_array($listofmodules) && count($listofmodules) > 0) {
$urltouse = dol_buildpath('/'.$regs[2].'/admin/'.$regs[1], 1); $urltouse = dol_buildpath('/'.$regs[2].'/admin/'.$regs[1], 1);
$linktoenabledisable .= ' &nbsp; <a href="'.$urltouse.(preg_match('/\?/', $urltouse) ? '&' : '?').'save_lastsearch_values=1&backtopage='.urlencode($backtourl).'" title="'.$langs->trans("Setup").'">'.img_picto($langs->trans("Setup"), "setup", 'style="padding-right: 6px"').'</a>'; $linktoenabledisable .= ' &nbsp; <a href="'.$urltouse.(preg_match('/\?/', $urltouse) ? '&' : '?').'save_lastsearch_values=1&backtopage='.urlencode($backtourl).'" title="'.$langs->trans("Setup").'">'.img_picto($langs->trans("Setup"), "setup", 'style="padding-right: 6px"').'</a>';
} else { } else {
// Case standard admin page (not a page provided by the module but a page // Case standard admin page (not a page provided by the
// module but a page provided by dolibarr)
$urltouse = DOL_URL_ROOT.'/admin/'.$urlpage; $urltouse = DOL_URL_ROOT.'/admin/'.$urlpage;
$linktoenabledisable .= ' &nbsp; <a href="'.$urltouse.(preg_match('/\?/', $urltouse) ? '&' : '?').'save_lastsearch_values=1&backtopage='.urlencode($backtourl).'" title="'.$langs->trans("Setup").'">'.img_picto($langs->trans("Setup"), "setup", 'style="padding-right: 6px"').'</a>'; $linktoenabledisable .= ' &nbsp; <a href="'.$urltouse.(preg_match('/\?/', $urltouse) ? '&' : '?').'save_lastsearch_values=1&backtopage='.urlencode($backtourl).'" title="'.$langs->trans("Setup").'">'.img_picto($langs->trans("Setup"), "setup", 'style="padding-right: 6px"').'</a>';
} }