b0y-101 Mini Shell


Current Path : E:/www/risk/libraries/vendor/web-auth/cose-lib/src/Algorithm/Signature/ECDSA/
File Upload :
Current File : E:/www/risk/libraries/vendor/web-auth/cose-lib/src/Algorithm/Signature/ECDSA/ES384.php

<?php

declare(strict_types=1);

/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2014-2019 Spomky-Labs
 *
 * This software may be modified and distributed under the terms
 * of the MIT license.  See the LICENSE file for details.
 */

namespace Cose\Algorithm\Signature\ECDSA;

use Cose\Key\Ec2Key;
use Cose\Key\Key;

final class ES384 extends ECDSA
{
    public const ID = -35;

    public static function identifier(): int
    {
        return self::ID;
    }

    public function sign(string $data, Key $key): string
    {
        $signature = parent::sign($data, $key);

        return ECSignature::fromAsn1($signature, $this->getSignaturePartLength());
    }

    public function verify(string $data, Key $key, string $signature): bool
    {
        if (mb_strlen($signature, '8bit') !== $this->getSignaturePartLength()) {
            @trigger_error('Since v2.1, the method "verify" will only accept raw ECDSA signature in v3.0 and ASN.1 structures will be rejected', E_USER_DEPRECATED);
        } else {
            $signature = ECSignature::toAsn1($signature, $this->getSignaturePartLength());
        }

        return parent::verify($data, $key, $signature);
    }

    protected function getHashAlgorithm(): int
    {
        return OPENSSL_ALGO_SHA384;
    }

    protected function getCurve(): int
    {
        return Ec2Key::CURVE_P384;
    }

    protected function getSignaturePartLength(): int
    {
        return 96;
    }
}

Copyright © 2019 by b0y-101