2012-10-23 Ramon Novoa <rnovoa@artica.es>
* include/functions_cron.php: Added to repository. Cron related
functions.
* include/functions_html.php, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
godmode/agentes/module_manager_editor_common.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/module_manager_editor.php: Added support for remote
cron modules.
* godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
operation/netflow/nf_view.php,
include/functions_netflow.php: Added a description to report items.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7083 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-23 12:45:25 +02:00
|
|
|
<?php
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* PHP Linux cron functions.
|
|
|
|
*
|
|
|
|
* @package Linux cron functions.
|
|
|
|
* @subpackage Backend functions.
|
|
|
|
*
|
|
|
|
* Pandora FMS- http://pandorafms.com
|
|
|
|
* ==================================================
|
|
|
|
* Copyright (c) 20012 Artica Soluciones Tecnologicas
|
|
|
|
* Please see http://pandorafms.org for full contribution list
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public License
|
|
|
|
* as published by the Free Software Foundation; version 2
|
|
|
|
* 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.
|
|
|
|
*/
|
2012-10-23 Ramon Novoa <rnovoa@artica.es>
* include/functions_cron.php: Added to repository. Cron related
functions.
* include/functions_html.php, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
godmode/agentes/module_manager_editor_common.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/module_manager_editor.php: Added support for remote
cron modules.
* godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
operation/netflow/nf_view.php,
include/functions_netflow.php: Added a description to report items.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7083 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-23 12:45:25 +02:00
|
|
|
|
|
|
|
global $config;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_db.php';
|
2012-10-23 Ramon Novoa <rnovoa@artica.es>
* include/functions_cron.php: Added to repository. Cron related
functions.
* include/functions_html.php, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
godmode/agentes/module_manager_editor_common.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/module_manager_editor.php: Added support for remote
cron modules.
* godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
operation/netflow/nf_view.php,
include/functions_netflow.php: Added a description to report items.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7083 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-23 12:45:25 +02:00
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the execution interval of the given module
|
|
|
|
*
|
|
|
|
* @param integer $module_id Id of module to update.
|
|
|
|
* @param string $cron String with the Linux cron configuration.
|
|
|
|
*
|
|
|
|
* @return boolean Return number of rows affected.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_update_module_interval($module_id, $cron)
|
|
|
|
{
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check for a valid cron.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!cron_check_syntax($cron)) {
|
2019-03-29 15:06:26 +01:00
|
|
|
return false;
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2019-03-29 15:06:26 +01:00
|
|
|
$module_interval = db_get_value(
|
|
|
|
'module_interval',
|
|
|
|
'tagente_modulo',
|
|
|
|
'id_agente_modulo',
|
|
|
|
$module_id
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($cron === '* * * * *') {
|
2019-02-22 12:53:35 +01:00
|
|
|
return db_process_sql(
|
|
|
|
'UPDATE tagente_estado SET current_interval = '.$module_interval.' WHERE id_agente_modulo = '.(int) $module_id
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
return db_process_sql(
|
|
|
|
'UPDATE tagente_estado SET current_interval = '.cron_next_execution($cron, $module_interval, $module_id).' WHERE id_agente_modulo = '.(int) $module_id
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-10-23 Ramon Novoa <rnovoa@artica.es>
* include/functions_cron.php: Added to repository. Cron related
functions.
* include/functions_html.php, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
godmode/agentes/module_manager_editor_common.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/module_manager_editor.php: Added support for remote
cron modules.
* godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
operation/netflow/nf_view.php,
include/functions_netflow.php: Added a description to report items.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7083 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-23 12:45:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Get the number of seconds left to the next execution of the given cron entry.
|
|
|
|
*
|
|
|
|
* @param string $cron String with the Linux cron configuration.
|
|
|
|
* @param integer $module_interval Module interval. Minimum increased time.
|
|
|
|
* @param integer $module_id Module id.
|
|
|
|
*
|
|
|
|
* @return integer Time to next execution time.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_next_execution($cron, $module_interval, $module_id)
|
|
|
|
{
|
2019-02-22 12:53:35 +01:00
|
|
|
// Get day of the week and month from cron config.
|
2019-01-30 16:18:44 +01:00
|
|
|
$cron_array = explode(' ', $cron);
|
|
|
|
$wday = $cron_array[4];
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Get last execution time.
|
|
|
|
$last_execution = db_get_value(
|
|
|
|
'utimestamp',
|
|
|
|
'tagente_estado',
|
|
|
|
'id_agente_modulo',
|
|
|
|
$module_id
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
$cur_time = ($last_execution !== false) ? $last_execution : time();
|
2019-04-04 15:04:23 +02:00
|
|
|
$nex_time = cron_next_execution_date($cron, $cur_time, $module_interval);
|
|
|
|
$nex_wday = (int) date('w', $nex_time);
|
2019-04-05 12:32:43 +02:00
|
|
|
// Check the wday values to avoid infinite loop.
|
|
|
|
$wday_int = cron_get_interval($wday);
|
|
|
|
if ($wday_int['down'] !== '*' && ($wday_int['down'] > 6 || ($wday_int['up'] !== false && $wday_int['up'] > 6))) {
|
|
|
|
$wday = '*';
|
|
|
|
}
|
2019-04-04 15:04:23 +02:00
|
|
|
|
|
|
|
// Check day of the way.
|
|
|
|
while (!cron_check_interval($nex_wday, $wday)) {
|
|
|
|
// If it does not acomplish the day of the week, go to the next day.
|
|
|
|
$nex_time += SECONDS_1DAY;
|
|
|
|
$nex_time = cron_next_execution_date($cron, $nex_time, 0);
|
|
|
|
$nex_wday = (int) date('w', $nex_time);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2019-04-04 15:04:23 +02:00
|
|
|
return ($nex_time - $cur_time);
|
2012-10-23 Ramon Novoa <rnovoa@artica.es>
* include/functions_cron.php: Added to repository. Cron related
functions.
* include/functions_html.php, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
godmode/agentes/module_manager_editor_common.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/module_manager_editor.php: Added support for remote
cron modules.
* godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
operation/netflow/nf_view.php,
include/functions_netflow.php: Added a description to report items.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7083 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-23 12:45:25 +02:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Get the next execution date for the given cron entry in seconds since epoch.
|
|
|
|
*
|
|
|
|
* @param string $cron String with the Linux cron configuration.
|
|
|
|
* @param integer $cur_time Current time in utimestamp.
|
|
|
|
* @param integer $module_interval Module interval. Minimum increased time.
|
|
|
|
*
|
|
|
|
* @return integer Next execution timestamp seing the cron configuration.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_next_execution_date($cron, $cur_time=false, $module_interval=300)
|
|
|
|
{
|
2019-02-22 12:53:35 +01:00
|
|
|
// Get cron configuration.
|
2019-01-30 16:18:44 +01:00
|
|
|
$cron_array = explode(' ', $cron);
|
|
|
|
|
|
|
|
// REMARKS: Months start from 1 in php (different to server)
|
2019-02-22 12:53:35 +01:00
|
|
|
// Get current time.
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($cur_time === false) {
|
|
|
|
$cur_time = time();
|
|
|
|
}
|
|
|
|
|
|
|
|
$nex_time = ($cur_time + $module_interval);
|
|
|
|
$nex_time_array = explode(' ', date('i H d m Y', $nex_time));
|
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array)) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update minutes.
|
2019-04-04 15:04:23 +02:00
|
|
|
$nex_time_array[0] = cron_get_next_time_element($cron_array[0]);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time >= $cur_time) {
|
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check if next hour is in cron.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[1]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
|
|
|
|
if ($nex_time === false) {
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the month day if overflow.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[1] = 0;
|
|
|
|
$nex_time_array[2]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time === false) {
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the month if overflow.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[2] = 1;
|
|
|
|
$nex_time_array[3]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time === false) {
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the year if overflow.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[3] = 1;
|
|
|
|
$nex_time_array[4]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check the hour.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the hour if fails.
|
2019-04-04 15:04:23 +02:00
|
|
|
$nex_time_array[1] = cron_get_next_time_element($cron_array[1]);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// When an overflow is passed check the hour update again.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time >= $cur_time) {
|
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check if next day is in cron.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[2]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time === false) {
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the month if overflow.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[2] = 1;
|
|
|
|
$nex_time_array[3]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time === false) {
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the year if overflow.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[3] = 1;
|
|
|
|
$nex_time_array[4]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check the day.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the day if fails.
|
2019-04-04 15:04:23 +02:00
|
|
|
$nex_time_array[2] = cron_get_next_time_element($cron_array[2]);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// When an overflow is passed check the hour update in the next execution.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time >= $cur_time) {
|
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check if next month is in cron.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[3]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time === false) {
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the year if overflow.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[3] = 1;
|
|
|
|
$nex_time_array[4]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Check the month.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the month if fails.
|
2019-04-04 15:04:23 +02:00
|
|
|
$nex_time_array[3] = cron_get_next_time_element($cron_array[3]);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// When an overflow is passed check the hour update in the next execution.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
if ($nex_time >= $cur_time) {
|
|
|
|
if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
|
|
|
|
return $nex_time;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Update the year.
|
2019-01-30 16:18:44 +01:00
|
|
|
$nex_time_array[4]++;
|
|
|
|
$nex_time = cron_valid_date($nex_time_array);
|
|
|
|
|
|
|
|
return ($nex_time !== false) ? $nex_time : $module_interval;
|
2017-11-23 12:30:04 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Get the next tentative time for a cron value or interval in case of overflow.
|
|
|
|
*
|
|
|
|
* @param string $cron_array_elem Cron element.
|
|
|
|
*
|
|
|
|
* @return integer The tentative time. Ex:
|
|
|
|
* * shold returns 0.
|
|
|
|
* 5 should returns 5.
|
|
|
|
* 10-55 should returns 10.
|
|
|
|
* 55-10 should retunrs 0.
|
|
|
|
*/
|
2019-04-04 15:04:23 +02:00
|
|
|
function cron_get_next_time_element($cron_array_elem)
|
|
|
|
{
|
|
|
|
$interval = cron_get_interval($cron_array_elem);
|
|
|
|
$value = ($interval['down'] == '*' || ($interval['up'] !== false && $interval['down'] > $interval['up'] )) ? 0 : $interval['down'];
|
|
|
|
return $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Get an array with the cron interval.
|
|
|
|
*
|
|
|
|
* @param string $element String with the elemen cron configuration.
|
|
|
|
*
|
|
|
|
* @return array With up and down elements.
|
|
|
|
* If there is not an interval, up element will be false.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_get_interval($element)
|
|
|
|
{
|
2019-02-22 12:53:35 +01:00
|
|
|
// Not a range.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!preg_match('/(\d+)\-(\d+)/', $element, $capture)) {
|
|
|
|
return [
|
|
|
|
'down' => $element,
|
|
|
|
'up' => false,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
|
|
|
'down' => $capture[1],
|
|
|
|
'up' => $capture[2],
|
|
|
|
];
|
2017-11-23 12:30:04 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Returns if a date is in a cron. Recursive.
|
|
|
|
*
|
|
|
|
* @param array $elems_cron Cron configuration in array format.
|
|
|
|
* @param integer $elems_curr_time Time to check if is in cron.
|
|
|
|
*
|
|
|
|
* @return boolean Returns true if is in cron. False if it is outside.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_is_in_cron($elems_cron, $elems_curr_time)
|
|
|
|
{
|
|
|
|
$elem_cron = array_shift($elems_cron);
|
|
|
|
$elem_curr_time = array_shift($elems_curr_time);
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// If there is no elements means that is in cron.
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($elem_cron === null || $elem_curr_time === null) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
// Go to last element if current is a wild card.
|
2019-04-04 15:04:23 +02:00
|
|
|
if (cron_check_interval($elem_curr_time, $elem_cron) === false) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return cron_is_in_cron($elems_cron, $elems_curr_time);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if an element is inside the cron interval or not.
|
|
|
|
*
|
|
|
|
* @param integer $elem_curr_time Integer that represents the time to check.
|
|
|
|
* @param string $elem_cron Cron interval (splitted by hypen)
|
|
|
|
* or cron single value (a number).
|
|
|
|
*
|
|
|
|
* @return boolean True if is in interval.
|
|
|
|
*/
|
|
|
|
function cron_check_interval($elem_curr_time, $elem_cron)
|
|
|
|
{
|
|
|
|
// Go to last element if current is a wild card.
|
|
|
|
if ($elem_cron === '*') {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$elem_s = cron_get_interval($elem_cron);
|
|
|
|
// Check if there is no a range.
|
|
|
|
if (($elem_s['up'] === false) && ($elem_s['down'] != $elem_curr_time)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if there is on the range.
|
|
|
|
if ($elem_s['up'] !== false && (int) $elem_s['up'] === (int) $elem_curr_time) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($elem_s['down'] < $elem_s['up']) {
|
|
|
|
if ($elem_curr_time < $elem_s['down'] || $elem_curr_time > $elem_s['up']) {
|
2019-01-30 16:18:44 +01:00
|
|
|
return false;
|
|
|
|
}
|
2019-04-04 15:04:23 +02:00
|
|
|
} else {
|
|
|
|
if ($elem_curr_time > $elem_s['down'] || $elem_curr_time < $elem_s['up']) {
|
|
|
|
return false;
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-04 15:04:23 +02:00
|
|
|
return true;
|
2017-11-23 12:30:04 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Check if a date is correct or not.
|
|
|
|
*
|
|
|
|
* @param array $da Date in array format [year, month, day, hour, minutes].
|
|
|
|
*
|
|
|
|
* @return integer Utimestamp. False if date is incorrect.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_valid_date($da)
|
|
|
|
{
|
2019-02-22 12:53:35 +01:00
|
|
|
$st = sprintf(
|
|
|
|
'%04d:%02d:%02d %02d:%02d:00',
|
|
|
|
$da[4],
|
|
|
|
$da[3],
|
|
|
|
$da[2],
|
|
|
|
$da[1],
|
|
|
|
$da[0]
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
$time = strtotime($st);
|
|
|
|
return $time;
|
2012-10-23 Ramon Novoa <rnovoa@artica.es>
* include/functions_cron.php: Added to repository. Cron related
functions.
* include/functions_html.php, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql,
godmode/agentes/module_manager_editor_common.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/module_manager_editor.php: Added support for remote
cron modules.
* godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
operation/netflow/nf_view.php,
include/functions_netflow.php: Added a description to report items.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7083 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-23 12:45:25 +02:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Check if cron is properly constructed.
|
|
|
|
*
|
|
|
|
* @param string $cron String with the Linux cron configuration.
|
|
|
|
*
|
|
|
|
* @return boolean True if is well formed. False otherwise.
|
|
|
|
*/
|
2019-01-30 16:18:44 +01:00
|
|
|
function cron_check_syntax($cron)
|
|
|
|
{
|
2019-02-22 12:53:35 +01:00
|
|
|
return preg_match(
|
|
|
|
'/^[\d|\*].* .*[\d|\*].* .*[\d|\*].* .*[\d|\*].* .*[\d|\*]$/',
|
|
|
|
$cron
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-04 15:30:30 +02:00
|
|
|
/**
|
|
|
|
* Cron list table.
|
|
|
|
*
|
|
|
|
* @return void It prints the HTML table.
|
|
|
|
*/
|
2019-02-22 12:53:35 +01:00
|
|
|
function cron_list_table()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$read_perms = check_acl($config['id_user'], 0, 'RR');
|
|
|
|
$write_perms = check_acl($config['id_user'], 0, 'RW');
|
|
|
|
$manage_perms = check_acl($config['id_user'], 0, 'RM');
|
|
|
|
$manage_pandora = check_acl($config['id_user'], 0, 'PM');
|
|
|
|
|
|
|
|
$url = 'index.php?extension_in_menu=gservers&sec=extensions&sec2=enterprise/extensions/cron&';
|
|
|
|
|
|
|
|
$user_groups = implode(
|
|
|
|
',',
|
|
|
|
array_keys(users_get_groups())
|
|
|
|
);
|
|
|
|
|
|
|
|
$defined_tasks = db_get_all_rows_filter(
|
|
|
|
'tuser_task_scheduled',
|
|
|
|
'id_grupo IN ('.$user_groups.')'
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!check_acl($config['id_user'], 0, 'PM')) {
|
|
|
|
$read_tasks = [];
|
|
|
|
foreach ($defined_tasks as $task) {
|
|
|
|
$function_name = db_get_value(
|
|
|
|
'function_name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
|
|
|
|
if (($function_name != 'cron_task_execute_custom_script')
|
|
|
|
&& ($function_name != 'cron_task_do_backup')
|
|
|
|
) {
|
|
|
|
$read_tasks[] = $task;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$defined_tasks = $read_tasks;
|
|
|
|
|
|
|
|
if (empty($defined_tasks)) {
|
|
|
|
$defined_tasks = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($defined_tasks !== false) {
|
|
|
|
echo '<h2>'.__('Scheduled jobs').'</h2>';
|
|
|
|
|
|
|
|
$table = new stdClass();
|
|
|
|
$table->class = 'databox data';
|
|
|
|
$table->width = '100%';
|
|
|
|
$table->data = [];
|
|
|
|
$table->head = [];
|
|
|
|
$table->head[0] = '';
|
|
|
|
$table->head[1] = __('User');
|
|
|
|
$table->head[2] = __('Task');
|
|
|
|
$table->head[3] = __('Scheduled');
|
|
|
|
$table->head[4] = __('Next execution');
|
|
|
|
$table->head[5] = __('Last run');
|
|
|
|
$table->head[6] = __('Group');
|
|
|
|
$table->head[7] = __('Actions');
|
|
|
|
$table->align[7] = 'left';
|
|
|
|
|
|
|
|
foreach ($defined_tasks as $task) {
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$function_name = db_get_value(
|
|
|
|
'function_name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
|
|
|
|
switch ($function_name) {
|
2021-05-24 17:35:15 +02:00
|
|
|
case 'cron_task_generate_csv_log':
|
|
|
|
case 'cron_task_call_user_function':
|
|
|
|
// Ignore.
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_console_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
|
|
|
|
if ($function_name === 'cron_task_call_user_function') {
|
|
|
|
$data[2] .= ' ('.$args['function_name'].')';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
case 'cron_task_generate_report':
|
|
|
|
if ($write_perms || $manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
$report = reports_get_report($args[0]);
|
|
|
|
|
|
|
|
// Check ACL in reports_get_report return false.
|
|
|
|
if ($report === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$email = $args[1];
|
2019-03-20 11:32:25 +01:00
|
|
|
$report_type = $args[4];
|
2019-02-22 12:53:35 +01:00
|
|
|
$data[2] .= '<br>- '.__('Report').": <a href='index.php?sec=reporting&sec2=operation/reporting/reporting_viewer&id=".$args[0]."'>";
|
|
|
|
$data[2] .= $report['name'].'</a>';
|
2019-03-20 11:32:25 +01:00
|
|
|
$data[2] .= '<br>- '.__('Report type').': '.$report_type;
|
2019-02-22 12:53:35 +01:00
|
|
|
$data[2] .= '<br>- '.__('Email').": <a href='mailto:".$email."'>";
|
|
|
|
$data[2] .= ui_print_truncate_text($email, 60, false).'</a>';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cron_task_generate_report_by_template':
|
|
|
|
if ($write_perms || $manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
|
|
|
|
$filter = [];
|
|
|
|
$filter['id_report'] = $args[0];
|
|
|
|
$template = db_get_row_filter(
|
|
|
|
'treport_template',
|
|
|
|
$filter,
|
|
|
|
false
|
|
|
|
);
|
|
|
|
|
|
|
|
// Check ACL in reports_get_report return false.
|
|
|
|
if ($template === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2021-06-11 15:54:04 +02:00
|
|
|
if (empty($args[1]) === false && (string) $args[1] !== '0') {
|
2021-05-17 13:31:46 +02:00
|
|
|
$agents_id = $args[1];
|
|
|
|
} else {
|
|
|
|
if (empty($args[2]) === false) {
|
|
|
|
$agents_id = sprintf(
|
|
|
|
'(%s) %s',
|
|
|
|
__('regex'),
|
|
|
|
$args[2]
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$agents_id = __('None');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-21 15:41:14 +02:00
|
|
|
$report_type = $args[7];
|
2021-06-11 15:54:04 +02:00
|
|
|
$report_per_agent = $args[3];
|
2021-05-17 13:31:46 +02:00
|
|
|
$report_name = $args[4];
|
|
|
|
$email = $args[5];
|
2020-01-09 17:56:34 +01:00
|
|
|
$data[2] .= '<br>- '.__('Template').': ';
|
|
|
|
$data[2] .= '<a href="'.ui_get_full_url('index.php?sec=reporting&sec2=enterprise/godmode/reporting/reporting_builder.template&action=edit&id_template='.$args[0]).'">';
|
|
|
|
$data[2] .= $template['name'].'</a>';
|
2020-03-10 17:23:19 +01:00
|
|
|
$data[2] .= '<br>- '.__('Agents').': '.ui_print_truncate_text($agents_id, 120).'</a>';
|
2019-02-22 12:53:35 +01:00
|
|
|
$data[2] .= '<br>- '.__('Report per agent').': '.$report_per_agent.'</a>';
|
|
|
|
$data[2] .= '<br>- '.__('Report name').': '.$report_name.'</a>';
|
|
|
|
$data[2] .= '<br>- '.__('Email').": <a href='mailto:".$email."'>".$email.'</a>';
|
2021-06-21 15:41:14 +02:00
|
|
|
$data[2] .= '<br>- '.__('Report type').': '.$report_type;
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cron_task_execute_custom_script':
|
|
|
|
if ($manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
$data[2] .= '<br>- '.__('Custom script').': '.$args[0];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cron_task_save_report_to_disk':
|
|
|
|
if ($write_perms || $manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
$report = reports_get_report($args[0]);
|
|
|
|
|
|
|
|
// Check ACL in reports_get_report return false.
|
|
|
|
if ($report === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$path = $args[1];
|
|
|
|
$data[2] .= '<br>- '.__('Report').": <a href='index.php?sec=reporting&sec2=operation/reporting/reporting_viewer";
|
|
|
|
$data[2] .= '&id='.$args[0]."'>".$report['name'].'</a>';
|
|
|
|
$data[2] .= '<br>- '.__('Path').': '.$path.'</a>';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cron_task_save_xml_report_to_disk':
|
|
|
|
if ($write_perms || $manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value('name', 'tuser_task', 'id', $task['id_user_task']);
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
$report = reports_get_report($args[0]);
|
|
|
|
|
|
|
|
// Check ACL in reports_get_report return false.
|
|
|
|
if ($report === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$path = $args[1];
|
2021-01-25 11:51:53 +01:00
|
|
|
$report_type = $args[3];
|
2019-02-22 12:53:35 +01:00
|
|
|
$data[2] .= '<br>- '.__('Report').": <a href='index.php?sec=reporting&sec2=operation/reporting/reporting_viewer";
|
|
|
|
$data[2] .= '&id='.$args[0]."'>".$report['name'].'</a>';
|
|
|
|
$data[2] .= '<br>- '.__('Path').': '.$path.'</a>';
|
2021-01-25 11:51:53 +01:00
|
|
|
$data[2] .= '<br>- '.__('Report type').': '.$report_type;
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cron_task_do_backup':
|
|
|
|
if ($manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
2021-03-16 11:31:43 +01:00
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'cron_task_generate_csv_log':
|
|
|
|
if ($manage_pandora) {
|
|
|
|
$data[0] = '<a href="'.$url;
|
|
|
|
$data[0] .= 'force_run=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[0] .= html_print_image(
|
|
|
|
'images/target.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Force run'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$data[0] .= '</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = $task['id_usuario'];
|
|
|
|
$data[2] = db_get_value(
|
2019-02-22 12:53:35 +01:00
|
|
|
'name',
|
|
|
|
'tuser_task',
|
|
|
|
'id',
|
|
|
|
$task['id_user_task']
|
|
|
|
);
|
|
|
|
$args = unserialize($task['args']);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
// Ignore.
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[3] = cron_get_scheduled_string($task['scheduled']);
|
|
|
|
$data[4] = date('Y/m/d H:i:s', $args['first_execution']);
|
|
|
|
$data[5] = empty($task['last_run']) ? __('Never') : date('Y/m/d H:i:s', $task['last_run']);
|
|
|
|
|
|
|
|
$data[6] = ui_print_group_icon($task['id_grupo'], true);
|
|
|
|
|
|
|
|
if ($function_name == 'cron_task_do_backup' || $function_name == 'cron_task_execute_custom_script') {
|
|
|
|
if ($manage_pandora) {
|
|
|
|
$data[7] = '<a href="'.$url;
|
|
|
|
$data[7] .= 'edit_task=1&id='.$task['id'].'">';
|
|
|
|
$data[7] .= html_print_image(
|
|
|
|
'images/config.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Edit'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[7] .= '</a>';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($manage_pandora) {
|
|
|
|
$data[7] .= '<a href="'.$url;
|
|
|
|
$data[7] .= 'delete_task=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[7] .= html_print_image(
|
|
|
|
'images/cross.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Delete'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[7] .= '</a>';
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ($write_perms || $manage_pandora) {
|
|
|
|
$data[7] = '<a href="'.$url;
|
|
|
|
$data[7] .= 'edit_task=1&id='.$task['id'].'">';
|
|
|
|
$data[7] .= html_print_image(
|
|
|
|
'images/config.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Edit'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[7] .= '</a>';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($manage_perms || $manage_pandora) {
|
|
|
|
$data[7] .= '<a href="'.$url;
|
|
|
|
$data[7] .= 'delete_task=1&id_user_task='.$task['id'].'">';
|
|
|
|
$data[7] .= html_print_image(
|
|
|
|
'images/cross.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Delete'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
2019-02-22 12:53:35 +01:00
|
|
|
);
|
|
|
|
$data[7] .= '</a>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
array_push($table->data, $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
}
|
2016-02-05 09:53:45 +01:00
|
|
|
}
|