streams/Zotlabs/Lib/JSalmon.php

72 lines
1.8 KiB
PHP
Raw Normal View History

<?php
namespace Zotlabs\Lib;
2018-06-28 02:22:12 +00:00
use Zotlabs\Web\HTTPSig;
class JSalmon {
static function sign($data,$key_id,$key,$data_type = 'application/x-zot+json') {
$data = base64url_encode(json_encode($data,true),true); // strip padding
$encoding = 'base64url';
$algorithm = 'RSA-SHA256';
$data = preg_replace('/\s+/','',$data);
// precomputed base64url encoding of data_type, encoding, algorithm concatenated with periods
$precomputed = '.' . base64url_encode($data_type,true) . '.YmFzZTY0dXJs.UlNBLVNIQTI1Ng';
2018-12-14 01:16:01 +00:00
$signature = base64url_encode(Crypto::sign($data . $precomputed, $key), true);
return ([
'signed' => true,
'data' => $data,
'data_type' => $data_type,
'encoding' => $encoding,
'alg' => $algorithm,
'sigs' => [
2017-10-06 05:01:45 +00:00
'value' => $signature,
'key_id' => base64url_encode($key_id, true)
]
]);
}
2018-06-28 02:22:12 +00:00
static function verify($x) {
logger('verify');
2018-06-28 02:22:12 +00:00
$ret = [ 'results' => [] ];
if(! is_array($x)) {
return $false;
}
if(! ( array_key_exists('signed',$x) && $x['signed'])) {
return $false;
}
$signed_data = preg_replace('/\s+/','',$x['data']) . '.'
. base64url_encode($x['data_type'],true) . '.'
. base64url_encode($x['encoding'],true) . '.'
. base64url_encode($x['alg'],true);
2020-07-15 19:52:08 +00:00
$key = HTTPSig::get_key(EMPTY_STR,'zot6',base64url_decode($x['sigs']['key_id']));
2018-07-12 01:02:25 +00:00
logger('key: ' . print_r($key,true));
if($key['portable_id'] && $key['public_key']) {
2018-12-14 01:16:01 +00:00
if(Crypto::verify($signed_data,base64url_decode($x['sigs']['value']),$key['public_key'])) {
logger('verified');
$ret = [ 'success' => true, 'signer' => $key['portable_id'], 'hubloc' => $key['hubloc'] ];
2018-06-28 02:22:12 +00:00
}
}
return $ret;
}
static function unpack($data) {
return json_decode(base64url_decode($data),true);
}
}