X-Git-Url: https://git-public.kairo.at/?p=php-utility-classes.git;a=blobdiff_plain;f=include%2Fclasses%2Frrdstat.php-class;h=c0d752019505048f97c0ebe4e80e3118cac1bd18;hp=6b241c7d281f0faf2c90304f47a8b009296717d6;hb=f21e94d918018aa0bf38e9a1270564b1fcb0ce07;hpb=099bd59fede8a97b821b13ad8a931239c9c751bf diff --git a/include/classes/rrdstat.php-class b/include/classes/rrdstat.php-class index 6b241c7..c0d7520 100644 --- a/include/classes/rrdstat.php-class +++ b/include/classes/rrdstat.php-class @@ -1,6 +1,130 @@ + * + * ***** END LICENSE BLOCK ***** */ + class rrdstat { + // rrdstat PHP class + // rrdtool statistics functions + // + // function rrdstat($rrdconfig, [$conf_id]) + // CONSTRUCTOR + // if $conf_id is set, $rrdconfig is a total configuration set + // else it's the configuration for this one RRD + // currently only a config array is supported, XML config is planned + // + // var $rrd_file + // RRD file name + // + // var $basename + // base name for this RRD (usually file name without .rrd) + // + // var $config_all + // complete, raw configuration array set + // + // var $config_raw + // configuration array set for current RRD + // + // var $config_graph + // configuration array set for default graph in this RRD + // + // var $config_page + // configuration array set for default page in this RRD + // + // var $rrd_fields + // definition of this RRD's fields + // + // var $rra_base + // definition of this RRD's base RRAs + // + // var $rrd_step + // basic stepping of this RRD in seconds (default: 300) + // + // var $rra_add_max + // should RRAs for MAX be added for every base RRA? (bool, default: true) + // + // var $status + // status of the RRD (unused/ok/readonly/graphonly) + // note that most functions require certain status values + // (e.g. update only works if status is ok, graph for ok/readonly/graphonly) + // + // function set_def($rrdconfig, [$conf_id]) + // set definitions based on given configuration + // [intended for internal use, called by the constructor] + // + // function create() + // create RRD file according to set config + // + // function update([$upArray]) + // feed new data into RRD (either use given array of values or use auto-update info from config) + // + // function fetch([$cf] = 'AVERAGE', $resolution = null, $start = null, $end = null) + // fetch data from the defined RRD + // using given consolidation function [default is AVERAGE], + // resolution (seconds, default is the RRD's stepping), + // start and end times (unix epoch, defaults are the RRD's last update time) + // + // function last_update() + // fetch time of last update in this RRD file + // + // function graph([$timeframe], [$sub], [$extra]) + // create a RRD graph (and return all meta info in a flat string) + // for given timeframe (day [default]/week/month/year), + // sub-graph ID (if given) and extra config options (if given) + // + // function graph_plus([$timeframe], [$sub], [$extra]) + // create a RRD graph (see above) and return meta info as a ready-to-use array + // + // function page([$sub], [$page_extras], [$graph_extras]) + // create a (HTML) page and return it in a string + // for given sub-page ID (if given, default is a simple HTML page) + // and extra page and graph config options (if given) + // + // function simple_html([$sub], [$page_extras], [$graph_extras]) + // create a simple (MRTG-like) HTML page and return it in a string + // XXX: this is here temporarily for compat only, it's preferred to use page()! + // + // function page_index($pconf) + // create a bare, very simple index list HTML page and return it in a string + // using given page config options + // [intended for internal use, called by page()] + // + // function page_overview($pconf, [$graph_extras]) + // create an overview HTML page (including graphs) and return it in a string + // using given page config options and extra graph options (if given) + // [intended for internal use, called by page()] + // + // function page_simple($pconf, [$graph_extras]) + // create a simple (MRTG-like) HTML page and return it in a string + // using given page config options and extra graph options (if given) + // [intended for internal use, called by page()] + // + // function h_page_statsArray($pconf) + // return array of stats to list on a page, using given page config options + // [intended for internal use, called by page_*()] + // + // function h_page_footer() + // return generic page footer + // [intended for internal use, called by page_*()] + // + // function text_quote($text) + // return a quoted/escaped text for use in rrdtool commandline text fields var $rrd_file = null; var $basename = null; @@ -68,11 +192,15 @@ class rrdstat { $this->rrd_file = $iinfo['file']; $this->basename = (substr($this->rrd_file, -4) == '.rrd')?substr($this->rrd_file, 0, -4):$this->rrd_file; } + elseif (!is_null($conf_id) && file_exists($conf_id.'.rrd')) { + $this->rrd_file = $conf_id.'.rrd'; + $this->basename = $conf_id; + } else { $this->basename = !is_null($conf_id)?$conf_id:'xxx.unknown'; } - if (isset($iinfo['file'])) { + if (!is_null($this->rrd_file)) { // fields (data sources, DS) // name - DS name // type - one of COUNTER, GAUGE, DERIVE, ABSOLUTE @@ -207,6 +335,13 @@ class rrdstat { $upvals[] = is_null($val)?'U':$val; } } + if (in_array('L', $upvals)) { + // for at least one value, we need to set the same as the last recorded value + $lastvals = $this->fetch(); + foreach (array_keys($upvals, 'L') as $akey) { + $upvals[$akey] = $lastvals[$akey]; + } + } $return = null; if (count($upvals)) { $update_cmd = 'rrdtool update '.$this->rrd_file.' N:'.implode(':', $upvals); @@ -263,6 +398,17 @@ class rrdstat { return $fresult; } + function last_update() { + // fetch time of last update in this RRD file + static $last_update; + if (!isset($last_update) && in_array($this->status, array('ok','readonly'))) { + $last_cmd = 'rrdtool last '.$this->rrd_file; + $return = trim(`$last_cmd 2>&1`); + $last_update = is_numeric($return)?$return:null; + } + return isset($last_update)?$last_update:null; + } + function graph($timeframe = 'day', $sub = null, $extra = null) { // create a RRD graph static $gColors; @@ -301,7 +447,7 @@ class rrdstat { if (isset($gconf['path'])) { $fname = $gconf['path'].'/'.$fname; } $fname = str_replace('//', '/', $fname); - $graphrows = array(); $gC = 0; + $graphrows = array(); $specialrows = array(); $gC = 0; $gDefs = ''; $gGraphs = ''; $addSpecial = ''; if ($timeframe == 'day') { @@ -389,6 +535,10 @@ class rrdstat { } $grow['gType'] = ((count($this->rrd_fields)==2) && ($key==0))?'AREA':'LINE1'; $grow['color'] = $gColors[$gC++]; if ($gC >= count($gColors)) { $gC = 0; } + if (isset($ds['legend'])) { + $grow['legend'] = $ds['legend']; + if (!isset($gconf['show_legend'])) { $gconf['show_legend'] = true; } + } $graphrows[] = $grow; } } @@ -492,6 +642,36 @@ class rrdstat { return $return; } + function graph_plus($timeframe = 'day', $sub = null, $extra = null) { + // create a RRD graph and return meta info as a ready-to-use array + $gmeta = array('filename'=>null); + $ret = $this->graph($timeframe, $sub, $extra); + if (strpos($ret, "\n\n") !== false) { $gmeta['graph_cmd'] = substr($ret, 0, strpos($ret, "\n\n")); $ret = substr($ret, strpos($ret, "\n\n")+2); } + else { $gmeta['graph_cmd'] = null; } + $grout = explode("\n", $ret); + foreach ($grout as $gline) { + if (preg_match('/^file:(.+)$/', $gline, $regs)) { + $gmeta['filename'] = $regs[1]; + } + elseif (preg_match('/^(\d+)x(\d+)$/', $gline, $regs)) { + $gmeta['width'] = $regs[1]; $gmeta['height'] = $regs[2]; + } + elseif (preg_match('/^([^\|]+)\|([^|]+)\|([^\|]*)$/', $gline, $regs)) { + $gmeta['data'][$regs[1]][$regs[2]] = $regs[3]; + } + elseif (preg_match('/^([^\|]+)\|([^\|]*)$/', $gline, $regs)) { + $gmeta['var'][$regs[1]] = $regs[2]; + } + elseif (strlen(trim($gline))) { + $gmeta['info'][] = $gline; + } + } + if (is_null($gmeta['filename'])) { + $gmeta['filename'] = $this->basename.(!is_null($sub)?'-'.$sub:'').'-'.$timeframe.'.png'; + } + return $gmeta; + } + function page($sub = null, $page_extras = null, $graph_extras = null) { // create a (HTML) page and return it in a string @@ -535,7 +715,7 @@ class rrdstat { function page_index($pconf) { // create a bare, very simple index list HTML page and return it in a string - $ptitle = isset($pconf['title_page'])?$pconf['title_page']:'Index - RRD statistics'; + $ptitle = isset($pconf['title_page'])?$pconf['title_page']:'RRD statistics index'; $out = ''; $out .= ''.$ptitle.''; @@ -552,42 +732,16 @@ class rrdstat { $out .= ''; $out .= '

'.$ptitle.'

'; - $out .= '

The following RRD stats are available:

'; - - $out .= '