sforkowany z mirror/friendica
Diaspora: Avoid warning "supplied key param cannot be coerced into a public key"
rodzic
3ecc53b448
commit
c9095386c8
|
@ -222,10 +222,14 @@ class Diaspora
|
||||||
$signable_data = $msg.".".base64url_encode($type).".".base64url_encode($encoding).".".base64url_encode($alg);
|
$signable_data = $msg.".".base64url_encode($type).".".base64url_encode($encoding).".".base64url_encode($alg);
|
||||||
|
|
||||||
$key = self::key($handle);
|
$key = self::key($handle);
|
||||||
|
if ($key == '') {
|
||||||
|
logger("Couldn't get a key for handle " . $handle . ". Discarding.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
$verify = Crypto::rsaVerify($signable_data, $sig, $key);
|
$verify = Crypto::rsaVerify($signable_data, $sig, $key);
|
||||||
if (!$verify) {
|
if (!$verify) {
|
||||||
logger('Message did not verify. Discarding.');
|
logger('Message from ' . $handle . ' did not verify. Discarding.');
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -321,6 +325,11 @@ class Diaspora
|
||||||
// Get the senders' public key
|
// Get the senders' public key
|
||||||
$key_id = $base->sig[0]->attributes()->key_id[0];
|
$key_id = $base->sig[0]->attributes()->key_id[0];
|
||||||
$author_addr = base64_decode($key_id);
|
$author_addr = base64_decode($key_id);
|
||||||
|
if ($author_addr == '') {
|
||||||
|
logger('No author could be decoded. Discarding. Message: ' . $xml);
|
||||||
|
System::httpExit(400);
|
||||||
|
}
|
||||||
|
|
||||||
$key = self::key($author_addr);
|
$key = self::key($author_addr);
|
||||||
|
|
||||||
$verify = Crypto::rsaVerify($signed_data, $signature, $key);
|
$verify = Crypto::rsaVerify($signed_data, $signature, $key);
|
||||||
|
|
Ładowanie…
Reference in New Issue