HEX
Server: LiteSpeed
System: Linux vearitale.com 5.14.0-570.32.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Aug 6 11:30:41 EDT 2025 x86_64
User: yunab9059 (2007)
PHP: 8.3.21
Disabled: NONE
Upload Files
File: /home/yunabox.top/public_html/wp-content/plugins/CyberSMTP/vendor/starkbank/ecdsa/src/signature.php
<?php

namespace EllipticCurve;

use EllipticCurve\Utils\Der;
use EllipticCurve\Utils\Binary;
use EllipticCurve\Utils\DerFieldType;


class Signature
{
    public $r, $s;
    public $recoveryId;

    function __construct($r, $s, $recoveryId=null)
    {
        $this->r = $r;
        $this->s = $s;
        $this->recoveryId = $recoveryId;
    }

    function toDer($withRecoveryId=false)
    {
        $hexadecimal = $this->_toString();
        $encodedSequence = Binary::byteStringFromHex($hexadecimal);
        if (!$withRecoveryId)
            return $encodedSequence;
        return chr(27 + $this->recoveryId) . $encodedSequence;
    }

    function toBase64($withRecoveryId=false)
    {
        return Binary::base64FromByteString($this->toDer($withRecoveryId));
    }

    static function fromDer($string, $recoveryByte=false)
    {
        $recoveryId = null;
        if ($recoveryByte) {
            $recoveryId = is_int($string[0]) ? $string[0] : ord($string[0]);
            $recoveryId -= 27;
            $string = substr($string, 1);
        }

        $hexadecimal = Binary::hexFromByteString($string);
        return Signature::_fromString($hexadecimal, $recoveryId);
    }

    static function fromBase64($string, $recoveryByte=false)
    {
        $der = Binary::byteStringFromBase64($string);
        return Signature::fromDer($der, $recoveryByte);
    }

    function _toString()
    {
        return Der::encodeConstructed(
            Der::encodePrimitive(DerFieldType::$integer, $this->r),
            Der::encodePrimitive(DerFieldType::$integer, $this->s)
        );
    }

    static function _fromString($string, $recoveryId=null)
    {
        list($r, $s) = Der::parse($string)[0];
        return new Signature($r, $s, $recoveryId);
    }
}