rework token, "fixed" gitmodules, saimods rework, split log & analytics, minor fixes
This commit is contained in:
parent
2330445e74
commit
070eea2fdd
5
.gitmodules
vendored
5
.gitmodules
vendored
@ -54,7 +54,4 @@
|
||||
url = ../lib_jstree.git
|
||||
[submodule "lib/font_awesome"]
|
||||
path = lib/font_awesome
|
||||
url = gogs@webcraft-media.de:webcraft/lib_font_awesome.git
|
||||
[submodule "lib/popper"]
|
||||
path = lib/popper
|
||||
url = D:\\sources\\web\\test\\democracy\\lib\\system\\lib\\popper
|
||||
url = ../lib_font_awesome.git
|
||||
|
||||
@ -81,4 +81,7 @@ class JsonResult{
|
||||
*/
|
||||
public static function fail(){
|
||||
return self::toString(NULL,false);}
|
||||
|
||||
public static function status($status){
|
||||
return $status ? self::ok() : self::fail();}
|
||||
}
|
||||
@ -35,7 +35,7 @@ class State {
|
||||
$vars = array();
|
||||
for($i=1;$i<count($state_vars);$i++){
|
||||
$var = \explode('.',$state_vars[$i]);
|
||||
$vars[$var[0]] = \urlencode($var[1]);}
|
||||
$vars[$var[0]] = \urlencode(implode('.',array_slice($var,1)));}
|
||||
$result = array();
|
||||
$res = \SYSTEM\SQL\SYS_PAGE_GROUP::QQ(array($group,$state_name));
|
||||
while($row = $res->next()){
|
||||
|
||||
@ -3,6 +3,7 @@ SYSTEM\autoload::registerFolder(dirname(__FILE__),'SYSTEM\SAI');
|
||||
//System Start Mod
|
||||
require_once dirname(__FILE__).'/saistart_sys_sai/autoload.inc';
|
||||
//System Mod
|
||||
require_once dirname(__FILE__).'/saimod_sys_analytics/autoload.inc';
|
||||
require_once dirname(__FILE__).'/saimod_sys_log/autoload.inc';
|
||||
//require_once dirname(__FILE__).'/saimod_sys_security/autoload.inc';
|
||||
//require_once dirname(__FILE__).'/saimod_sys_mod/autoload.inc';
|
||||
|
||||
5
sai/modules/saimod_sys_analytics/autoload.inc
Normal file
5
sai/modules/saimod_sys_analytics/autoload.inc
Normal file
@ -0,0 +1,5 @@
|
||||
<?php
|
||||
\SYSTEM\autoload::registerFolder(dirname(__FILE__),'SYSTEM\SAI');
|
||||
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/qq/','SYSTEM\SQL');
|
||||
|
||||
\SYSTEM\SAI\sai::register('\SYSTEM\SAI\saimod_sys_analytics');
|
||||
84
sai/modules/saimod_sys_analytics/js/saimod_sys_analytics.js
Normal file
84
sai/modules/saimod_sys_analytics/js/saimod_sys_analytics.js
Normal file
@ -0,0 +1,84 @@
|
||||
google.load("visualization", "1", {packages:["corechart"]});
|
||||
function init_saimod_sys_analytics() {
|
||||
$('#tabs_analytics a').click(function (e) {
|
||||
$('#tabs_analytics li a').each(function(){
|
||||
$(this).removeClass('active');});
|
||||
$(this).addClass('active');
|
||||
});
|
||||
load_visualisation();
|
||||
$('#vis_filter_time').change(function(){
|
||||
load_visualisation();})
|
||||
$('#vis_filter_type').change(function(){
|
||||
load_visualisation();})
|
||||
$('#tabs_analytics a').click(function (e) {
|
||||
e.preventDefault();
|
||||
load_visualisation();
|
||||
});
|
||||
$('#tabs_analytics li').each(function(){
|
||||
$(this).removeClass('active');});
|
||||
$('#menu_stats').parent().addClass('active');
|
||||
};
|
||||
|
||||
function load_visualisation(){
|
||||
var name = $('#vis_filter_type').val();;
|
||||
var filter = $('#vis_filter_time').val();
|
||||
var db = $('#tabs_analytics a.active').attr('db');
|
||||
/*$.getJSON('./sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log&action=stats&name='+name+'&filter='+filter+'&db='+db,function(json){
|
||||
|
||||
});*/
|
||||
$.ajax({
|
||||
async: true,
|
||||
url: this.endpoint,
|
||||
type: 'GET',
|
||||
dataType: 'JSON',
|
||||
data: {
|
||||
sai_mod: '.SYSTEM.SAI.saimod_sys_analytics',
|
||||
action: 'stats',
|
||||
name: name,
|
||||
filter: filter,
|
||||
db: db
|
||||
},
|
||||
success: function(data){
|
||||
if(data.status){
|
||||
var json = data.result;
|
||||
var gdata = new google.visualization.DataTable();
|
||||
first = true;
|
||||
$.each(json[0], function(key, value){
|
||||
if(first){
|
||||
gdata.addColumn('datetime',key);
|
||||
first = false;
|
||||
} else {
|
||||
gdata.addColumn('number',key);
|
||||
}
|
||||
});
|
||||
$.each(json, function(key, value){
|
||||
first = true;
|
||||
gdata.addRow($.map(value, function(v) {
|
||||
if(first){
|
||||
first=false;
|
||||
return [new Date(v)];
|
||||
} else {
|
||||
return [(v == null || parseFloat(v) <= 0) ? parseFloat(0) : parseFloat(v)];
|
||||
}
|
||||
}));
|
||||
});
|
||||
|
||||
var options = { title: name,
|
||||
aggregationTarget: 'category',
|
||||
selectionMode: 'multiple',
|
||||
curveType: 'function',
|
||||
/*focusTarget: 'category',*/
|
||||
chartArea: {left:100,top:40},
|
||||
vAxis: {logScale: true},
|
||||
interpolateNulls: false,
|
||||
width: "1200",
|
||||
height: "500"};
|
||||
new google.visualization.LineChart(document.getElementById('vis')).draw(gdata, options);
|
||||
}
|
||||
$('img#loader').hide();
|
||||
},
|
||||
error: function(){
|
||||
alert('Something happend - try again!');
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -0,0 +1,56 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_ANALYTICS extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 1;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 1;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,60 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - basic querytime
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_BASIC_QUERYTIME extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'avg('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_avg,'
|
||||
.'max('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_max,'
|
||||
.'min('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_min,'
|
||||
.'variance('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_var'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'avg('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_avg,'
|
||||
.'max('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_max,'
|
||||
.'min('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_min,'
|
||||
.'variance('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_var'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,85 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - basic success
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_BASIC_SUCCESS extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\COUNTER\' and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\INFO\' and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'INFO\' and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\DEPRECATED\' and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'DEPRECATED\' and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\WARNING\' and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'PreprocessingLog\' '
|
||||
.'then 1 else 0 end) class_fail,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\COUNTER\' or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\INFO\' or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'INFO\' or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\DEPRECATED\' or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'DEPRECATED\' or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\WARNING\' or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'PreprocessingLog\' '
|
||||
.'then 1 else 0 end) class_log,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\COUNTER\' then 1 else 0 end) class_sucess'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\COUNTER" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\INFO" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "INFO" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\DEPRECATED" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "DEPRECATED" and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\WARNING" and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "PreprocessingLog" '
|
||||
.'then 1 else 0 end) class_fail,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\INFO" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "INFO" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\DEPRECATED" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "DEPRECATED" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\WARNING" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "PreprocessingLog" '
|
||||
.'then 1 else 0 end) class_log,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\COUNTER" then 1 else 0 end) class_sucess'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,56 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - basic visitor
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_BASIC_VISITOR extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,62 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - class basic
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_CLASS_BASIC extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ERROR\' then 1 else 0 end) class_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'WARNING\' then 1 else 0 end) class_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'INFO\' then 1 else 0 end) class_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'DEPRECATED\' then 1 else 0 end) class_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'AppError\' then 1 else 0 end) class_AppError'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ERROR\' then 1 else 0 end) class_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'WARNING\' then 1 else 0 end) class_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'INFO\' then 1 else 0 end) class_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'DEPRECATED\' then 1 else 0 end) class_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'AppError\' then 1 else 0 end) class_AppError'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,58 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - class other
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_CLASS_OTHER extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'Exception\' then 1 else 0 end) class_Exception,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'RuntimeException\' then 1 else 0 end) class_RuntimeException,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ErrorException\' then 1 else 0 end) class_ErrorException'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'Exception\' then 1 else 0 end) class_Exception,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'RuntimeException\' then 1 else 0 end) class_RuntimeException,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ErrorException\' then 1 else 0 end) class_ErrorException'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,66 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - class system
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_CLASS_SYSTEM extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\COUNTER\' then 1 else 0 end) class_SYSTEM_LOG_COUNTER,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\INFO\' then 1 else 0 end) class_SYSTEM_LOG_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\DEPRECATED\' then 1 else 0 end) class_SYSTEM_LOG_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\WARNING\' then 1 else 0 end) class_SYSTEM_LOG_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\ERROR\' then 1 else 0 end) class_SYSTEM_LOG_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\ERROR_EXCEPTION\' then 1 else 0 end) class_SYSTEM_LOG_ERROR_EXCEPTION,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'SYSTEM\LOG\SHUTDOWN_EXCEPTION\' then 1 else 0 end) class_SYSTEM_LOG_SHUTDOWN_EXCEPTION'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\COUNTER" then 1 else 0 end) class_SYSTEM_LOG_COUNTER,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\INFO" then 1 else 0 end) class_SYSTEM_LOG_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\DEPRECATED" then 1 else 0 end) class_SYSTEM_LOG_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\WARNING" then 1 else 0 end) class_SYSTEM_LOG_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\ERROR" then 1 else 0 end) class_SYSTEM_LOG_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\ERROR_EXCEPTION" then 1 else 0 end) class_SYSTEM_LOG_ERROR_EXCEPTION,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\\\LOG\\\\SHUTDOWN_EXCEPTION" then 1 else 0 end) class_SYSTEM_LOG_SHUTDOWN_EXCEPTION'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
50
sai/modules/saimod_sys_analytics/qq/SYS_SAIMOD_LOG_ERROR.php
Normal file
50
sai/modules/saimod_sys_analytics/qq/SYS_SAIMOD_LOG_ERROR.php
Normal file
@ -0,0 +1,50 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get data for a system_log entry
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_ERROR extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT * FROM '.\SYSTEM\SQL\system_log::NAME_PG.
|
||||
' LEFT JOIN '.\SYSTEM\SQL\system_user::NAME_PG.
|
||||
' ON '.\SYSTEM\SQL\system_log::NAME_PG.'.'.\SYSTEM\SQL\system_log::FIELD_USER.
|
||||
' = '.\SYSTEM\SQL\system_user::NAME_PG.'.'.\SYSTEM\SQL\system_user::FIELD_ID.
|
||||
' WHERE '.\SYSTEM\SQL\system_log::NAME_PG.'."'.\SYSTEM\SQL\system_log::FIELD_ID.'" = $1;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT * FROM '.\SYSTEM\SQL\system_log::NAME_MYS.
|
||||
' LEFT JOIN '.\SYSTEM\SQL\system_user::NAME_MYS.
|
||||
' ON '.\SYSTEM\SQL\system_log::NAME_MYS.'.'.\SYSTEM\SQL\system_log::FIELD_USER.
|
||||
' = '.\SYSTEM\SQL\system_user::NAME_MYS.'.'.\SYSTEM\SQL\system_user::FIELD_ID.
|
||||
' WHERE '.\SYSTEM\SQL\system_log::NAME_MYS.'.'.\SYSTEM\SQL\system_log::FIELD_ID.' = ?;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,60 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to filter data from system_log
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_FILTER extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT * FROM '.\SYSTEM\SQL\system_log::NAME_PG.
|
||||
' LEFT JOIN '.\SYSTEM\SQL\system_user::NAME_PG.
|
||||
' ON '.\SYSTEM\SQL\system_log::NAME_PG.'.'.\SYSTEM\SQL\system_log::FIELD_USER.
|
||||
' = '.\SYSTEM\SQL\system_user::NAME_PG.'.'.\SYSTEM\SQL\system_user::FIELD_ID.
|
||||
' WHERE '.\SYSTEM\SQL\system_log::FIELD_CLASS.' LIKE $1'.
|
||||
' AND ('.\SYSTEM\SQL\system_log::FIELD_MESSAGE.' LIKE $2'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_FILE.' LIKE $3'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_IP.' LIKE $4'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.' LIKE $5'.')'.
|
||||
' ORDER BY '.\SYSTEM\SQL\system_log::FIELD_TIME.' DESC, '.\SYSTEM\SQL\system_log::NAME_PG.'."'.\SYSTEM\SQL\system_log::FIELD_ID.'" DESC;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT * FROM '.\SYSTEM\SQL\system_log::NAME_MYS.
|
||||
' LEFT JOIN '.\SYSTEM\SQL\system_user::NAME_MYS.
|
||||
' ON '.\SYSTEM\SQL\system_log::NAME_MYS.'.'.\SYSTEM\SQL\system_log::FIELD_USER.
|
||||
' = '.\SYSTEM\SQL\system_user::NAME_MYS.'.'.\SYSTEM\SQL\system_user::FIELD_ID.
|
||||
' WHERE '.\SYSTEM\SQL\system_log::FIELD_CLASS.' LIKE ?'.
|
||||
' AND ('.\SYSTEM\SQL\system_log::FIELD_MESSAGE.' LIKE ?'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_FILE.' LIKE ?'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_IP.' LIKE ?'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.' LIKE ?'.')'.
|
||||
' ORDER BY '.\SYSTEM\SQL\system_log::FIELD_TIME.' DESC, '.\SYSTEM\SQL\system_log::NAME_MYS.'.'.\SYSTEM\SQL\system_log::FIELD_ID.' DESC;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,48 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to find all classfilters from system_log
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_FILTERS extends \SYSTEM\DB\QQ {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT '.\SYSTEM\SQL\system_log::FIELD_CLASS.
|
||||
' FROM '.\SYSTEM\SQL\system_log::NAME_PG.
|
||||
' GROUP BY '.\SYSTEM\SQL\system_log::FIELD_CLASS.
|
||||
' ORDER BY '.\SYSTEM\SQL\system_log::FIELD_CLASS.';';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT '.\SYSTEM\SQL\system_log::FIELD_CLASS.
|
||||
' FROM '.\SYSTEM\SQL\system_log::NAME_MYS.
|
||||
' GROUP BY '.\SYSTEM\SQL\system_log::FIELD_CLASS.
|
||||
' ORDER BY '.\SYSTEM\SQL\system_log::FIELD_CLASS.';';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,54 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to count filtered data from system_log
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_FILTER_COUNT extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT COUNT(*) as count'.
|
||||
' FROM '.\SYSTEM\SQL\system_log::NAME_PG.
|
||||
' WHERE '.\SYSTEM\SQL\system_log::FIELD_CLASS.' LIKE $1'.
|
||||
' AND ('.\SYSTEM\SQL\system_log::FIELD_MESSAGE.' LIKE $2'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_FILE.' LIKE $3'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_IP.' LIKE $4'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.' LIKE $5'.');';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT COUNT(*) as count'.
|
||||
' FROM '.\SYSTEM\SQL\system_log::NAME_MYS.
|
||||
' WHERE '.\SYSTEM\SQL\system_log::FIELD_CLASS.' LIKE ?'.
|
||||
' AND ('.\SYSTEM\SQL\system_log::FIELD_MESSAGE.' LIKE ?'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_FILE.' LIKE ?'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_IP.' LIKE ?'.
|
||||
' OR '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.' LIKE ?'.');';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,42 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to truncate data from system_log
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_TRUNCATE extends \SYSTEM\DB\QQ {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'TRUNCATE '.\SYSTEM\SQL\system_log::NAME_PG.';';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'TRUNCATE '.\SYSTEM\SQL\system_log::NAME_MYS.';';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,58 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - unique basic
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_UNIQUE_BASIC extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,58 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - unique exception
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_UNIQUE_EXCEPTION extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_FILE.') as file_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_LINE.') as line_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_CLASS.') as class_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_FILE.') as file_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_LINE.') as line_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_CLASS.') as class_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,60 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - unique referer
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_UNIQUE_REFERER extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_REFERER.') as http_referer_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_USER_AGENT.') as http_user_agent_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_REFERER.') as http_referer_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_USER_AGENT.') as http_user_agent_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,60 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get analytics data from system_log - unique request
|
||||
*/
|
||||
class SYS_SAIMOD_LOG_UNIQUE_REQUEST extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs PostgreSQL Query String
|
||||
*
|
||||
* @return string Returns PostgreSQL Query String
|
||||
*/
|
||||
public static function pgsql(){return
|
||||
'SELECT to_char(to_timestamp(extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int - (extract(epoch from '.\SYSTEM\SQL\system_log::FIELD_TIME.')::int % $1)), \'YYYY/MM/DD HH24:MI:SS\') as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_PORT.') as server_port_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.') as request_uri_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_POST.') as post_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_PG
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT DATE_FORMAT(FROM_UNIXTIME(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.') - MOD(UNIX_TIMESTAMP('.\SYSTEM\SQL\system_log::FIELD_TIME.'),?)),"%Y/%m/%d %H:%i:%s") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_PORT.') as server_port_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.') as request_uri_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_POST.') as post_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;';
|
||||
}
|
||||
}
|
||||
422
sai/modules/saimod_sys_analytics/saimod_sys_analytics.php
Normal file
422
sai/modules/saimod_sys_analytics/saimod_sys_analytics.php
Normal file
@ -0,0 +1,422 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SAI
|
||||
*/
|
||||
namespace SYSTEM\SAI;
|
||||
|
||||
/**
|
||||
* saimod_sys_log Class provided by System as saimod to manage the system_log table
|
||||
*/
|
||||
class saimod_sys_analytics extends \SYSTEM\SAI\sai_module {
|
||||
/**
|
||||
* Deletes the Log Entries
|
||||
*
|
||||
* @return json Returns json with status ok
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_truncate(){
|
||||
\SYSTEM\SQL\SYS_SAIMOD_LOG_TRUNCATE::QQ();
|
||||
return \SYSTEM\LOG\JsonResult::ok();}
|
||||
|
||||
/**
|
||||
* Generates HTML for one Log Analytics Entry
|
||||
*
|
||||
* @return string Returns HTML
|
||||
*/
|
||||
public static function analytics(){
|
||||
$vars = array();
|
||||
$data = \SYSTEM\SQL\SYS_SAIMOD_LOG_ANALYTICS::Q1(array(86400));
|
||||
$vars['log_today'] = $data['count'];
|
||||
$vars['ip_today'] = $data['ip_unique'];
|
||||
$vars['user_today'] = $data['user_unique'];
|
||||
$data = \SYSTEM\SQL\SYS_SAIMOD_LOG_ANALYTICS::Q1(array(604800));
|
||||
$vars['log_week'] = $data['count'];
|
||||
$vars['ip_week'] = $data['ip_unique'];
|
||||
$vars['user_week'] = $data['user_unique'];
|
||||
$data = \SYSTEM\SQL\SYS_SAIMOD_LOG_ANALYTICS::Q1(array(2692000));
|
||||
$vars['log_month'] = $data['count'];
|
||||
$vars['ip_month'] = $data['ip_unique'];
|
||||
$vars['user_month'] = $data['user_unique'];
|
||||
$vars['page_value'] = \round( $vars['log_today']+$vars['ip_today']*10+$vars['user_today']*100+
|
||||
($vars['log_week']+$vars['ip_week']*10+$vars['user_week']*100)/7+
|
||||
($vars['log_month']+$vars['ip_month']*10+$vars['user_week']*100)/31,0);
|
||||
return \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_analytics/tpl/saimod_sys_analytics_analytics.tpl'))->SERVERPATH(), $vars);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for class system
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_class_system($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_CLASS_SYSTEM::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('class_system',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" then 1 else 0 end) class_SYSTEM_LOG_COUNTER,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\INFO" then 1 else 0 end) class_SYSTEM_LOG_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\DEPRECATED" then 1 else 0 end) class_SYSTEM_LOG_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\WARNING" then 1 else 0 end) class_SYSTEM_LOG_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\ERROR" then 1 else 0 end) class_SYSTEM_LOG_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\ERROR_EXCEPTION" then 1 else 0 end) class_SYSTEM_LOG_ERROR_EXCEPTION,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\SHUTDOWN_EXCEPTION" then 1 else 0 end) class_SYSTEM_LOG_SHUTDOWN_EXCEPTION'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for class other
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_class_other($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_CLASS_OTHER::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('class_other',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'Exception\' then 1 else 0 end) class_Exception,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'RuntimeException\' then 1 else 0 end) class_RuntimeException,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ErrorException\' then 1 else 0 end) class_ErrorException'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for class basic
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_class_basic($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_CLASS_BASIC::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('class_basic',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ERROR\' then 1 else 0 end) class_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'WARNING\' then 1 else 0 end) class_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'INFO\' then 1 else 0 end) class_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'DEPRECATED\' then 1 else 0 end) class_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'AppError\' then 1 else 0 end) class_AppError'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unique basic
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_unique_basic($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_BASIC::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_basic',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unique request
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_unique_request($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_REQUEST::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_request',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_PORT.') as server_port_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.') as request_uri_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_POST.') as post_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unqiue exception
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_unique_exception($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_EXCEPTION::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_exception',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_FILE.') as file_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_LINE.') as line_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_CLASS.') as class_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unique referer
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_unique_referer($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_REFERER::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_referer',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_REFERER.') as http_referer_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_USER_AGENT.') as http_user_agent_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for basic visitor
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_basic_visitor($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_BASIC_VISITOR::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('basic_visitor',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for basic success
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_basic_sucess($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_BASIC_SUCCESS::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('basic_sucess',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\INFO" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "INFO" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\DEPRECATED" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "DEPRECATED" and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\WARNING" and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "PreprocessingLog" '
|
||||
.'then 1 else 0 end) class_fail,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\INFO" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "INFO" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\DEPRECATE" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "DEPRECATED" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\WARNING" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "PreprocessingLog" '
|
||||
.'then 1 else 0 end) class_log,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" then 1 else 0 end) class_sucess'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for basic querytime
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics_action_stats_name_basic_querytime($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_BASIC_QUERYTIME::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('basic_querytime',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'avg('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_avg,'
|
||||
.'max('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_max,'
|
||||
.'min('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_min'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);}
|
||||
|
||||
/**
|
||||
* Generate the HTML for the Saimods startpage
|
||||
*
|
||||
* @return string Returns HTML for the Saimods startpage
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_analytics(){
|
||||
$vars = \SYSTEM\PAGE\text::tag(\SYSTEM\SQL\system_text::TAG_SAI_LOG);
|
||||
$vars['dbfile_entries'] = '';
|
||||
if( \SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH) &&
|
||||
file_exists(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH))){
|
||||
$scanned_directory = array_diff(scandir(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH)), array('..', '.', 'undefined', '.gitignore'));
|
||||
foreach($scanned_directory as $file){
|
||||
$vars['dbfile_entries'] .= \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_analytics/tpl/saimod_sys_analytics_menu.tpl'))->SERVERPATH(), array('file' => $file));}
|
||||
}
|
||||
//positioning problem
|
||||
//$vars['analytics'] = self::analytics();
|
||||
return \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_analytics/tpl/saimod_sys_analytics.tpl'))->SERVERPATH(), $vars);
|
||||
}
|
||||
|
||||
/**
|
||||
* Generate <li> Menu for the Saimod
|
||||
*
|
||||
* @return string Returns <li> Menu for the Saimod
|
||||
*/
|
||||
public static function menu(){
|
||||
return new sai_module_menu( 1,
|
||||
sai_module_menu::POISITION_LEFT,
|
||||
sai_module_menu::DIVIDER_NONE,
|
||||
\SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_analytics/tpl/menu.tpl'))->SERVERPATH()));}
|
||||
|
||||
/**
|
||||
* Returns if the Saimod is public(access for everyone)
|
||||
*
|
||||
* @return boolean Returns if the Saimod is public(true) or not(false)
|
||||
*/
|
||||
public static function right_public(){return false;}
|
||||
|
||||
/**
|
||||
* Returns if the requesting user has the required rights to access the Saimod
|
||||
*
|
||||
* @return boolean Returns true if the user can access
|
||||
*/
|
||||
public static function right_right(){return \SYSTEM\SECURITY\security::check(\SYSTEM\SECURITY\RIGHTS::SYS_SAI);}
|
||||
|
||||
/**
|
||||
* Get all js System Paths required for this Saimod
|
||||
*
|
||||
* @return array Returns array of Pathobjects pointing to the saimods js
|
||||
*/
|
||||
public static function js(){
|
||||
return array(new \SYSTEM\PSAI('modules/saimod_sys_analytics/js/saimod_sys_analytics.js'));}
|
||||
}
|
||||
7
sai/modules/saimod_sys_analytics/tpl/menu.tpl
Normal file
7
sai/modules/saimod_sys_analytics/tpl/menu.tpl
Normal file
@ -0,0 +1,7 @@
|
||||
<li class="nav-item">
|
||||
<a id="menu_analytics" class="nav-link" data-toggle="tooltip" data-placement="bottom" title="Analytics" href="#!analytics">
|
||||
<span class="d-md-none" style="padding-left: 15px;"></span>
|
||||
<i class="fa fa-bar-chart" aria-hidden="true"></i>
|
||||
<span class="d-md-none"> Analytics</span>
|
||||
</a>
|
||||
</li>
|
||||
@ -0,0 +1,46 @@
|
||||
<div class="row">
|
||||
<div class="col-12 sai_padding_10 bg-primary">
|
||||
<h4 class="sai_margin_off"> <span class="fa fa-bar-chart" aria-hidden="true"></span> System Analytics</h4>
|
||||
</div>
|
||||
<div class="col-md-2 sai_padding_off">
|
||||
<ul class="nav bg-light flex-column" id="tabs_analytics">
|
||||
<li class="nav-item" db=""><a class="nav-link active" href="#!analytics" id="menu_tag_basics">Current Month</a></li>
|
||||
${dbfile_entries}
|
||||
</ul>
|
||||
</div>
|
||||
<div class="col-md-10 sai_border_left sai_padding_top_10" id="tab_analytics">
|
||||
<select id="vis_filter_time">
|
||||
<option value="2692000">30d</option>
|
||||
<option value="1209600">14d</option>
|
||||
<option value="604800">7d</option>
|
||||
<option value="172800">2d</option>
|
||||
<option value="86400" selected>1d</option>
|
||||
<option value="43200">12h</option>
|
||||
<option value="21600">6h</option>
|
||||
<option value="14400">4h</option>
|
||||
<option value="7200">2h</option>
|
||||
<option value="3600">1h</option>
|
||||
<option value="1800">30m</option>
|
||||
<option value="600">10m</option>
|
||||
<option value="300">5m</option>
|
||||
<option value="60">1m</option>
|
||||
<option value="30">30s</option>
|
||||
<option value="10">10s</option>
|
||||
<option value="5">5s</option>
|
||||
<option value="1">1s</option>
|
||||
</select>
|
||||
<select id="vis_filter_type">
|
||||
<option value="basic_visitor">basic_visitor</option>
|
||||
<option value="basic_sucess">basic_sucess</option>
|
||||
<option value="basic_querytime">basic_querytime</option>
|
||||
<option value="unique_basic">unique_basic</option>
|
||||
<option value="unique_request">unique_request</option>
|
||||
<option value="unique_exception">unique_exception</option>
|
||||
<option value="unique_referer">unique_referer</option>
|
||||
<option value="class_system">class_system</option>
|
||||
<option value="class_other">class_other</option>
|
||||
<option value="class_basic">class_basic</option>
|
||||
</select>
|
||||
<div id="vis"></div>
|
||||
</div>
|
||||
</div>
|
||||
@ -0,0 +1 @@
|
||||
<li class="nav-item"><a class="nav-link" href="#!analytics" db="${file}">${file}</a></li>
|
||||
@ -1,4 +1,3 @@
|
||||
google.load("visualization", "1", {packages:["corechart"]});
|
||||
function init_saimod_sys_log() {
|
||||
$("#sai_mod_log_table").tablesorter();
|
||||
$('#tabs_log a').click(function (e) {
|
||||
@ -20,85 +19,4 @@ function init_saimod_sys_log_log() {
|
||||
$(this).removeClass('active');});
|
||||
$('#menu_loglist').parent().addClass('active');
|
||||
register_search();
|
||||
}
|
||||
|
||||
function init_saimod_sys_log_stats() {
|
||||
$("#sai_mod_log_table").tablesorter();
|
||||
load_visualisation();
|
||||
$('#vis_filter_time').change(function(){
|
||||
load_visualisation();})
|
||||
$('#vis_filter_type').change(function(){
|
||||
load_visualisation();})
|
||||
$('#stats_tabs a').click(function (e) {
|
||||
e.preventDefault();
|
||||
$(this).tab('show');
|
||||
load_visualisation();
|
||||
});
|
||||
$('#tabs_log li').each(function(){
|
||||
$(this).removeClass('active');});
|
||||
$('#menu_stats').parent().addClass('active');
|
||||
}
|
||||
function load_visualisation(){
|
||||
$('img#loader').show();
|
||||
var name = $('#vis_filter_type').val();;
|
||||
var filter = $('#vis_filter_time').val();
|
||||
var db = $('#stats_tabs li.active').attr('db');
|
||||
/*$.getJSON('./sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log&action=stats&name='+name+'&filter='+filter+'&db='+db,function(json){
|
||||
|
||||
});*/
|
||||
$.ajax({
|
||||
async: true,
|
||||
url: this.endpoint,
|
||||
type: 'GET',
|
||||
dataType: 'JSON',
|
||||
data: {
|
||||
sai_mod: '.SYSTEM.SAI.saimod_sys_log',
|
||||
action: 'stats',
|
||||
name: name,
|
||||
filter: filter,
|
||||
db: db
|
||||
},
|
||||
success: function(data){
|
||||
if(data.status){
|
||||
var json = data.result;
|
||||
var gdata = new google.visualization.DataTable();
|
||||
first = true;
|
||||
$.each(json[0], function(key, value){
|
||||
if(first){
|
||||
gdata.addColumn('datetime',key);
|
||||
first = false;
|
||||
} else {
|
||||
gdata.addColumn('number',key);
|
||||
}
|
||||
});
|
||||
$.each(json, function(key, value){
|
||||
first = true;
|
||||
gdata.addRow($.map(value, function(v) {
|
||||
if(first){
|
||||
first=false;
|
||||
return [new Date(v)];
|
||||
} else {
|
||||
return [(v == null || parseFloat(v) <= 0) ? parseFloat(0) : parseFloat(v)];
|
||||
}
|
||||
}));
|
||||
});
|
||||
|
||||
var options = { title: name,
|
||||
aggregationTarget: 'category',
|
||||
selectionMode: 'multiple',
|
||||
curveType: 'function',
|
||||
/*focusTarget: 'category',*/
|
||||
chartArea: {left:100,top:40},
|
||||
vAxis: {logScale: true},
|
||||
interpolateNulls: false,
|
||||
width: "1200",
|
||||
height: "500"};
|
||||
new google.visualization.LineChart(document.getElementById('vis')).draw(gdata, options);
|
||||
}
|
||||
$('img#loader').hide();
|
||||
},
|
||||
error: function(){
|
||||
alert('Something happend - try again!');
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -24,368 +24,6 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
\SYSTEM\SQL\SYS_SAIMOD_LOG_TRUNCATE::QQ();
|
||||
return \SYSTEM\LOG\JsonResult::ok();}
|
||||
|
||||
/**
|
||||
* Generates HTML for one Log Analytics Entry
|
||||
*
|
||||
* @return string Returns HTML
|
||||
*/
|
||||
public static function analytics(){
|
||||
$vars = array();
|
||||
$data = \SYSTEM\SQL\SYS_SAIMOD_LOG_ANALYTICS::Q1(array(86400));
|
||||
$vars['log_today'] = $data['count'];
|
||||
$vars['ip_today'] = $data['ip_unique'];
|
||||
$vars['user_today'] = $data['user_unique'];
|
||||
$data = \SYSTEM\SQL\SYS_SAIMOD_LOG_ANALYTICS::Q1(array(604800));
|
||||
$vars['log_week'] = $data['count'];
|
||||
$vars['ip_week'] = $data['ip_unique'];
|
||||
$vars['user_week'] = $data['user_unique'];
|
||||
$data = \SYSTEM\SQL\SYS_SAIMOD_LOG_ANALYTICS::Q1(array(2692000));
|
||||
$vars['log_month'] = $data['count'];
|
||||
$vars['ip_month'] = $data['ip_unique'];
|
||||
$vars['user_month'] = $data['user_unique'];
|
||||
$vars['page_value'] = \round( $vars['log_today']+$vars['ip_today']*10+$vars['user_today']*100+
|
||||
($vars['log_week']+$vars['ip_week']*10+$vars['user_week']*100)/7+
|
||||
($vars['log_month']+$vars['ip_month']*10+$vars['user_week']*100)/31,0);
|
||||
return \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_analytics.tpl'))->SERVERPATH(), $vars);
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates HTML for the Log Analytics
|
||||
*
|
||||
* @return string Returns HTML
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats(){
|
||||
$vars = \SYSTEM\PAGE\text::tag(\SYSTEM\SQL\system_text::TAG_SAI_LOG);
|
||||
$vars['dbfile_entries'] = '';
|
||||
if( \SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH) &&
|
||||
file_exists(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH))){
|
||||
$scanned_directory = array_diff(scandir(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH)), array('..', '.'));
|
||||
foreach($scanned_directory as $file){
|
||||
$vars['dbfile_entries'] .= \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_stats_menu.tpl'))->SERVERPATH(), array('file' => $file));}
|
||||
}
|
||||
//positioning problem
|
||||
//$vars['analytics'] = self::analytics();
|
||||
return \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_stats.tpl'))->SERVERPATH(), $vars);}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for class system
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_class_system($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_CLASS_SYSTEM::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('class_system',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" then 1 else 0 end) class_SYSTEM_LOG_COUNTER,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\INFO" then 1 else 0 end) class_SYSTEM_LOG_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\DEPRECATED" then 1 else 0 end) class_SYSTEM_LOG_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\WARNING" then 1 else 0 end) class_SYSTEM_LOG_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\ERROR" then 1 else 0 end) class_SYSTEM_LOG_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\ERROR_EXCEPTION" then 1 else 0 end) class_SYSTEM_LOG_ERROR_EXCEPTION,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\SHUTDOWN_EXCEPTION" then 1 else 0 end) class_SYSTEM_LOG_SHUTDOWN_EXCEPTION'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for class other
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_class_other($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_CLASS_OTHER::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('class_other',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'Exception\' then 1 else 0 end) class_Exception,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'RuntimeException\' then 1 else 0 end) class_RuntimeException,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ErrorException\' then 1 else 0 end) class_ErrorException'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for class basic
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_class_basic($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_CLASS_BASIC::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('class_basic',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'ERROR\' then 1 else 0 end) class_ERROR,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'WARNING\' then 1 else 0 end) class_WARNING,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'INFO\' then 1 else 0 end) class_INFO,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'DEPRECATED\' then 1 else 0 end) class_DEPRECATED,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = \'AppError\' then 1 else 0 end) class_AppError'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unique basic
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_unique_basic($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_BASIC::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_basic',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unique request
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_unique_request($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_REQUEST::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_request',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_NAME.') as server_name_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_SERVER_PORT.') as server_port_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_REQUEST_URI.') as request_uri_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_POST.') as post_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unqiue exception
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_unique_exception($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_EXCEPTION::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_exception',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_FILE.') as file_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_LINE.') as line_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_CLASS.') as class_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for unique referer
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_unique_referer($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_UNIQUE_REFERER::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('unique_referer',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_REFERER.') as http_referer_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_HTTP_USER_AGENT.') as http_user_agent_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for basic visitor
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_basic_visitor($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_BASIC_VISITOR::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('basic_visitor',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_USER.') as user_unique,'
|
||||
.'count(distinct '.\SYSTEM\SQL\system_log::FIELD_IP.') as ip_unique'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for basic success
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_basic_sucess($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_BASIC_SUCCESS::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('basic_sucess',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'sum(case when not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\INFO" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "INFO" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\DEPRECATED" and'
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "DEPRECATED" and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\WARNING" and '
|
||||
.' not '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "PreprocessingLog" '
|
||||
.'then 1 else 0 end) class_fail,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\INFO" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "INFO" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\DEPRECATE" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "DEPRECATED" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\WARNING" or '
|
||||
.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "PreprocessingLog" '
|
||||
.'then 1 else 0 end) class_log,'
|
||||
.'sum(case when '.\SYSTEM\SQL\system_log::FIELD_CLASS.' = "SYSTEM\\LOG\\COUNTER" then 1 else 0 end) class_sucess'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);}
|
||||
|
||||
/**
|
||||
* Get Log Analytics Data for basic querytime
|
||||
*
|
||||
* @param int $filter Timeiterval in seconds to cluster upon
|
||||
* @param string $db DB to operate on
|
||||
* @return json Returns json with data
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_stats_name_basic_querytime($filter,$db=null){
|
||||
$result = array();
|
||||
if(!$db){
|
||||
$result = \SYSTEM\SQL\SYS_SAIMOD_LOG_BASIC_QUERYTIME::QA(array($filter));
|
||||
} else {
|
||||
$con = new \SYSTEM\DB\Connection(new \SYSTEM\DB\DBInfoSQLite(\SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CRON_LOG2SQLITE_PATH).$db));
|
||||
$res = $con->prepare('basic_querytime',
|
||||
'SELECT datetime(strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.') - strftime("%s",'.\SYSTEM\SQL\system_log::FIELD_TIME.')%:filter,"unixepoch", "localtime") as day,'
|
||||
.'count(*) as count,'
|
||||
.'avg('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_avg,'
|
||||
.'max('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_max,'
|
||||
.'min('.\SYSTEM\SQL\system_log::FIELD_QUERYTIME.') as querytime_min'
|
||||
.' FROM '.\SYSTEM\SQL\system_log::NAME_MYS
|
||||
.' GROUP BY day'
|
||||
.' ORDER BY day DESC'
|
||||
.' LIMIT 30;',
|
||||
array(':filter' => $filter));
|
||||
while($row = $res->next()){
|
||||
$result[] = $row;}
|
||||
}
|
||||
return \SYSTEM\LOG\JsonResult::toString($result);}
|
||||
|
||||
/**
|
||||
* Generates HTML for a Log Entry
|
||||
*
|
||||
@ -403,7 +41,7 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
*
|
||||
* @param string $filter Classfilter
|
||||
* @param string $search SearchFilter
|
||||
* @param int $page Page of the List(100 are displayed)
|
||||
* @param int $page Page of the List(50 are displayed)
|
||||
* @return string Returns HTML
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log_action_filter($filter = "%",$search="%",$page=0){
|
||||
@ -416,8 +54,8 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
$res = \SYSTEM\SQL\SYS_SAIMOD_LOG_FILTER::QQ(array(str_replace('\\', '\\\\', $filter),$search,$search,$search,$search));
|
||||
$vars['table'] = '';
|
||||
$count_filtered = 0;
|
||||
$res->seek(100*$page);
|
||||
while(($r = $res->next()) && ($count_filtered < 100)){
|
||||
$res->seek(50*$page);
|
||||
while(($r = $res->next()) && ($count_filtered < 50)){
|
||||
$r['class_row'] = self::tablerow_class($r['class']);
|
||||
$r['time'] = \SYSTEM\time::time_ago_string(strtotime($r['time']));
|
||||
$r['message'] = htmlspecialchars(substr($r['message'],0,255));
|
||||
@ -426,9 +64,9 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
$count_filtered++;
|
||||
}
|
||||
$vars['pagination'] = '';
|
||||
$vars['page_last'] = floor($count/100);
|
||||
$vars['page_last'] = floor($count/50);
|
||||
$dots = false;
|
||||
for($i=0;$i < ceil($count/100);$i++){
|
||||
for($i=0;$i < ceil($count/50);$i++){
|
||||
if(abs($page-$i) < 7){
|
||||
$data = array('page' => $i,'search' => $vars['search_encoded'], 'filter' => $filter, 'active' => ($i == $page) ? 'active' : '');
|
||||
$vars['pagination'] .= \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_pagination.tpl'))->SERVERPATH(), $data);
|
||||
@ -441,11 +79,6 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
}
|
||||
}
|
||||
$vars['count'] = $count_filtered.'/'.$count;
|
||||
$vars['error_filter'] = '';
|
||||
$res = \SYSTEM\SQL\SYS_SAIMOD_LOG_FILTERS::QQ();
|
||||
while($row = $res->next()){
|
||||
$data = array('active' => ($filter == $row['class'] ? 'active' : ''), 'filter' => $row['class'], 'search_encoded' => $vars['search_encoded']);
|
||||
$vars['error_filter'] .= \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_error_filter.tpl'))->SERVERPATH(),$data);}
|
||||
$vars['active'] = ($filter == '%' ? 'active' : '');
|
||||
$vars = array_merge($vars, \SYSTEM\PAGE\text::tag(\SYSTEM\SQL\system_text::TAG_SAI_LOG));
|
||||
return \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_filter.tpl'))->SERVERPATH(),$vars);
|
||||
@ -458,6 +91,11 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
*/
|
||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_log(){
|
||||
$vars = \SYSTEM\PAGE\text::tag(\SYSTEM\SQL\system_text::TAG_SAI_LOG);
|
||||
$vars['error_filter'] = '';
|
||||
$res = \SYSTEM\SQL\SYS_SAIMOD_LOG_FILTERS::QQ();
|
||||
while($row = $res->next()){
|
||||
$data = array('filter' => $row['class']);
|
||||
$vars['error_filter'] .= \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log_error_filter.tpl'))->SERVERPATH(),$data);}
|
||||
return \SYSTEM\PAGE\replace::replaceFile((new \SYSTEM\PSAI('modules/saimod_sys_log/tpl/saimod_sys_log.tpl'))->SERVERPATH(), $vars);
|
||||
}
|
||||
|
||||
@ -470,16 +108,13 @@ class saimod_sys_log extends \SYSTEM\SAI\sai_module {
|
||||
public static function tablerow_class($class){
|
||||
switch($class){
|
||||
case 'SYSTEM\LOG\INFO': case 'INFO': case 'SYSTEM\LOG\COUNTER':
|
||||
return 'success';
|
||||
return 'table-success';
|
||||
case 'SYSTEM\LOG\DEPRECATED': case 'DEPRECATED':
|
||||
return 'info';
|
||||
//case 'SYSTEM\LOG\ERROR': case 'ERROR': case 'Exception': case 'SYSTEM\LOG\ERROR_EXCEPTION':
|
||||
//case 'ErrorException': case 'SYSTEM\LOG\SHUTDOWN_EXCEPTION':
|
||||
// return 'danger';
|
||||
return 'table-info';
|
||||
case 'SYSTEM\LOG\WARNING': case 'WARNING': case 'SYSTEM\LOG\TODO': case 'TODO':
|
||||
return 'warning';
|
||||
return 'table-warning';
|
||||
default:
|
||||
return 'danger';
|
||||
return 'table-danger';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -1,5 +1,6 @@
|
||||
<li class="nav-item">
|
||||
<a id="menu_log" class="nav-link" data-toggle="tooltip" data-placement="bottom" title="${sai_menu_log}" href="#!log">
|
||||
<span class="d-md-none" style="padding-left: 15px;"></span>
|
||||
<i class="fa fa-list" aria-hidden="true"></i>
|
||||
<span class="d-md-none"> ${sai_menu_log}</span>
|
||||
</a>
|
||||
|
||||
@ -1,23 +1,12 @@
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<h4> <span class="fa fa-list" aria-hidden="true"></span> ${sai_log_title}</h4>
|
||||
<div class="row">
|
||||
<div class="col-12 sai_padding_10 bg-primary">
|
||||
<h4 class="sai_margin_off"> <span class="fa fa-list" aria-hidden="true"></span> ${sai_log_title}</h4>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<hr>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<ul class="nav nav-tabs" id="tabs_log">
|
||||
<li class="nav-item"><a class="nav-link active" href="#!log" id="menu_loglist">${basic_log}</a></li>
|
||||
<li class="nav-item"><a class="nav-link" href="#!log(stats)" id="menu_stats">${basic_analytics}</a></li>
|
||||
<img id="loader" src="./files/sai/ajax-loader.gif" style="margin-left: 10px; margin-top: 10px; display: none; float: left"/>
|
||||
<button onClick="system.load('log',true);" class="btn-success btn btn-sm" style="height: 32px; font-size: 13px; float: right;"><span class="fa fa-refresh" aria-hidden="true"></span> ${basic_refresh}</button>
|
||||
<div class="col-md-2 sai_padding_off">
|
||||
<ul class="nav bg-light flex-column" id="tabs_log">
|
||||
<li class="nav-item"><a class="nav-link active" href="#!log" id="menu_tag_basics">${basic_all}</a></li>
|
||||
${error_filter}
|
||||
</ul>
|
||||
<div class="tab-content">
|
||||
<div class="tab-pane active" id="tab_log"></div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md-10 sai_padding_off sai_border_left" id="tab_log"></div>
|
||||
</div>
|
||||
@ -1 +1 @@
|
||||
<li class="nav-item"><a class="nav-link ${active}" href="#!log;filter.${filter};search.${search_encoded}">${filter}</a></li>
|
||||
<li class="nav-item"><a class="nav-link ${active}" href="#!log;filter.${filter}">${filter}</a></li>
|
||||
@ -1,28 +1,33 @@
|
||||
<ul class="nav nav-pills" id="error_filter">
|
||||
<li class="nav-item"><a class="nav-link ${active}" href="#!log;filter.%;search.${search_encoded}">${basic_all}</a></li>
|
||||
${error_filter}
|
||||
<button class="btn-sm btn btn-success" state="log;filter.${filter};search." id="btn_search_log" type="submit" style="float: right; margin-left: 10px;"><span class="fa fa-search" aria-hidden="true"></span> ${basic_search}</button>
|
||||
<input class="input-medium search-query action-control" id="input_search_log" type="text" placeholder="${basic_placeholder_search}" size="20" style="float: right;" value="${search}"/>
|
||||
</ul>
|
||||
<div id="table_log">
|
||||
<h6>${basic_rows}: ${count} ${basic_page}: ${page}</h6>
|
||||
<table class="table table-hover table-condensed tablesorter" style="word-break: break-word;" id="sai_mod_log_table">
|
||||
<tr>
|
||||
<th>${time_ago}</th>
|
||||
<th>${table_class}</th>
|
||||
<th>${table_message}</th>
|
||||
<th>${table_file}</th>
|
||||
<th>${table_line}</th>
|
||||
<th>${table_ip}</th>
|
||||
<th>${table_url}</th>
|
||||
<th>${table_user}</th>
|
||||
<th>${table_querytime}</th>
|
||||
</tr>
|
||||
${table}
|
||||
<div class="table-responsive">
|
||||
<table class="table table-striped table-condensed tablesorter sai_margin_off" id="table_log">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>${time_ago}</th>
|
||||
<th>${table_class}</th>
|
||||
<th>${table_message}</th>
|
||||
<th>${table_file}</th>
|
||||
<th>${table_line}</th>
|
||||
<th>${table_ip}</th>
|
||||
<th>${table_url}</th>
|
||||
<th>${table_user}</th>
|
||||
<th>${table_querytime}</th>
|
||||
</tr>
|
||||
<tr>
|
||||
<th colspan="9">
|
||||
${basic_rows}: ${count} ${basic_page}: ${page}
|
||||
<button class="btn btn-sm btn-success pull-right" onClick="system.reload();" style="margin-left: 10px;"><span class="fa fa-refresh" aria-hidden="true"></span></button>
|
||||
<button class="btn btn-sm btn-success pull-right" state="log;filter.${filter};search." id="btn_search_log" type="submit" style="margin-left: 10px;"><span class="fa fa-search" aria-hidden="true"></span> ${basic_search}</button>
|
||||
<input class="input-medium search-query action-control pull-right" id="input_search_log" type="text" placeholder="${basic_placeholder_search}" size="20" value="${search}"/>
|
||||
</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody id="table_log" style="word-break: break-word;">
|
||||
${table}
|
||||
</tbody>
|
||||
</table>
|
||||
<ul class="pagination">
|
||||
<li class="page-item"><a class="page-link" href="#!log;filter.${filter};search.${search_encoded};page.0">«</a></li>
|
||||
${pagination}
|
||||
<li class="page-item"><a class="page-link" href="#!log;filter.${filter};search.${search_encoded};page.${page_last}">»</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
<ul class="pagination sai_margin_top_10">
|
||||
<li class="page-item"><a class="page-link" href="#!log;filter.${filter};search.${search_encoded};page.0">«</a></li>
|
||||
${pagination}
|
||||
<li class="page-item"><a class="page-link" href="#!log;filter.${filter};search.${search_encoded};page.${page_last}">»</a></li>
|
||||
</ul>
|
||||
@ -1 +0,0 @@
|
||||
<li class="nav-item" db="${file}"><a class="nav-link" href="#tab_stats">${file}</a></li>
|
||||
@ -1,9 +1,9 @@
|
||||
function init_saimod_sys_text() {
|
||||
$("#sai_mod_text_table").tablesorter();
|
||||
$('#tabs_text a').click(function (e) {
|
||||
$('#tabs_text li').each(function(){
|
||||
$('#tabs_text a').each(function(){
|
||||
$(this).removeClass('active');});
|
||||
$(this).parent().addClass('active');
|
||||
$(this).addClass('active');
|
||||
});
|
||||
text_menu();
|
||||
|
||||
|
||||
@ -1,5 +1,6 @@
|
||||
<li class="nav-item">
|
||||
<a id="menu_text" class="nav-link" data-toggle="tooltip" data-placement="bottom" title="${sai_menu_text}" href="#!text">
|
||||
<span class="d-md-none" style="padding-left: 15px;"></span>
|
||||
<i class="fa fa-edit" aria-hidden="true"></i>
|
||||
<span class="d-md-none"> ${sai_menu_text}</span>
|
||||
</a>
|
||||
|
||||
@ -1,24 +1,15 @@
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<h4> <span class="fa fa-edit" aria-hidden="true"></span> ${sai_text_title}</h4>
|
||||
<div class="row">
|
||||
<div class="col-12 sai_padding_10 bg-primary">
|
||||
<h4 class="sai_margin_off"> <span class="fa fa-edit" aria-hidden="true"></span> ${sai_text_title}</h4>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<hr>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<div class="tabbable">
|
||||
<ul class="nav nav-tabs" id="tabs_text">
|
||||
<li class="nav-item"><a class="nav-link" href="#!text" id="menu_tag_all">${basic_all}</a></li>
|
||||
<li class="nav-item"><a class="nav-link" href="#!text;tag.notag" id="menu_tag_notag">${basic_no_tag}</a></li>
|
||||
${tabopts}
|
||||
<button class="btn-sm btn btn-success content_add" onClick="system.load('text(edittext(editor));id.${new_id};lang.${new_lang}');" style="margin-left: 15px; float: right;"><span class="fa fa-plus" aria-hidden="true"></span> ${basic_add}</button>
|
||||
<button type="submit" value="${basic_show_all}" id="btn_show_all" class="btn-sm btn btn-primary" style="margin-left: 15px; float: right;"><span class="fa fa-eye" aria-hidden="true"></span> ${basic_show_all}</button>
|
||||
</ul>
|
||||
<div class="tab-content sai_margin_top_10" id="tab_content"></div>
|
||||
</div>
|
||||
<div class="col-md-2 sai_padding_off">
|
||||
<ul class="nav bg-light flex-column" id="tabs_text">
|
||||
<li class="nav-item"><a class="nav-link active" href="#!text" id="menu_tag_all">${basic_all}</a></li>
|
||||
<li class="nav-item"><a class="nav-link" href="#!text;tag.notag" id="menu_tag_notag">${basic_no_tag}</a></li>
|
||||
${tabopts}
|
||||
<button class="btn-sm btn btn-success content_add" onClick="system.load('text(edittext(editor));id.${new_id};lang.${new_lang}');" style="margin-left: 15px; float: right;"><span class="fa fa-plus" aria-hidden="true"></span> ${basic_add}</button>
|
||||
<button type="submit" value="${basic_show_all}" id="btn_show_all" class="btn-sm btn btn-primary" style="margin-left: 15px; float: right;"><span class="fa fa-eye" aria-hidden="true"></span> ${basic_show_all}</button>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="col-md-10 sai_padding_off sai_border_left" id="tab_content"></div>
|
||||
</div>
|
||||
@ -1,9 +1,9 @@
|
||||
google.load("visualization", "1", {packages:["corechart"]});
|
||||
function init_saimod_sys_todo() {
|
||||
$('#tabs_todo a').click(function (e) {
|
||||
$('#tabs_todo li').each(function(){
|
||||
$('#tabs_todo a').each(function(){
|
||||
$(this).removeClass('active');});
|
||||
$(this).parent().addClass('active');
|
||||
$(this).addClass('active');
|
||||
});
|
||||
|
||||
$('#btn_close_all').click(function(){
|
||||
|
||||
@ -1,5 +1,6 @@
|
||||
<li class="nav-item">
|
||||
<a id="menu_todo" class="nav-link" data-toggle="tooltip" data-placement="bottom" title="${sai_menu_todo}" href="#!todo">
|
||||
<span class="d-md-none" style="padding-left: 15px;"></span>
|
||||
<i class="fa fa-tasks" aria-hidden="true"></i>
|
||||
<span class="d-md-none"> ${sai_menu_todo}</span>
|
||||
</a>
|
||||
|
||||
@ -1,28 +1,17 @@
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<h4> <span class="glyphicon glyphicon-list" aria-hidden="true"></span> ${sai_todo_title}</h4>
|
||||
<div class="row">
|
||||
<div class="col-12 sai_padding_10 bg-primary">
|
||||
<h4 class="sai_margin_off"> <span class="fa fa-tasks" aria-hidden="true"></span> ${sai_todo_title}</h4>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<hr>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row-fluid">
|
||||
<div class="col-md-12 sai_padding_off">
|
||||
<div class="tabbable">
|
||||
<ul class="nav nav-tabs" id="tabs_todo">
|
||||
<li class="nav-item"><a class="nav-link active" href="#!todo" id="menu_todolist">ToDo</a></li>
|
||||
<div class="col-md-2 sai_padding_off">
|
||||
<ul class="nav bg-light flex-column" id="tabs_todo">
|
||||
<li class="nav-item"><a class="nav-link active" href="#!todo" id="menu_todolist">ToDo</a></li>
|
||||
<li class="nav-item"><a class="nav-link" href="#!todo(doto)" id="menu_doto">DoTo</a></li>
|
||||
<li class="nav-item"><a class="nav-link" href="#!todo(stats)" id="menu_stats">Statistics</a></li>
|
||||
<img id="img_loader" src="./files/sai/ajax-loader.gif" style="margin-left: 10px; margin-top: 10px; display: none; float: left"/>
|
||||
<button id="btn_refresh" class="btn-primary btn btn-sm" onClick="system.load('todo',true);" style="height: 32px; font-size: 13px; float: right;"><span class="glyphicon glyphicon-refresh" aria-hidden="true"></span> ${basic_refresh}</button>
|
||||
<button id="btn_close_all" class="btn-danger btn btn-sm" style="margin-right: 15px; height: 32px; font-size: 13px; float: right;"><span class="glyphicon glyphicon-minus-sign" aria-hidden="true"></span> ${basic_close_all}</button>
|
||||
<button id="btn_new" class="btn-success btn btn-sm" onClick="system.load('todo(new)');" style="margin-right: 15px; height: 32px; font-size: 13px; float: right;"><span class="glyphicon glyphicon-plus" aria-hidden="true"></span> ${basic_add}</button>
|
||||
</ul>
|
||||
<div class="tab-content sai_margin_top_10">
|
||||
<div class="tab-pane active" id="tab_todo"></div>
|
||||
</div>
|
||||
</div>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="col-md-10 sai_padding_off sai_border_left" id="tab_todo"></div>
|
||||
</div>
|
||||
@ -34,7 +34,7 @@ class saistart_sys_sai extends \SYSTEM\SAI\sai_module {
|
||||
|
||||
$vars['project_name'] = \SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_SAI_CONFIG_PROJECT);
|
||||
$vars['project_url'] = \SYSTEM\CONFIG\config::get(\SYSTEM\CONFIG\config_ids::SYS_CONFIG_PATH_BASEURL);
|
||||
$vars['analytics'] = \SYSTEM\SAI\saimod_sys_log::analytics();
|
||||
$vars['analytics'] = \SYSTEM\SAI\saimod_sys_analytics::analytics();
|
||||
$user = \SYSTEM\SECURITY\security::getUser();
|
||||
$vars['username'] = $user->username;
|
||||
$vars['locale'] = $user->locale;
|
||||
|
||||
@ -287,7 +287,7 @@ class security {
|
||||
* @return bool Returns json with status true or false or a bool
|
||||
*/
|
||||
public static function confirm($token) {
|
||||
return \SYSTEM\TOKEN\token::confirm($token) ? \SYSTEM\TOKEN\token::text_success($token) : \SYSTEM\TOKEN\token::text_fail($token);}
|
||||
return \SYSTEM\LOG\JsonResult::status(\SYSTEM\TOKEN\token::confirm($token));}
|
||||
|
||||
/**
|
||||
* Get Userinfo stored in the current Session.
|
||||
|
||||
@ -25,7 +25,7 @@ REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`
|
||||
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (70, 42, 'log', 'log', -1, 0, 0, '#content', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log', 'init_saimod_sys_log', '\\SYSTEM\\SAI\\saimod_sys_log');
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (71, 42, 'list', 'log', 70, 0, 0, '#tab_log', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log&action=filter&filter=${filter}&search=${search}&page=${page}', 'init_saimod_sys_log_log', '\\SYSTEM\\SAI\\saimod_sys_log');
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (72, 42, 'stats', 'log', 70, 0, 1, '#tab_log', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log&action=stats', 'init_saimod_sys_log_stats', '\\SYSTEM\\SAI\\saimod_sys_log');
|
||||
-- REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (72, 42, 'stats', 'log', 70, 0, 1, '#tab_log', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log&action=stats', 'init_saimod_sys_log_stats', '\\SYSTEM\\SAI\\saimod_sys_log');
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (73, 42, 'error', 'log', 70, 0, 1, '#tab_log', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_log&action=error&error=${error}', '', '');
|
||||
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (80, 42, 'login', 'login', -1, 0, 0, '#content', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_login', 'init_saimod_sys_login', '\\SYSTEM\\SAI\\saimod_sys_login');
|
||||
@ -64,4 +64,6 @@ REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (132, 42, 'delete', 'page', 130, 0, 1, '#tab_page', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_page&action=deletedialog&group=${group}&ID=${id}', 'init_saimod_sys_page_delete', '\\SYSTEM\\SAI\\saimod_sys_page');
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (133, 42, 'new', 'page', 130, 0, 1, '#tab_page', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_page&action=newdialog', 'init_saimod_sys_page_new', '\\SYSTEM\\SAI\\saimod_sys_page');
|
||||
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (140, 42, 'git', 'git', -1, 0, 0, '#content', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_git', 'init_saimod_sys_git', '\\SYSTEM\\SAI\\saimod_sys_git');
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (140, 42, 'git', 'git', -1, 0, 0, '#content', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_git', 'init_saimod_sys_git', '\\SYSTEM\\SAI\\saimod_sys_git');
|
||||
|
||||
REPLACE INTO `system_page` (`id`, `group`, `name`, `state`, `parent_id`, `login`, `type`, `div`, `url`, `func`, `php_class`) VALUES (150, 42, 'analytics', 'analytics', -1, 0, 0, '#content', './sai.php?sai_mod=.SYSTEM.SAI.saimod_sys_analytics', 'init_saimod_sys_analytics', '\\SYSTEM\\SAI\\saimod_sys_analytics');
|
||||
@ -67,10 +67,6 @@ REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `na
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (203, 42, 3, 200, 'filter', 'page', 'UINT0');
|
||||
--
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (210, 42, 3, 200, 'error', 'error', 'INT');
|
||||
--
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (220, 42, 0, 200, 'stats', 'name', null);
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (221, 42, 3, 220, null, 'filter', 'UINT');
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (222, 42, 3, 220, null, 'db', 'STRING');
|
||||
|
||||
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (300, 42, 0, 0, '_SYSTEM_SAI_saimod_sys_security', 'action', NULL);
|
||||
@ -215,4 +211,9 @@ REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `na
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1309, 42, 2, 1300, 'deletecall', 'group', 'INT');
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1310, 42, 2, 1300, 'deletedialog', 'ID', 'INT');
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1311, 42, 2, 1300, 'deletedialog', 'group', 'INT');
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1320, 42, 3, 1300, 'list', 'group', 'INT');
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1320, 42, 3, 1300, 'list', 'group', 'INT');
|
||||
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1400, 42, 0, 0, '_SYSTEM_SAI_saimod_sys_analytics', 'action', NULL);
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1401, 42, 0, 1400, 'stats', 'name', null);
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1402, 42, 3, 1401, null, 'filter', 'UINT');
|
||||
REPLACE INTO `system_api` (`ID`, `group`, `type`, `parentID`, `parentValue`, `name`, `verify`) VALUES (1403, 42, 3, 1401, null, 'db', 'STRING');
|
||||
@ -7,7 +7,6 @@ CREATE TABLE `system_token` (
|
||||
`request_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||
`confirm_user` INT(11) NULL DEFAULT NULL,
|
||||
`confirm_time` TIMESTAMP NULL DEFAULT NULL,
|
||||
`post_script` VARCHAR(255) NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`token`)
|
||||
)
|
||||
COLLATE='utf8_general_ci'
|
||||
|
||||
@ -28,6 +28,6 @@ class SYS_TOKEN_CONFIRM extends \SYSTEM\DB\QP {
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'UPDATE system_token SET expire = null, confirm_time = NOW(), confirm_user = ? WHERE token = ?;';
|
||||
'UPDATE system_token SET confirm_time = NOW(), confirm_user = ? WHERE token = ?;';
|
||||
}
|
||||
}
|
||||
33
token/qq/SYS_TOKEN_DELETE.php
Normal file
33
token/qq/SYS_TOKEN_DELETE.php
Normal file
@ -0,0 +1,33 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to delete a token
|
||||
*/
|
||||
class SYS_TOKEN_DELETE extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'DELETE FROM system_token WHERE token = ?;';
|
||||
}
|
||||
}
|
||||
33
token/qq/SYS_TOKEN_DUPLICATE.php
Normal file
33
token/qq/SYS_TOKEN_DUPLICATE.php
Normal file
@ -0,0 +1,33 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to get a token
|
||||
*/
|
||||
class SYS_TOKEN_DUPLICATE extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'SELECT * FROM system_token WHERE class = ? AND data = ?;';
|
||||
}
|
||||
}
|
||||
33
token/qq/SYS_TOKEN_EXPIRE_UPDATE.php
Normal file
33
token/qq/SYS_TOKEN_EXPIRE_UPDATE.php
Normal file
@ -0,0 +1,33 @@
|
||||
<?php
|
||||
/**
|
||||
* System - PHP Framework
|
||||
*
|
||||
* PHP Version 5.6
|
||||
*
|
||||
* @copyright 2016 Ulf Gebhardt (http://www.webcraft-media.de)
|
||||
* @license http://www.opensource.org/licenses/mit-license.php MIT
|
||||
* @link https://github.com/webcraftmedia/system
|
||||
* @package SYSTEM\SQL
|
||||
*/
|
||||
namespace SYSTEM\SQL;
|
||||
|
||||
/**
|
||||
* QQ to insert a token
|
||||
*/
|
||||
class SYS_TOKEN_EXPIRE_UPDATE extends \SYSTEM\DB\QP {
|
||||
/**
|
||||
* Get Classname of the QQ
|
||||
*
|
||||
* @return string Returns classname
|
||||
*/
|
||||
public static function get_class(){return \get_class();}
|
||||
|
||||
/**
|
||||
* Get QQs MYSQL Query String
|
||||
*
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'UPDATE system_token SET expire = ?, confirm_time = NULL WHERE token = ?;';
|
||||
}
|
||||
}
|
||||
@ -28,7 +28,7 @@ class SYS_TOKEN_INSERT extends \SYSTEM\DB\QP {
|
||||
* @return string Returns sql Insert Types
|
||||
*/
|
||||
public static function types(){return
|
||||
'ssssis';
|
||||
'ssssi';
|
||||
}
|
||||
|
||||
/**
|
||||
@ -37,7 +37,7 @@ class SYS_TOKEN_INSERT extends \SYSTEM\DB\QP {
|
||||
* @return string Returns MYSQL Query String
|
||||
*/
|
||||
public static function mysql(){return
|
||||
'INSERT INTO system_token (token, class, expire, data, request_user, post_script)'.
|
||||
' VALUES (?, ?, FROM_UNIXTIME(?), ?, ?, ?);';
|
||||
'INSERT INTO system_token (token, class, expire, data, request_user)'.
|
||||
' VALUES (?, ?, FROM_UNIXTIME(?), ?, ?);';
|
||||
}
|
||||
}
|
||||
@ -50,16 +50,28 @@ class token{
|
||||
* @param string $post_script Function to be called after successfull token confirm
|
||||
* @return string Returns token string.
|
||||
*/
|
||||
public static function request($class,$data=array(),$post_script=null){
|
||||
public static function request($class,$data=array(),$ignore_duplicate_data=false){
|
||||
if(!\in_array($class, self::$type_handlers)){
|
||||
throw new \SYSTEM\LOG\ERROR("Token_handler class not known to Token class. Please register it first.");}
|
||||
|
||||
|
||||
// Check for duplicate Data
|
||||
if($ignore_duplicate_data){
|
||||
$duplicate = \SYSTEM\SQL\SYS_TOKEN_DUPLICATE::Q1(array($class,json_encode($data)));
|
||||
if($duplicate){
|
||||
$new_time = \call_user_func(array($class, 'expire'));
|
||||
// Update Expire on Duplicate
|
||||
if($duplicate['expire'] != $new_time || $duplicate['confirm_time']){
|
||||
\SYSTEM\SQL\SYS_TOKEN_EXPIRE_UPDATE::QI(array($new_time,$duplicate['token']));}
|
||||
return $duplicate['token'];
|
||||
}
|
||||
}
|
||||
|
||||
// Insert Token
|
||||
$token = \call_user_func(array($class, 'token'));
|
||||
$res = \SYSTEM\SQL\SYS_TOKEN_INSERT::QI( array( $token, $class,
|
||||
\call_user_func(array($class, 'expire')),
|
||||
json_encode($data),
|
||||
\SYSTEM\SECURITY\security::isLoggedIn() ? \SYSTEM\SECURITY\security::getUser()->id : null,
|
||||
$post_script));
|
||||
\SYSTEM\SECURITY\security::isLoggedIn() ? \SYSTEM\SECURITY\security::getUser()->id : null));
|
||||
return $token;
|
||||
}
|
||||
|
||||
@ -69,53 +81,21 @@ class token{
|
||||
* @param string $token Token string
|
||||
* @return bool Returns true or false or throws an error depending on success.
|
||||
*/
|
||||
public static function confirm($token){
|
||||
public static function confirm($token,$delete_on_success=false){
|
||||
$res = self::get($token);
|
||||
/*if(!$res){
|
||||
throw new \SYSTEM\LOG\ERROR('Token invalid.');}
|
||||
if(!$res['expire'] || strtotime($res['expire']) < time()){
|
||||
throw new \SYSTEM\LOG\ERROR('Token has expired!');}*/
|
||||
if(!$res || !$res['expire'] || strtotime($res['expire']) < time()){
|
||||
if(!$res || $res['confirm_time'] || ($res['expire'] && strtotime($res['expire']) < time())){
|
||||
return false;}
|
||||
|
||||
if(!\in_array($res['class'], self::$type_handlers)){
|
||||
throw new \SYSTEM\LOG\ERROR('Token_handler class not known to Token class. Please register it first.');}
|
||||
|
||||
if(\array_key_exists('post_script',$res) && $res['post_script']){
|
||||
if(!\is_callable($res['post_script'])){
|
||||
throw new \SYSTEM\LOG\ERROR('Post Script required, but could not find it!');}
|
||||
if(!\call_user_func($res['post_script'], $res)){
|
||||
throw new \SYSTEM\LOG\ERROR('Post Script did not execute successfully');}
|
||||
}
|
||||
if(!\call_user_func_array(array($res['class'], 'confirm'),array($res))){
|
||||
throw new \SYSTEM\LOG\ERROR('Token_handler rejected Token.');}
|
||||
return \SYSTEM\SQL\SYS_TOKEN_CONFIRM::QI(array( \SYSTEM\SECURITY\security::isLoggedIn() ? \SYSTEM\SECURITY\security::getUser()->id : null, $token));
|
||||
}
|
||||
|
||||
/**
|
||||
* Call token text_success on success
|
||||
*
|
||||
* @param string $token token_handler Classname
|
||||
* @return string Returns token success string.
|
||||
*/
|
||||
public static function text_success($token){
|
||||
$res = self::get($token);
|
||||
if(!\in_array($res['class'], self::$type_handlers)){
|
||||
throw new \SYSTEM\LOG\ERROR('Token_handler class not known to Token class. Please register it first.');}
|
||||
return \call_user_func_array(array($res['class'], 'text_success'),array($res));
|
||||
}
|
||||
|
||||
/**
|
||||
* Call token text_fail on fail
|
||||
*
|
||||
* @param string $token token_handler Classname
|
||||
* @return string Returns token fail string.
|
||||
*/
|
||||
public static function text_fail($token){
|
||||
$res = self::get($token);
|
||||
if(!\in_array($res['class'], self::$type_handlers)){
|
||||
throw new \SYSTEM\LOG\ERROR('Token_handler class not known to Token class. Please register it first.');}
|
||||
return \call_user_func_array(array($res['class'], 'text_fail'),array($res));
|
||||
return false;}
|
||||
if($delete_on_success){
|
||||
return \SYSTEM\SQL\SYS_TOKEN_DELETE::QI(array($token));
|
||||
} else {
|
||||
return \SYSTEM\SQL\SYS_TOKEN_CONFIRM::QI(array( \SYSTEM\SECURITY\security::isLoggedIn() ? \SYSTEM\SECURITY\security::getUser()->id : null, $token));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@ -46,25 +46,4 @@ class token_change_email implements token_handler{
|
||||
\SYSTEM\SECURITY\security::update_session_data(array('email' => $data['email'],'email_confirmed' => NULL), $res['session_id']);}
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback text_fail on fail
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token fail string.
|
||||
*/
|
||||
public static function text_fail($token_data) {
|
||||
$data = \json_decode($token_data['data'],true);
|
||||
return 'Could NOT change your Account\'s EMail-Address to '.$data['email'].'. Token is expired or invalid.';}
|
||||
|
||||
/**
|
||||
* Callback text_success on success
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token success string.
|
||||
*/
|
||||
public static function text_success($token_data) {
|
||||
$data = \json_decode($token_data['data'],true);
|
||||
return 'Changed your Account\'s EMail-Address to '.$data['email'].'.';}
|
||||
|
||||
}
|
||||
@ -46,22 +46,4 @@ class token_confirm_email implements token_handler{
|
||||
\SYSTEM\SECURITY\security::update_session_data(array('email_confirmed' => 1), $res['session_id']);}
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback text_fail on fail
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token fail string.
|
||||
*/
|
||||
public static function text_fail($token_data) {
|
||||
return 'Could NOT confirm your EMail-Address. Token is expired or invalid.';}
|
||||
|
||||
/**
|
||||
* Callback text_success on success
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token success string.
|
||||
*/
|
||||
public static function text_success($token_data) {
|
||||
return 'Confirmed your EMail-Address.';}
|
||||
}
|
||||
@ -36,20 +36,4 @@ interface token_handler {
|
||||
* @return bool Returns true or false.
|
||||
*/
|
||||
static function confirm($token_data);
|
||||
|
||||
/**
|
||||
* Callback text_success on success
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token success string.
|
||||
*/
|
||||
static function text_success($token_data);
|
||||
|
||||
/**
|
||||
* Callback text_success on success
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token success string.
|
||||
*/
|
||||
static function text_fail($token_data);
|
||||
}
|
||||
@ -41,22 +41,4 @@ class token_reset_password implements token_handler{
|
||||
public static function confirm($token_data){
|
||||
$data = \json_decode($token_data['data'],true);
|
||||
return \SYSTEM\SQL\SYS_SECURITY_RESET_PASSWORD::QI(array($data['pw_sha1'],$data['user'])) ? true : false;}
|
||||
|
||||
/**
|
||||
* Callback text_fail on fail
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token fail string.
|
||||
*/
|
||||
public static function text_fail($token_data) {
|
||||
return 'Could NOT reset your Password. Token is expired or invalid.';}
|
||||
|
||||
/**
|
||||
* Callback text_success on success
|
||||
*
|
||||
* @param array $token_data Token Data
|
||||
* @return string Returns token success string.
|
||||
*/
|
||||
public static function text_success($token_data) {
|
||||
return 'Changed your Password successfully.';}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user