From 4a9b88468a9dff79dc0da423a9b58a3cc5cc6159 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Mon, 14 Jan 2019 15:26:04 +0100 Subject: [PATCH] moving all logic to admin_cmd::get_rows and only leave session stuff in admin_cmds::get_rows --- admin/inc/class.admin_cmd.inc.php | 48 ++++++++++++++++++++++++++++- admin/inc/class.admin_cmds.inc.php | 49 +----------------------------- 2 files changed, 48 insertions(+), 49 deletions(-) diff --git a/admin/inc/class.admin_cmd.inc.php b/admin/inc/class.admin_cmd.inc.php index 06d5b9e801..8bc24b9409 100644 --- a/admin/inc/class.admin_cmd.inc.php +++ b/admin/inc/class.admin_cmd.inc.php @@ -510,7 +510,53 @@ abstract class admin_cmd } unset($query['col_filter']['periodic']); - return admin_cmd::$sql->get_rows($query,$rows,$readonlys); + $total = admin_cmd::$sql->get_rows($query,$rows,$readonlys); + + if (!$rows) return 0; + + $async = new Api\Asyncservice(); + foreach($rows as &$row) + { + try { + $cmd = admin_cmd::instanciate($row); + $row['title'] = $cmd->__tostring(); // we call __tostring explicit, as a cast to string requires php5.2+ + } + catch (Exception $e) { + $row['title'] = $e->getMessage(); + } + + $row['value'] = $cmd->value; + + if(method_exists($cmd, 'summary')) + { + $row['data'] = $cmd->summary(); + } + else + { + $row['data'] = !($data = json_php_unserialize($row['data'])) ? '' : + json_encode($data+(empty($row['rrule'])?array():array('rrule' => $row['rrule'])), + JSON_PRETTY_PRINT|JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES); + } + if($row['rrule']) + { + $rrule = calendar_rrule::event2rrule(calendar_rrule::parseRrule($row['rrule'],true)+array( + 'start' => time(), + 'tzid'=> Api\DateTime::$server_timezone->getName() + )); + $row['rrule'] = ''.$rrule; + } + if(!$row['scheduled'] && $cmd && $cmd->async_job_id) + { + $job = $async->read($cmd->async_job_id); + + $row['scheduled'] = $job ? $job[$cmd->async_job_id]['next'] : null; + } + if ($row['status'] == admin_cmd::scheduled) + { + $row['class'] = 'AllowDelete'; + } + } + return $total; } /** diff --git a/admin/inc/class.admin_cmds.inc.php b/admin/inc/class.admin_cmds.inc.php index 4503b506bd..e40f6a0501 100644 --- a/admin/inc/class.admin_cmds.inc.php +++ b/admin/inc/class.admin_cmds.inc.php @@ -34,54 +34,7 @@ class admin_cmds { Api\Cache::setSession('admin', 'cmds', $query); - $total = admin_cmd::get_rows($query,$rows,$readonlys); - - if (!$rows) return array(); - - $async = new Api\Asyncservice(); - foreach($rows as &$row) - { - try { - $cmd = admin_cmd::instanciate($row); - $row['title'] = $cmd->__tostring(); // we call __tostring explicit, as a cast to string requires php5.2+ - } - catch (Exception $e) { - $row['title'] = $e->getMessage(); - } - - $row['value'] = $cmd->value; - - if(method_exists($cmd, 'summary')) - { - $row['data'] = $cmd->summary(); - } - else - { - $row['data'] = !($data = json_php_unserialize($row['data'])) ? '' : - json_encode($data+(empty($row['rrule'])?array():array('rrule' => $row['rrule'])), - JSON_PRETTY_PRINT|JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES); - } - if($row['rrule']) - { - $rrule = calendar_rrule::event2rrule(calendar_rrule::parseRrule($row['rrule'],true)+array( - 'start' => time(), - 'tzid'=> Api\DateTime::$server_timezone->getName() - )); - $row['rrule'] = ''.$rrule; - } - if(!$row['scheduled'] && $cmd && $cmd->async_job_id) - { - $job = $async->read($cmd->async_job_id); - - $row['scheduled'] = $job ? $job[$cmd->async_job_id]['next'] : null; - } - if ($row['status'] == admin_cmd::scheduled) - { - $row['class'] = 'AllowDelete'; - } - } - //_debug_array($rows); - return $total; + return admin_cmd::get_rows($query,$rows,$readonlys); } /**