"container"]); echo UI::h('h1', [], [ UI::h('a', ['href'=>"index.php"], "SE"), " » ", " Status systemu procesy5" ]); try { DB::getPDO(); if ($postTask = V::get('_postTask', '', $_REQUEST)) { DBG::log($args, 'array', "exec '{$postTask}'"); if (!method_exists($this, "{$postTask}PostTask")) throw new Exception("Post Task not exists!"); ob_start(); $this->{"{$postTask}PostTask"}($args); $outputPostTask = ob_get_clean(); if ($outputPostTask) { echo UI::h('details', [], [ UI::h('summary', [], "Wynik '{$postTask}' (rozwiń)"), $outputPostTask, ]); } } $this->viewStatusDatabase(); if (in_array(User::get('ADM_ADMIN_LEVEL'), ['0', '1'])) { $this->viewStatusUsers(); } // UI::table([ // 'caption' => 'Baza danych', // 'rows' => DB::getPDO()->fetchAll(" SHOW VARIABLES ") // ]); } catch (Exception $e) { UI::alert('danger', $e->getMessage()); } UI::endTag('div');// .container UI::dol(); } public function viewStatusDatabase() { $dbEvents = DB::getPDO()->fetchFirst(" SHOW VARIABLES WHERE VARIABLE_NAME = 'event_scheduler' "); // DBG::nicePrint($dbEvents, '$dbEvents'); // [Variable_name] => event_scheduler // [Value] => ON $aclObjectCacheExists = false; $objectStorage = SchemaFactory::loadDefaultObject('SystemObject'); $aclCacheTableName = $objectStorage->getRootTableName(); if ($aclCacheTableName) { try { $totalObjects = DB::getPDO()->fetchValue("select count(*) as cnt from `{$aclCacheTableName}`"); if ($totalObjects > 0) $aclObjectCacheExists = true; } catch (Exception $e) { DBG::log($e); } } DBG::log($objectStorage, 'array', "\$objectStorage"); DBG::log($objectStorage->getRootTableName(), 'array', "\$objectStorage->getRootTableName()"); UI::table([ 'caption' => UI::h('b', ['style' => "color:#000"], 'Baza danych'), 'rows' => [ [ 'nazwa' => "Event Scheduler (generowanie Grafika, itp.)", 'wartość' => ('ON' == $dbEvents['Value']) ? UI::h('span', ['class' => "label label-success"], "ON") : UI::h('span', ['class' => "label label-danger"], "OFF"), '#' => UI::hButtonPost("Włącz", [ 'class' => "btn btn-xs btn-default", 'data' => [ '_postTask' => 'fixEventSheduler', ] ]) ], [ 'nazwa' => "System obiektów (xsd)", 'wartość' => ($aclObjectCacheExists) ? UI::h('span', ['class' => "label label-success"], "ON") : UI::h('span', ['class' => "label label-danger"], "OFF"), '#' => UI::hButtonPost("Aktualizuj cache", [ 'class' => "btn btn-xs btn-default", 'data' => [ '_postTask' => 'updateObjectCache' ] ]) ], ] ]); } public function fixEventShedulerPostTask() { DB::getPDO()->execSql(" SET GLOBAL event_scheduler='ON' "); } public function updateObjectCachePostTask() { DBG::log("updateObjectCachePostTask..."); SchemaFactory::loadDefaultObject('SystemObject')->updateCache(); SchemaFactory::loadDefaultObject('SystemObjectField')->updateCache(); UI::alert('info', "Lista obiketów zaktualizowana"); } public function viewStatusUsers() { $nowMinus3Months = date("Y-m-d", mktime(0,0,0, date('m') - 1, date('d'), date('Y'))); $sesUsers = DB::getPDO()->fetchAll(" select c.ID, c.CONF_KEY, c.CONF_VAL from CRM_CONFIG c where c.CONF_KEY like 'acl_user_%_%_cache_update' and c.CONF_VAL > '{$nowMinus3Months}' "); $sesUsers = array_reduce( $sesUsers, function ($ret, $record) { // $format = "acl_user_{ID_USERS}_{ID_PROCES}_cache_update"; list($idUser, $idProces) = explode('_', substr($record['CONF_KEY'], strlen('acl_user_'), -1 * strlen('_cache_update'))); if (!array_key_exists($idUser, $ret)) { $ret[$idUser] = [ 'idUser' => $idUser, 'lastUpdateAclCache' => $record['CONF_VAL'], 'log' => [] ]; } else { $ret[$idUser]['lastUpdateAclCache'] = ($record['CONF_VAL'] > $ret[$idUser]['lastUpdateAclCache']) ? $record['CONF_VAL'] : $ret[$idUser]['lastUpdateAclCache']; } $ret[$idUser]['log'][] = [ 'ID_PROCES' => $idProces, 'data' => $record['CONF_VAL'] ]; return $ret; }, [] ); $sesUsers = array_map(function ($sesGroup) { return [ 'idUser' => $sesGroup['idUser'], 'user' => DB::getPDO()->fetchValue("select u.ADM_ACCOUNT from ADMIN_USERS u where u.ID = {$sesGroup['idUser']}"), 'lastUpdateAclCache' => $sesGroup['lastUpdateAclCache'], 'log' => UI::h('span', [ 'style' => "color:#bbb" ], implode('
', array_map(function ($log) { return ($log['ID_PROCES'] > 0) ? "Filtr procesu {$log['ID_PROCES']} uruchomiony {$log['data']}" : "Filtr ogólny uruchomiony {$log['data']}"; }, $sesGroup['log']))), ]; }, $sesUsers); usort($sesUsers, function ($ua, $ub) { $a = $ua['lastUpdateAclCache']; $b = $ub['lastUpdateAclCache']; return ($a === $b) ? 0 : ( ($a < $b) ? 1 : -1 ) ; }); if ('0' == User::get('ADM_ADMIN_LEVEL')) { $sesUsers = array_map(function ($row) { $row['#'] = UI::h('div', [ 'style' => "display:inline-block", 'class' => "activateUserDebugBtn" . ( DBG::hasUserDebug($row['idUser'], User::getID()) ? ' active' : '' ) ], [ UI::h('label', ['style' => "padding-right:6px; font-weight:normal"], "Debug"), UI::hButtonAjax("Włącz", "activateUserDebug", [ 'class' => "btn btn-xs btn-default activateUserDebugBtn-activate", 'href' => $this->getLink('startUserDebugAjax'), 'data' => [ 'idUser' => $row['idUser'], 'do' => 'activate' ] ]), UI::hButtonAjax("Wyłącz", "activateUserDebug", [ 'class' => "btn btn-xs btn-default activateUserDebugBtn-deactivate", 'href' => $this->getLink('startUserDebugAjax'), 'data' => [ 'idUser' => $row['idUser'], 'do' => 'deactivate' ] ]), ]); return $row; }, $sesUsers); } UI::table([ 'caption' => UI::h('b', ['style' => "color:#000"], "Ostatnie logowania do aplikacji") . " (update acl cache)", // TODO: Aktualnie zalogowani użytkownicy 'rows' => $sesUsers ]); echo UI::h('style', ['type' => "text/css"], " .activateUserDebugBtn .activateUserDebugBtn-activate { display:inline } .activateUserDebugBtn .activateUserDebugBtn-deactivate { display:none } .activateUserDebugBtn.active .activateUserDebugBtn-activate { display:none } .activateUserDebugBtn.active .activateUserDebugBtn-deactivate { display:inline } "); echo UI::h('script', ['src'=>"static/vendor.js?_v=b636cab1", 'type'=>"text/javascript"]); echo UI::h('script', [], " (function (global) { if (!global.p5VendorJs.React) throw 'Missing p5VendorJs.React' if (!global.p5VendorJs.ReactDOM) throw 'Missing p5VendorJs.ReactDOM' if (!global.p5VendorJs.ToggleButton) throw 'Missing p5VendorJs.ToggleButton' if (!global.fetch) throw 'Missing global.fetch' var React = global.p5VendorJs.React var ReactDOM = global.p5VendorJs.ReactDOM var h = React.createElement function convertToReactToggle(n, activateBtn, deactivateBtn, isActive) { var toggleReact = document.createElement('div') toggleReact.style.display = 'inline-block' n.parentNode.insertBefore(toggleReact, n.nextSibling) deactivateBtn.style.display = 'none' activateBtn.style.display = 'none' function reactToggleBtnOnToggle(value) { if (value) { deactivateBtn.onclick() } else { activateBtn.onclick() } render_reactToggleBtn(!value) } function render_reactToggleBtn(state) { ReactDOM.render( h(global.p5VendorJs.ToggleButton, { value: state, onToggle: reactToggleBtnOnToggle }) , toggleReact ) } render_reactToggleBtn(isActive) } var toggles = document.querySelectorAll('.activateUserDebugBtn') for (var i = 0; i < toggles.length; i++) { var btns = toggles[i].querySelectorAll('a') if (2 !== btns.length) contiune; var activateBtn = btns[0] var deactivateBtn = btns[1] convertToReactToggle(toggles[i], activateBtn, deactivateBtn, toggles[i].classList.contains('active')) } })(window) "); UI::hButtonAjaxOnResponse("activateUserDebug", /* payload, n */ " p5UI__notifyAjaxCallback(payload) // console.log('activateUserDebug :: payload', payload) if ('success' !== payload.type) return false if (payload.body && 'active' in payload.body) { if (payload.body.active) { n.parentNode.classList.add('active') } else { n.parentNode.classList.remove('active') } } "); } public function startUserDebugAjaxAction() { Response::sendTryCatchJson(array($this, 'startUserDebugAjax'), $_POST); } public function startUserDebugAjax($args) { if ('0' !== (string)User::get('ADM_ADMIN_LEVEL')) throw new Exception("Access Denied"); $idUser = V::get('idUser', 0, $args); if ($idUser <= 0) throw new Exception("Missing idUser"); $do = V::get('do', 0, $args); if (!in_array($do, ['activate', 'deactivate'])) throw new Exception("Missing do"); $hasDebug = DBG::hasUserDebug($idUser, User::getID()); switch ($do) { case 'activate': DBG::startUserDebug($idUser, User::getID()); break; case 'deactivate': DBG::stopUserDebug($idUser, User::getID()); break; } return [ 'type' => 'success', '__args' => $args, '__$hasDebug' => $hasDebug, 'body' => [ 'active' => DBG::hasUserDebug($idUser, User::getID()) ] ]; } }