2013-03-22 17:10:17 +01:00
< ? php
/* Copyright ( C ) 2012 Nicolas Villa aka Boyquotes http :// informetic . fr
2016-02-07 16:02:30 +01:00
* Copyright ( C ) 2013 Florian Henry < florian . henry @ open - concept . pro >
* Copyright ( C ) 2013 - 2016 Laurent Destailleur < eldy @ users . sourceforge . net >
2013-03-22 17:10:17 +01:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http :// www . gnu . org / licenses />.
*/
/**
2017-07-26 10:11:39 +02:00
* \file htdocs / cron / list . php
2013-03-22 17:10:17 +01:00
* \ingroup cron
* \brief Lists Jobs
*/
require '../main.inc.php' ;
2018-05-26 20:51:17 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/admin.lib.php' ;
require_once DOL_DOCUMENT_ROOT . '/cron/class/cronjob.class.php' ;
2013-03-22 17:10:17 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/cron.lib.php' ;
2018-05-26 20:51:17 +02:00
// Load translation files required by the page
2018-08-21 13:58:24 +02:00
$langs -> loadLangs ( array ( " admin " , " cron " , " bills " , " members " ));
2013-03-22 17:10:17 +01:00
if ( ! $user -> rights -> cron -> read ) accessforbidden ();
$action = GETPOST ( 'action' , 'alpha' );
2018-03-01 15:24:50 +01:00
$massaction = GETPOST ( 'massaction' , 'alpha' ); // The bulk action (combo box choice into lists)
2013-03-22 17:10:17 +01:00
$confirm = GETPOST ( 'confirm' , 'alpha' );
2018-03-01 15:24:50 +01:00
$toselect = GETPOST ( 'toselect' , 'array' ); // Array of ids of elements selected into a list
2018-02-22 12:15:11 +01:00
$contextpage = GETPOST ( 'contextpage' , 'aZ' ) ? GETPOST ( 'contextpage' , 'aZ' ) : 'cronjoblist' ; // To manage different context of search
2013-03-22 17:10:17 +01:00
2018-03-01 15:24:50 +01:00
$id = GETPOST ( 'id' , 'int' );
2017-06-08 14:55:12 +02:00
$limit = GETPOST ( 'limit' , 'int' ) ? GETPOST ( 'limit' , 'int' ) : $conf -> liste_limit ;
2016-02-16 00:31:05 +01:00
$sortfield = GETPOST ( " sortfield " , 'alpha' );
$sortorder = GETPOST ( " sortorder " , 'alpha' );
$page = GETPOST ( " page " , 'int' );
2017-06-06 10:53:53 +02:00
if ( empty ( $page ) || $page == - 1 ) { $page = 0 ; } // If $page is not defined, or '' or -1
2016-02-16 00:31:05 +01:00
$offset = $limit * $page ;
$pageprev = $page - 1 ;
$pagenext = $page + 1 ;
2018-02-27 20:04:29 +01:00
if ( ! $sortfield ) $sortfield = 't.status,t.priority' ;
if ( ! $sortorder ) $sortorder = 'DESC,ASC' ;
2016-08-17 15:40:17 +02:00
2018-03-01 12:53:40 +01:00
$search_status = GETPOST ( 'search_status' , 'int' ) ? GETPOST ( 'search_status' , 'int' ) : GETPOST ( 'status' , 'int' );
if ( $search_status == '' ) $search_status =- 2 ;
2013-03-22 17:10:17 +01:00
//Search criteria
$search_label = GETPOST ( " search_label " , 'alpha' );
2016-09-08 13:01:50 +02:00
$securitykey = GETPOST ( 'securitykey' , 'alpha' );
2016-08-17 15:40:17 +02:00
$diroutputmassaction = $conf -> cronjob -> dir_output . '/temp/massgeneration/' . $user -> id ;
2017-06-10 12:56:28 +02:00
// Initialize technical object to manage hooks of page. Note that conf->hooks_modules contains array of hook context
2016-08-17 15:40:17 +02:00
$hookmanager -> initHooks ( array ( 'cronjoblist' ));
$extrafields = new ExtraFields ( $db );
// fetch optionals attributes and labels
$extralabels = $extrafields -> fetch_name_optionals_label ( 'cronjob' );
$search_array_options = $extrafields -> getOptionalsFromPost ( $extralabels , '' , 'search_' );
$object = new Cronjob ( $db );
2013-03-22 17:10:17 +01:00
2016-02-07 16:02:30 +01:00
/*
* Actions
*/
2018-03-01 12:53:40 +01:00
if ( GETPOST ( 'cancel' , 'alpha' )) { $action = 'list' ; $massaction = '' ; }
if ( ! GETPOST ( 'confirmmassaction' , 'alpha' ) && $massaction != 'presend' && $massaction != 'confirm_presend' ) { $massaction = '' ; }
2013-03-22 17:10:17 +01:00
2018-03-01 12:53:40 +01:00
$parameters = array ();
$reshook = $hookmanager -> executeHooks ( 'doActions' , $parameters , $object , $action ); // Note that $action and $object may have been modified by some hooks
if ( $reshook < 0 ) setEventMessages ( $hookmanager -> error , $hookmanager -> errors , 'errors' );
2013-03-22 17:10:17 +01:00
2018-03-01 12:53:40 +01:00
if ( empty ( $reshook ))
2016-02-07 16:02:30 +01:00
{
2018-03-01 12:53:40 +01:00
// Selection of new fields
include DOL_DOCUMENT_ROOT . '/core/actions_changeselectedfields.inc.php' ;
// Purge search criteria
if ( GETPOST ( 'button_removefilter_x' , 'alpha' ) || GETPOST ( 'button_removefilter.x' , 'alpha' ) || GETPOST ( 'button_removefilter' , 'alpha' )) // All tests are required to be compatible with all browsers
{
$search_label = '' ;
$search_status =- 1 ;
2018-03-01 15:24:50 +01:00
$toselect = '' ;
$search_array_options = array ();
}
if ( GETPOST ( 'button_removefilter_x' , 'alpha' ) || GETPOST ( 'button_removefilter.x' , 'alpha' ) || GETPOST ( 'button_removefilter' , 'alpha' )
|| GETPOST ( 'button_search_x' , 'alpha' ) || GETPOST ( 'button_search.x' , 'alpha' ) || GETPOST ( 'button_search' , 'alpha' ))
{
$massaction = '' ; // Protection to avoid mass action if we force a new search during a mass action confirmation
2018-03-01 12:53:40 +01:00
}
2013-03-22 17:10:17 +01:00
2018-03-01 12:53:40 +01:00
$filter = array ();
if ( ! empty ( $search_label ))
{
$filter [ 't.label' ] = $search_label ;
2013-03-22 17:10:17 +01:00
}
2018-03-01 12:53:40 +01:00
// Delete jobs
if ( $action == 'confirm_delete' && $confirm == " yes " && $user -> rights -> cron -> delete )
{
//Delete cron task
$object = new Cronjob ( $db );
$object -> id = $id ;
$result = $object -> delete ( $user );
if ( $result < 0 ) {
setEventMessages ( $object -> error , $object -> errors , 'errors' );
}
}
// Execute jobs
if ( $action == 'confirm_execute' && $confirm == " yes " && $user -> rights -> cron -> execute )
{
if ( ! empty ( $conf -> global -> CRON_KEY ) && $conf -> global -> CRON_KEY != $securitykey )
{
setEventMessages ( 'Security key ' . $securitykey . ' is wrong' , null , 'errors' );
$action = '' ;
}
else
{
$object = new Cronjob ( $db );
$job = $object -> fetch ( $id );
$now = dol_now (); // Date we start
$resrunjob = $object -> run_jobs ( $user -> login ); // Return -1 if KO, 1 if OK
if ( $resrunjob < 0 ) {
setEventMessages ( $object -> error , $object -> errors , 'errors' );
}
// Programm next run
$res = $object -> reprogram_jobs ( $user -> login , $now );
if ( $res > 0 )
{
if ( $resrunjob >= 0 ) // We show the result of reprogram only if no error message already reported
{
if ( $object -> lastresult >= 0 ) setEventMessages ( $langs -> trans ( " JobFinished " ), null , 'mesgs' );
else setEventMessages ( $langs -> trans ( " JobFinished " ), null , 'errors' );
}
$action = '' ;
}
else
{
setEventMessages ( $object -> error , $object -> errors , 'errors' );
$action = '' ;
}
$param = '&search_status=' . urlencode ( $search_status );
if ( ! empty ( $contextpage ) && $contextpage != $_SERVER [ " PHP_SELF " ]) $param .= '&contextpage=' . urlencode ( $contextpage );
if ( $limit > 0 && $limit != $conf -> liste_limit ) $param .= '&limit=' . urlencode ( $limit );
if ( $search_label ) $param .= '&search_label=' . urlencode ( $search_label );
if ( $optioncss != '' ) $param .= '&optioncss=' . urlencode ( $optioncss );
// Add $param from extra fields
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_param.tpl.php' ;
header ( " Location: " . DOL_URL_ROOT . '/cron/list.php?' . $param . ( $sortfield ? '&sortfield=' . $sortfield : '' ) . ( $sortorder ? '&sortorder=' . $sortorder : '' )); // Make a redirect to avoid to run twice the job when using back
exit ;
}
}
2018-03-01 15:24:50 +01:00
// Mass actions
$objectclass = 'CronJob' ;
$objectlabel = 'CronJob' ;
$permtoread = $user -> rights -> cron -> read ;
$permtocreate = $user -> rights -> cron -> create ? $user -> rights -> cron -> create : $user -> rights -> cron -> write ;
$permtodelete = $user -> rights -> cron -> delete ;
$uploaddir = $conf -> cron -> dir_output ;
include DOL_DOCUMENT_ROOT . '/core/actions_massactions.inc.php' ;
if ( $permtocreate )
{
$tmpcron = new Cronjob ( $db );
foreach ( $toselect as $id )
{
$result = $tmpcron -> fetch ( $id );
if ( $result )
{
$result = 0 ;
if ( $massaction == 'disable' ) $result = $tmpcron -> setStatut ( Cronjob :: STATUS_DISABLED );
elseif ( $massaction == 'enable' ) $result = $tmpcron -> setStatut ( Cronjob :: STATUS_ENABLED );
else dol_print_error ( $db , 'Bad value for massaction' );
if ( $result < 0 ) setEventMessages ( $tmpcron -> error , $tmpcron -> errors , 'errors' );
}
else
{
$error ++ ;
}
}
}
2013-03-22 17:10:17 +01:00
}
/*
* View
*/
$form = new Form ( $db );
2018-02-22 12:15:11 +01:00
$cronjob = new Cronjob ( $db );
2013-03-22 17:10:17 +01:00
2013-04-17 16:26:14 +02:00
$pagetitle = $langs -> trans ( " CronList " );
2013-03-22 17:10:17 +01:00
2013-04-01 20:15:52 +02:00
llxHeader ( '' , $pagetitle );
2013-03-22 17:10:17 +01:00
2014-07-28 20:30:31 +02:00
2016-08-17 15:40:17 +02:00
$sql = " SELECT " ;
$sql .= " t.rowid, " ;
$sql .= " t.tms, " ;
$sql .= " t.datec, " ;
$sql .= " t.jobtype, " ;
$sql .= " t.label, " ;
$sql .= " t.command, " ;
$sql .= " t.classesname, " ;
$sql .= " t.objectname, " ;
$sql .= " t.methodename, " ;
$sql .= " t.params, " ;
$sql .= " t.md5params, " ;
$sql .= " t.module_name, " ;
$sql .= " t.priority, " ;
$sql .= " t.datelastrun, " ;
$sql .= " t.datenextrun, " ;
$sql .= " t.dateend, " ;
$sql .= " t.datestart, " ;
$sql .= " t.lastresult, " ;
$sql .= " t.datelastresult, " ;
$sql .= " t.lastoutput, " ;
$sql .= " t.unitfrequency, " ;
$sql .= " t.frequency, " ;
$sql .= " t.status, " ;
$sql .= " t.fk_user_author, " ;
$sql .= " t.fk_user_mod, " ;
$sql .= " t.note, " ;
2018-09-18 23:25:38 +02:00
$sql .= " t.maxrun, " ;
2016-08-17 15:40:17 +02:00
$sql .= " t.nbrun, " ;
$sql .= " t.libname, " ;
$sql .= " t.test " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " cronjob as t " ;
2018-04-05 12:28:52 +02:00
$sql .= " WHERE entity IN (0, " . $conf -> entity . " ) " ;
2018-03-01 12:53:40 +01:00
if ( $search_status >= 0 && $search_status < 2 ) $sql .= " AND t.status = " . ( empty ( $search_status ) ? '0' : '1' );
if ( $search_status == 2 ) $sql .= " AND t.status = 2 " ;
2016-08-17 15:40:17 +02:00
//Manage filter
if ( is_array ( $filter ) && count ( $filter ) > 0 ) {
foreach ( $filter as $key => $value ) {
2018-09-18 23:25:38 +02:00
$sql .= ' AND ' . $key . ' LIKE \'%' . $db -> escape ( $value ) . '%\'' ;
2016-08-17 15:40:17 +02:00
}
2013-06-05 16:24:32 +02:00
}
2016-08-17 15:40:17 +02:00
$sqlwhere = array ();
if ( ! empty ( $module_name )) {
2018-09-18 23:25:38 +02:00
$sqlwhere [] = '(t.module_name=' . $db -> escape ( $module_name ) . ')' ;
2016-08-17 15:40:17 +02:00
}
if ( count ( $sqlwhere ) > 0 ) {
$sql .= " WHERE " . implode ( ' AND ' , $sqlwhere );
}
// Add where from extra fields
2017-11-27 15:24:29 +01:00
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_sql.tpl.php' ;
2016-08-17 15:40:17 +02:00
// Add where from hooks
$parameters = array ();
$reshook = $hookmanager -> executeHooks ( 'printFieldListWhere' , $parameters ); // Note that $action and $object may have been modified by hook
$sql .= $hookmanager -> resPrint ;
2013-04-01 20:15:52 +02:00
2016-08-17 15:40:17 +02:00
$sql .= $db -> order ( $sortfield , $sortorder );
2013-06-23 22:30:33 +02:00
2016-08-17 15:40:17 +02:00
// Count total nb of records
2017-01-15 20:49:20 +01:00
$nbtotalofrecords = '' ;
2016-08-17 15:40:17 +02:00
if ( empty ( $conf -> global -> MAIN_DISABLE_FULL_SCANLIST ))
2016-03-03 10:05:40 +01:00
{
2016-08-17 15:40:17 +02:00
$result = $db -> query ( $sql );
$nbtotalofrecords = $db -> num_rows ( $result );
2018-04-24 11:37:57 +02:00
if (( $page * $limit ) > $nbtotalofrecords ) // if total resultset is smaller then paging size (filtering), goto and load page 0
{
$page = 0 ;
$offset = 0 ;
}
2016-03-03 10:05:40 +01:00
}
2013-06-23 22:30:33 +02:00
2016-08-17 15:40:17 +02:00
$sql .= $db -> plimit ( $limit + 1 , $offset );
$result = $db -> query ( $sql );
if ( ! $result ) dol_print_error ( $db );
2013-06-23 22:30:33 +02:00
2016-08-17 15:40:17 +02:00
$num = $db -> num_rows ( $result );
2016-09-10 19:53:32 +02:00
2018-03-01 15:24:50 +01:00
$arrayofselected = is_array ( $toselect ) ? $toselect : array ();
$param = '' ;
2016-09-10 19:53:32 +02:00
if ( ! empty ( $contextpage ) && $contextpage != $_SERVER [ " PHP_SELF " ]) $param .= '&contextpage=' . $contextpage ;
if ( $limit > 0 && $limit != $conf -> liste_limit ) $param .= '&limit=' . $limit ;
2018-03-01 15:24:50 +01:00
if ( $search_status ) $param .= '&search_status=' . $search_status ;
2016-09-10 19:53:32 +02:00
if ( $search_label ) $param .= '&search_label=' . $search_label ;
if ( $optioncss != '' ) $param .= '&optioncss=' . $optioncss ;
// Add $param from extra fields
2017-11-27 15:24:29 +01:00
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_param.tpl.php' ;
2016-08-17 15:40:17 +02:00
2016-09-10 19:53:32 +02:00
$stringcurrentdate = $langs -> trans ( " CurrentHour " ) . ': ' . dol_print_date ( dol_now (), 'dayhour' );
if ( $action == 'delete' )
{
2018-02-27 20:16:20 +01:00
print $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . " ?id= " . $id . $param , $langs -> trans ( " CronDelete " ), $langs -> trans ( " CronConfirmDelete " ), " confirm_delete " , '' , '' , 1 );
2016-09-10 19:53:32 +02:00
}
if ( $action == 'execute' )
{
2018-02-27 20:16:20 +01:00
print $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . " ?id= " . $id . '&securitykey=' . $securitykey . $param , $langs -> trans ( " CronExecute " ), $langs -> trans ( " CronConfirmExecute " ), " confirm_execute " , '' , '' , 1 );
2016-09-10 19:53:32 +02:00
}
2018-03-01 12:53:40 +01:00
// List of mass actions available
$arrayofmassactions = array (
//'presend'=>$langs->trans("SendByMail"),
//'builddoc'=>$langs->trans("PDFMerge"),
2018-03-21 20:15:21 +01:00
'enable' => $langs -> trans ( " CronStatusActiveBtn " ),
'disable' => $langs -> trans ( " CronStatusInactiveBtn " ),
2018-03-01 12:53:40 +01:00
);
if ( $user -> rights -> mymodule -> delete ) $arrayofmassactions [ 'predelete' ] = $langs -> trans ( " Delete " );
if ( in_array ( $massaction , array ( 'presend' , 'predelete' ))) $arrayofmassactions = array ();
$massactionbutton = $form -> selectMassAction ( '' , $arrayofmassactions );
2016-09-10 19:53:32 +02:00
2018-03-01 12:53:40 +01:00
print '<form method="POST" id="searchFormList" action="' . $_SERVER [ " PHP_SELF " ] . '" name="search_form">' . " \n " ;
2016-09-10 19:53:32 +02:00
if ( $optioncss != '' ) print '<input type="hidden" name="optioncss" value="' . $optioncss . '">' ;
print '<input type="hidden" name="token" value="' . $_SESSION [ 'newtoken' ] . '">' ;
2018-03-01 12:53:40 +01:00
print '<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">' ;
2016-09-10 19:53:32 +02:00
print '<input type="hidden" name="action" value="list">' ;
print '<input type="hidden" name="sortfield" value="' . $sortfield . '">' ;
print '<input type="hidden" name="sortorder" value="' . $sortorder . '">' ;
2017-05-21 02:43:51 +02:00
print '<input type="hidden" name="page" value="' . $page . '">' ;
2018-03-01 12:53:40 +01:00
print '<input type="hidden" name="contextpage" value="' . $contextpage . '">' ;
print '<input type="hidden" name="search_status" value="' . $search_status . '" >' ;
2016-09-10 19:53:32 +02:00
print '<input type="hidden" name="viewstatut" value="' . $viewstatut . '">' ;
// Line with explanation and button new job
2018-04-15 17:37:49 +02:00
$newcardbutton = '' ;
if ( $user -> rights -> cron -> create )
2016-09-10 19:53:32 +02:00
{
2018-06-13 22:57:41 +02:00
$newcardbutton .= '<a class="butActionNew" style="margin-right: 0px;margin-left: 0px;" href="' . DOL_URL_ROOT . '/cron/card.php?action=create"><span class="valignmiddle">' . $langs -> trans ( " CronCreateJob " ) . '</span>' ;
2018-04-18 03:26:15 +02:00
$newcardbutton .= '<span class="fa fa-plus-circle valignmiddle"></span>' ;
$newcardbutton .= '</a>' ;
2016-09-10 19:53:32 +02:00
}
else
{
2018-06-13 22:57:41 +02:00
$newcardbutton .= '<a class="butActionNewRefused" href="#" title="' . dol_escape_htmltag ( $langs -> transnoentitiesnoconv ( " NotEnoughPermissions " )) . '"><span class="valignmiddle">' . $langs -> trans ( " CronCreateJob " ) . '</span>' ;
2018-04-18 03:26:15 +02:00
$newcardbutton .= '<span class="fa fa-plus-circle valignmiddle"></span>' ;
$newcardbutton .= '</a>' ;
2016-09-10 19:53:32 +02:00
}
2016-09-20 12:51:09 +02:00
2018-04-15 16:35:18 +02:00
print_barre_liste ( $pagetitle , $page , $_SERVER [ " PHP_SELF " ], $param , $sortfield , $sortorder , $massactionbutton , $num , $nbtotalofrecords , 'title_setup' , 0 , $newcardbutton , '' , $limit );
2016-09-20 12:51:09 +02:00
2018-09-04 00:29:31 +02:00
print '<span class="opacitymedium">' . $langs -> trans ( 'CronInfo' ) . '</span><br>' ;
2017-05-12 19:14:54 +02:00
$text = $langs -> trans ( " HoursOnThisPageAreOnServerTZ " ) . ' ' . $stringcurrentdate . '<br>' ;
if ( ! empty ( $conf -> global -> CRON_WARNING_DELAY_HOURS )) $text .= $langs -> trans ( " WarningCronDelayed " , $conf -> global -> CRON_WARNING_DELAY_HOURS );
print info_admin ( $text );
2016-09-10 19:53:32 +02:00
print '<br>' ;
2018-02-22 12:15:11 +01:00
$varpage = empty ( $contextpage ) ? $_SERVER [ " PHP_SELF " ] : $contextpage ;
2018-03-01 15:24:50 +01:00
$selectedfields = '' ;
2018-02-22 12:15:11 +01:00
//$selectedfields=$form->multiSelectArrayWithCheckbox('selectedfields', $arrayfields, $varpage); // This also change content of $arrayfields
2018-03-01 15:24:50 +01:00
$selectedfields .= ( count ( $arrayofmassactions ) ? $form -> showCheckAddButtons ( 'checkforselect' , 1 ) : '' );
2016-09-10 19:53:32 +02:00
2017-01-17 20:04:41 +01:00
print '<div class="div-table-responsive">' ;
2017-03-28 13:22:11 +02:00
print '<table class="noborder">' ;
2016-09-10 19:53:32 +02:00
2017-03-28 13:22:11 +02:00
print '<tr class="liste_titre_filter">' ;
2016-12-11 16:11:42 +01:00
print '<td class="liste_titre"> </td>' ;
2016-09-10 19:53:32 +02:00
print '<td class="liste_titre">' ;
print '<input type="text" class="flat" name="search_label" value="' . $search_label . '" size="10">' ;
print '</td>' ;
2016-12-11 16:11:42 +01:00
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
print '<td class="liste_titre"> </td>' ;
2018-02-27 19:53:03 +01:00
print '<td class="liste_titre"> </td>' ;
2016-09-10 19:53:32 +02:00
print '<td class="liste_titre" align="center">' ;
2018-03-01 12:53:40 +01:00
print $form -> selectarray ( 'search_status' , array ( '0' => $langs -> trans ( " Disabled " ), '1' => $langs -> trans ( " Enabled " ), '-2' => $langs -> trans ( " EnabledAndDisabled " ), '2' => $langs -> trans ( " Archived " )), $search_status , 1 );
2016-09-10 19:53:32 +02:00
print '</td><td class="liste_titre" align="right">' ;
2018-02-28 19:36:04 +01:00
$searchpicto = $form -> showFilterButtons ();
print $searchpicto ;
2016-09-10 19:53:32 +02:00
print '</td>' ;
print '</tr>' ;
2017-03-28 13:22:11 +02:00
print '<tr class="liste_titre">' ;
2017-08-02 13:31:53 +02:00
print_liste_field_titre ( " ID " , $_SERVER [ " PHP_SELF " ], " t.rowid " , " " , $param , '' , $sortfield , $sortorder );
print_liste_field_titre ( " CronLabel " , $_SERVER [ " PHP_SELF " ], " t.label " , " " , $param , '' , $sortfield , $sortorder );
2018-02-27 19:53:03 +01:00
print_liste_field_titre ( " Prority " , $_SERVER [ " PHP_SELF " ], " t.priority " , " " , $param , '' , $sortfield , $sortorder );
2017-08-02 13:31:53 +02:00
print_liste_field_titre ( " CronTask " , '' , '' , " " , $param , '' , $sortfield , $sortorder );
print_liste_field_titre ( " CronFrequency " , '' , " " , " " , $param , '' , $sortfield , $sortorder );
print_liste_field_titre ( " CronDtStart " , $_SERVER [ " PHP_SELF " ], " t.datestart " , " " , $param , 'align="center"' , $sortfield , $sortorder );
print_liste_field_titre ( " CronDtEnd " , $_SERVER [ " PHP_SELF " ], " t.dateend " , " " , $param , 'align="center"' , $sortfield , $sortorder );
print_liste_field_titre ( " CronMaxRun " , $_SERVER [ " PHP_SELF " ], " t.maxrun " , " " , $param , 'align="right"' , $sortfield , $sortorder );
print_liste_field_titre ( " CronNbRun " , $_SERVER [ " PHP_SELF " ], " t.nbrun " , " " , $param , 'align="right"' , $sortfield , $sortorder );
print_liste_field_titre ( " CronDtLastLaunch " , $_SERVER [ " PHP_SELF " ], " t.datelastrun " , " " , $param , 'align="center"' , $sortfield , $sortorder );
print_liste_field_titre ( " CronLastResult " , $_SERVER [ " PHP_SELF " ], " t.lastresult " , " " , $param , 'align="center"' , $sortfield , $sortorder );
print_liste_field_titre ( " CronLastOutput " , $_SERVER [ " PHP_SELF " ], " t.lastoutput " , " " , $param , '' , $sortfield , $sortorder );
2017-08-21 12:24:58 +02:00
print_liste_field_titre ( " CronDtNextLaunch " , $_SERVER [ " PHP_SELF " ], " t.datenextrun " , " " , $param , 'align="center"' , $sortfield , $sortorder );
2018-02-27 20:04:29 +01:00
print_liste_field_titre ( " Status " , $_SERVER [ " PHP_SELF " ], " t.status,t.priority " , " " , $param , 'align="center"' , $sortfield , $sortorder );
2018-03-01 15:24:50 +01:00
print_liste_field_titre ( $selectedfields , $_SERVER [ " PHP_SELF " ], " " , " " , $param , 'align="center"' , $sortfield , $sortorder , 'maxwidthsearch ' );
2017-03-28 13:22:11 +02:00
print " </tr> \n " ;
2016-09-10 19:53:32 +02:00
if ( $num > 0 )
{
2015-12-19 02:38:11 +01:00
// Loop on each job
2015-08-31 12:13:23 +02:00
$style = 'pair' ;
2016-08-17 15:40:17 +02:00
$now = dol_now ();
$i = 0 ;
$totalarray = array ();
while ( $i < min ( $num , $limit ))
2013-04-17 16:26:14 +02:00
{
2016-08-17 15:40:17 +02:00
$obj = $db -> fetch_object ( $result );
2017-07-13 00:35:10 +02:00
2017-08-03 11:01:43 +02:00
if ( empty ( $obj )) break ;
2016-08-17 15:40:17 +02:00
if ( ! verifCond ( $obj -> test )) continue ; // Discard line with test = false
2017-07-13 00:35:10 +02:00
2018-02-22 12:15:11 +01:00
$object -> id = $obj -> rowid ;
$object -> ref = $obj -> rowid ;
$object -> label = $obj -> label ;
2018-02-27 20:04:29 +01:00
$object -> status = $obj -> status ;
2018-02-27 19:53:03 +01:00
$object -> priority = $obj -> priority ;
2018-02-22 12:15:11 +01:00
2017-07-26 10:11:39 +02:00
print '<tr class="oddeven">' ;
2013-03-26 21:18:01 +01:00
2018-02-27 19:53:03 +01:00
// Ref
2016-01-31 15:37:23 +01:00
print '<td class="nowrap">' ;
2018-02-22 12:15:11 +01:00
print $object -> getNomUrl ( 1 );
2015-06-04 12:57:49 +02:00
print '</td>' ;
2018-02-27 19:53:03 +01:00
// Label
2015-06-04 12:57:49 +02:00
print '<td>' ;
2016-08-17 15:40:17 +02:00
if ( ! empty ( $obj -> label ))
2015-06-04 12:57:49 +02:00
{
2018-02-27 19:37:29 +01:00
$object -> ref = $langs -> trans ( $obj -> label );
2018-02-22 12:15:11 +01:00
print $object -> getNomUrl ( 0 , '' , 1 );
$object -> ref = $obj -> rowid ;
2013-03-26 21:18:01 +01:00
}
2015-06-04 12:57:49 +02:00
else
{
2015-12-19 02:38:11 +01:00
//print $langs->trans('CronNone');
2013-03-22 17:10:17 +01:00
}
print '</td>' ;
2013-03-26 21:18:01 +01:00
2018-02-27 19:53:03 +01:00
// Priority
print '<td class="right">' ;
print $object -> priority ;
print '</td>' ;
2013-03-22 17:10:17 +01:00
print '<td>' ;
2016-08-17 15:40:17 +02:00
if ( $obj -> jobtype == 'method' )
2015-06-04 12:57:49 +02:00
{
2016-01-19 23:45:03 +01:00
$text = $langs -> trans ( " CronClass " );
2016-08-17 15:40:17 +02:00
$texttoshow = $langs -> trans ( 'CronModule' ) . ': ' . $obj -> module_name . '<br>' ;
$texttoshow .= $langs -> trans ( 'CronClass' ) . ': ' . $obj -> classesname . '<br>' ;
$texttoshow .= $langs -> trans ( 'CronObject' ) . ': ' . $obj -> objectname . '<br>' ;
$texttoshow .= $langs -> trans ( 'CronMethod' ) . ': ' . $obj -> methodename ;
$texttoshow .= '<br>' . $langs -> trans ( 'CronArgs' ) . ': ' . $obj -> params ;
$texttoshow .= '<br>' . $langs -> trans ( 'Comment' ) . ': ' . $langs -> trans ( $obj -> note );
2016-01-19 23:45:03 +01:00
}
2017-07-13 00:35:10 +02:00
elseif ( $obj -> jobtype == 'command' )
2016-01-19 23:45:03 +01:00
{
$text = $langs -> trans ( 'CronCommand' );
2016-08-17 15:40:17 +02:00
$texttoshow = $langs -> trans ( 'CronCommand' ) . ': ' . dol_trunc ( $obj -> command );
$texttoshow .= '<br>' . $langs -> trans ( 'CronArgs' ) . ': ' . $obj -> params ;
$texttoshow .= '<br>' . $langs -> trans ( 'Comment' ) . ': ' . $langs -> trans ( $obj -> note );
2013-03-22 17:10:17 +01:00
}
2016-03-25 15:24:57 +01:00
print $form -> textwithpicto ( $text , $texttoshow , 1 );
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2016-01-19 23:45:03 +01:00
print '<td>' ;
2016-08-17 15:40:17 +02:00
if ( $obj -> unitfrequency == " 60 " ) print $langs -> trans ( 'CronEach' ) . " " . ( $obj -> frequency ) . " " . $langs -> trans ( 'Minutes' );
if ( $obj -> unitfrequency == " 3600 " ) print $langs -> trans ( 'CronEach' ) . " " . ( $obj -> frequency ) . " " . $langs -> trans ( 'Hours' );
if ( $obj -> unitfrequency == " 86400 " ) print $langs -> trans ( 'CronEach' ) . " " . ( $obj -> frequency ) . " " . $langs -> trans ( 'Days' );
if ( $obj -> unitfrequency == " 604800 " ) print $langs -> trans ( 'CronEach' ) . " " . ( $obj -> frequency ) . " " . $langs -> trans ( 'Weeks' );
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2015-12-19 03:27:55 +01:00
print '<td class="center">' ;
2017-05-12 18:32:13 +02:00
if ( ! empty ( $obj -> datestart )) { print dol_print_date ( $db -> jdate ( $obj -> datestart ), 'dayhour' );}
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2015-12-19 03:27:55 +01:00
print '<td class="center">' ;
2017-05-12 18:32:13 +02:00
if ( ! empty ( $obj -> dateend )) { print dol_print_date ( $db -> jdate ( $obj -> dateend ), 'dayhour' );}
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2015-12-19 03:27:55 +01:00
print '<td align="right">' ;
2016-08-17 15:40:17 +02:00
if ( ! empty ( $obj -> maxrun )) { print $obj -> maxrun ;}
2015-12-19 03:27:55 +01:00
print '</td>' ;
2017-07-13 00:35:10 +02:00
2015-12-19 03:27:55 +01:00
print '<td align="right">' ;
2016-08-17 15:40:17 +02:00
if ( ! empty ( $obj -> nbrun )) { print $obj -> nbrun ;} else { print '0' ;}
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2015-12-19 03:27:55 +01:00
print '<td class="center">' ;
2017-05-12 18:32:13 +02:00
if ( ! empty ( $obj -> datelastrun )) { print dol_print_date ( $db -> jdate ( $obj -> datelastrun ), 'dayhour' );}
2015-12-19 02:38:11 +01:00
print '</td>' ;
2015-12-19 03:27:55 +01:00
print '<td class="center">' ;
2018-05-01 19:51:53 +02:00
if ( $obj -> lastresult != '' ) {
if ( empty ( $obj -> lastresult )) print $obj -> lastresult ;
else print '<span class="error">' . dol_trunc ( $obj -> lastresult ) . '</div>' ;
}
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2013-03-22 17:10:17 +01:00
print '<td>' ;
2016-08-17 15:40:17 +02:00
if ( ! empty ( $obj -> lastoutput )) { print dol_trunc ( nl2br ( $obj -> lastoutput ), 50 );}
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2017-08-21 12:24:58 +02:00
print '<td class="center">' ;
2018-09-18 23:39:49 +02:00
if ( ! empty ( $obj -> datenextrun )) {
$datenextrun = $db -> jdate ( $obj -> datenextrun );
2018-06-16 23:51:30 +02:00
if ( empty ( $obj -> status )) print '<span class="opacitymedium">' ;
2018-09-18 23:45:22 +02:00
print dol_print_date ( $datenextrun , 'dayhoursec' );
if ( $obj -> status == Cronjob :: STATUS_ENABLED )
{
if ( $obj -> maxrun && $obj -> nbrun >= $obj -> maxrun ) print img_warning ( $langs -> trans ( " MaxRunReached " ));
elseif ( $datenextrun && $datenextrun < $now ) print img_warning ( $langs -> trans ( " Late " ));
}
2018-09-18 23:39:49 +02:00
if ( empty ( $obj -> status )) print '</span>' ;
2018-06-16 23:51:30 +02:00
}
2017-08-21 12:24:58 +02:00
print '</td>' ;
2015-06-04 12:57:49 +02:00
// Status
2013-03-26 21:18:01 +01:00
print '<td align="center">' ;
2018-02-27 20:04:29 +01:00
print $object -> getLibStatut ( 3 );
2013-04-17 16:26:14 +02:00
print '</td>' ;
2018-02-28 19:36:04 +01:00
print '<td align="right" class="nowraponall">' ;
2018-05-27 15:53:18 +02:00
$backtourl = urlencode ( $_SERVER [ " PHP_SELF " ] . '?' . $param . ( $sortfield ? '&sortfield=' . $sortfield : '' ) . ( $sortorder ? '&sortorder=' . $sortorder : '' ));
2016-01-19 23:45:03 +01:00
if ( $user -> rights -> cron -> create )
{
2018-05-27 15:53:18 +02:00
print " <a href= \" " . DOL_URL_ROOT . " /cron/card.php?id= " . $obj -> rowid . " &action=edit " . ( $sortfield ? '&sortfield=' . $sortfield : '' ) . ( $sortorder ? '&sortorder=' . $sortorder : '' ) . $param ;
print " &backtourl= " . $backtourl . " \" title= \" " . dol_escape_htmltag ( $langs -> trans ( 'Edit' )) . " \" > " . img_picto ( $langs -> trans ( 'Edit' ), 'edit' ) . " </a> " ;
2016-01-19 23:45:03 +01:00
}
2015-06-04 12:57:49 +02:00
if ( $user -> rights -> cron -> delete )
{
2018-05-27 15:53:18 +02:00
print " <a href= \" " . $_SERVER [ " PHP_SELF " ] . " ?id= " . $obj -> rowid . " &action=delete " . ( $sortfield ? '&sortfield=' . $sortfield : '' ) . ( $sortorder ? '&sortorder=' . $sortorder : '' ) . $param ;
print " \" title= \" " . dol_escape_htmltag ( $langs -> trans ( 'CronDelete' )) . " \" > " . img_picto ( $langs -> trans ( 'CronDelete' ), 'delete' ) . " </a> " ;
2013-03-22 17:10:17 +01:00
} else {
2015-06-04 12:57:49 +02:00
print " <a href= \" # \" title= \" " . dol_escape_htmltag ( $langs -> trans ( 'NotEnoughPermissions' )) . " \" > " . img_picto ( $langs -> trans ( 'NotEnoughPermissions' ), 'delete' ) . " </a> " ;
2013-03-22 17:10:17 +01:00
}
2015-06-04 12:57:49 +02:00
if ( $user -> rights -> cron -> execute )
{
2018-03-21 13:16:05 +01:00
if ( ! empty ( $obj -> status )) print '<a href="' . $_SERVER [ " PHP_SELF " ] . '?id=' . $obj -> rowid . '&action=execute' . ( empty ( $conf -> global -> CRON_KEY ) ? '' : '&securitykey=' . $conf -> global -> CRON_KEY ) . ( $sortfield ? '&sortfield=' . $sortfield : '' ) . ( $sortorder ? '&sortorder=' . $sortorder : '' ) . $param . " \" title= \" " . dol_escape_htmltag ( $langs -> trans ( 'CronExecute' )) . " \" > " . img_picto ( $langs -> trans ( 'CronExecute' ), " play " ) . '</a>' ;
else print '<a href="#" class="cursordefault" title="' . dol_escape_htmltag ( $langs -> trans ( 'JobDisabled' )) . '">' . img_picto ( $langs -> trans ( 'JobDisabled' ), " playdisabled " ) . '</a>' ;
2013-03-22 17:10:17 +01:00
} else {
2018-03-21 13:16:05 +01:00
print '<a href="#" class="cursornotallowed" title="' . dol_escape_htmltag ( $langs -> trans ( 'NotEnoughPermissions' )) . '">' . img_picto ( $langs -> trans ( 'NotEnoughPermissions' ), " playdisabled " ) . '</a>' ;
2013-03-22 17:10:17 +01:00
}
2018-03-01 15:24:50 +01:00
if ( $massactionbutton || $massaction ) // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
{
$selected = 0 ;
if ( in_array ( $obj -> rowid , $arrayofselected )) $selected = 1 ;
2018-03-21 13:16:05 +01:00
print ' <input id="cb' . $obj -> rowid . '" class="flat checkforselect valignmiddle" type="checkbox" name="toselect[]" value="' . $obj -> rowid . '"' . ( $selected ? ' checked="checked"' : '' ) . '>' ;
2018-03-01 15:24:50 +01:00
}
2013-03-22 17:10:17 +01:00
print '</td>' ;
2013-03-26 21:18:01 +01:00
2013-03-22 17:10:17 +01:00
print '</tr>' ;
2017-07-13 00:35:10 +02:00
2016-08-17 15:40:17 +02:00
$i ++ ;
2013-03-22 17:10:17 +01:00
}
}
2013-06-23 22:30:33 +02:00
else
{
2016-09-10 19:53:32 +02:00
print '<tr><td colspan="9" class="opacitymedium">' . $langs -> trans ( 'CronNoJobs' ) . '</td></tr>' ;
2013-06-23 22:30:33 +02:00
}
print '</table>' ;
2017-01-17 20:04:41 +01:00
print '</div>' ;
2013-06-23 22:30:33 +02:00
2013-06-24 17:36:33 +02:00
print '</from>' ;
2013-06-23 22:30:33 +02:00
2016-03-03 10:05:40 +01:00
print '<br><br>' ;
2013-03-22 17:10:17 +01:00
2013-06-23 22:21:21 +02:00
dol_print_cron_urls ();
2013-03-22 17:10:17 +01:00
llxFooter ();
2013-03-27 13:24:26 +01:00
$db -> close ();