1
0
mirror of https://github.com/Yubico/yubikey-val.git synced 2024-11-29 09:24:12 +01:00
yubikey-val/ykval-munin-ksmlatency.php

84 lines
2.8 KiB
PHP
Raw Normal View History

2010-06-22 17:55:52 +02:00
#!/usr/bin/php
<?php
2013-02-04 17:36:04 +01:00
# Copyright (c) 2010-2013 Yubico AB
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# * Redistributions in binary form must reproduce the above
# copyright notice, this list of conditions and the following
# disclaimer in the documentation and/or other materials provided
# with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2010-06-22 17:55:52 +02:00
set_include_path(get_include_path() . PATH_SEPARATOR .
"/etc/yubico/val:/usr/share/yubikey-val");
2010-06-22 17:55:52 +02:00
require_once 'ykval-config.php';
2010-11-15 11:48:52 +01:00
function url2shortname ($url) {
if (preg_match("/^[^\/]+\/\/([a-z0-9-]+)/", $url, $name)==0){
echo "Cannot match URL hostname: " . $url . "\n";
2010-06-22 17:55:52 +02:00
exit (1);
}
2010-11-15 11:48:52 +01:00
return $name[1];
2010-06-22 17:55:52 +02:00
}
2010-11-15 11:48:52 +01:00
2010-06-22 17:55:52 +02:00
$ksms = otp2ksmurls ("ccccccccfnkjtvvijktfrvvginedlbvudjhjnggndtck", 16);
2010-11-15 11:48:52 +01:00
$shortksms = array_map("url2shortname", $ksms);
2010-06-22 17:55:52 +02:00
2010-06-22 18:01:39 +02:00
if ($argc==2 && strcmp($argv[1], "autoconf") == 0) {
2010-06-22 17:59:25 +02:00
print "yes\n";
2010-06-22 18:01:39 +02:00
exit (0);
2010-06-22 17:59:25 +02:00
}
2010-06-22 18:01:39 +02:00
if ($argc==2 && strcmp($argv[1], "config") == 0) {
2010-06-22 17:55:52 +02:00
echo "multigraph ykval_ksmlatency\n";
2010-06-22 17:55:52 +02:00
echo "graph_title KSM latency\n";
echo "graph_vlabel Average KSM Decrypt Latency (seconds)\n";
echo "graph_category ykval\n";
echo "graph_width 400\n";
foreach ($shortksms as $shortksm) {
echo "${shortksm}_avgwait.label ${shortksm}\n";
echo "${shortksm}_avgwait.type GAUGE\n";
echo "${shortksm}_avgwait.info Average wait time for KSM decrypt\n";
echo "${shortksm}_avgwait.min 0\n";
echo "${shortksm}_avgwait.draw LINE1\n";
}
2010-06-22 18:01:39 +02:00
exit (0);
2010-06-22 17:55:52 +02:00
}
echo "multigraph ykval_ksmlatency\n";
2010-06-22 17:55:52 +02:00
foreach ($ksms as $ksm) {
2010-11-15 11:48:52 +01:00
$shortksm = url2shortname ($ksm);
2010-06-22 22:18:38 +02:00
$time = `curl --silent --write-out '%{time_total}' --max-time 3 '$ksm' -o /dev/null`;
if (preg_match("/^3\./", $time)) {
$time = "timeout";
}
if (preg_match("/^0\.000/", $time)) {
$time = "error";
}
2010-06-22 17:55:52 +02:00
echo "${shortksm}_avgwait.value $time\n";
}