1
0
mirror of https://github.com/Yubico/yubikey-val.git synced 2025-01-20 10:52:15 +01:00
yubikey-val/common.php

75 lines
1.8 KiB
PHP
Raw Normal View History

2008-09-26 03:21:11 +00:00
<?php
define('S_OK', 'OK');
define('S_BAD_OTP', 'BAD_OTP');
define('S_BAD_CLIENT', 'BAD_CLIENT'); // New, added by paul 20080920
define('S_REPLAYED_OTP', 'REPLAYED_OTP');
define('S_BAD_SIGNATURE', 'BAD_SIGNATURE');
define('S_MISSING_PARAMETER', 'MISSING_PARAMETER');
//define('S_NO_SUCH_CLIENT', 'NO_SUCH_CLIENT'); // Deprecated by paul 20080920
define('S_OPERATION_NOT_ALLOWED', 'OPERATION_NOT_ALLOWED');
define('S_BACKEND_ERROR', 'BACKEND_ERROR');
2008-09-26 05:00:41 +00:00
function debug($msg, $exit = false) {
2008-09-26 03:21:11 +00:00
global $trace;
if ($trace) {
if (is_array($msg)) {
print_r($msg);
} else {
2008-09-26 05:00:41 +00:00
echo 'debug> ' . $msg;
2008-09-26 03:21:11 +00:00
}
echo "\n";
}
if ($exit) {
2008-09-26 05:00:41 +00:00
die('<font color=red><h4>Exit</h4></font>');
2008-09-26 03:21:11 +00:00
}
}
2008-09-26 05:00:41 +00:00
function genRandRaw($len) {
$h = hash_hmac('sha1', rand(9999,9999999), 'dj*ccbcuiiurubrvnubcdluul', true);
$a = str_split($h);
//print_r($a);
$a = array_slice($a, 0, $len);
//print_r($a);
$s = implode($a);
//outputToFile('out', $s);
return $s;
2008-09-26 03:21:11 +00:00
}
2008-09-27 09:04:49 +00:00
function getUTCTimeStamp() {
date_default_timezone_set('UTC');
return date('Y-m-d\TH:i:s\ZZ', time());
}
// Sign a http query string in the array of key-value pairs
// return b64 encoded hmac hash
function sign($a, $apiKey) {
ksort($a);
$qs = '';
$n = count($a);
$i = 0;
foreach (array_keys($a) as $key) {
$qs .= $key.'='.$a[$key];
if (++$i < $n) {
$qs .= '&';
}
}
// Generate the signature
//debug('API key: '.$apiKey); // API key of the client
debug('Signing: '.$qs);
// the TRUE at the end states we want the raw value, not hexadecimal form
$hmac = hash_hmac('sha1', utf8_encode($qs), $apiKey, true);
$hmac = base64_encode($hmac);
return $hmac;
} // SignWithTime
2008-09-26 05:00:41 +00:00
function outputToFile($outFname, $content, $mode, $append = false) {
$out = fopen($outFname, ($append ? "a" : "w"));
fwrite($out, $content);
fclose($out);
2008-09-26 03:21:11 +00:00
}
?>