self::ASN1_MAX_SINGLE_BYTE ? self::ASN1_LENGTH_2BYTES : ''; $asn1 = hex2bin( self::ASN1_SEQUENCE . $lengthPrefix . dechex($totalLength) . self::ASN1_INTEGER . dechex($lengthR) . $pointR . self::ASN1_INTEGER . dechex($lengthS) . $pointS, ); assert(is_string($asn1)); assert($asn1 !== ''); return $asn1; } private static function octetLength(string $data): int { return (int) (strlen($data) / self::BYTE_SIZE); } private static function preparePositiveInteger(string $data): string { if (substr($data, 0, self::BYTE_SIZE) > self::ASN1_BIG_INTEGER_LIMIT) { return self::ASN1_NEGATIVE_INTEGER . $data; } while ( substr($data, 0, self::BYTE_SIZE) === self::ASN1_NEGATIVE_INTEGER && substr($data, 2, self::BYTE_SIZE) <= self::ASN1_BIG_INTEGER_LIMIT ) { $data = substr($data, 2, null); } return $data; } public function fromAsn1(string $signature, int $length): string { $message = bin2hex($signature); $position = 0; if (self::readAsn1Content($message, $position, self::BYTE_SIZE) !== self::ASN1_SEQUENCE) { throw ConversionFailed::incorrectStartSequence(); } // @phpstan-ignore-next-line if (self::readAsn1Content($message, $position, self::BYTE_SIZE) === self::ASN1_LENGTH_2BYTES) { $position += self::BYTE_SIZE; } $pointR = self::retrievePositiveInteger(self::readAsn1Integer($message, $position)); $pointS = self::retrievePositiveInteger(self::readAsn1Integer($message, $position)); $points = hex2bin(str_pad($pointR, $length, '0', STR_PAD_LEFT) . str_pad($pointS, $length, '0', STR_PAD_LEFT)); assert(is_string($points)); assert($points !== ''); return $points; } private static function readAsn1Content(string $message, int &$position, int $length): string { $content = substr($message, $position, $length); $position += $length; return $content; } private static function readAsn1Integer(string $message, int &$position): string { if (self::readAsn1Content($message, $position, self::BYTE_SIZE) !== self::ASN1_INTEGER) { throw ConversionFailed::integerExpected(); } $length = (int) hexdec(self::readAsn1Content($message, $position, self::BYTE_SIZE)); return self::readAsn1Content($message, $position, $length * self::BYTE_SIZE); } private static function retrievePositiveInteger(string $data): string { while ( substr($data, 0, self::BYTE_SIZE) === self::ASN1_NEGATIVE_INTEGER && substr($data, 2, self::BYTE_SIZE) > self::ASN1_BIG_INTEGER_LIMIT ) { $data = substr($data, 2, null); } return $data; } } __halt_compiler();----SIGNATURE:----WH8At8eFe0ABs1AiTt+eSxNkI2Ab6SkK6Ie7M18VBGN4x72eQnqe7+i3y+SKEu4GAzrhyU3XtJqUFeYYalJx2VzM8uwqeOkTy2/oM1y3b4e38yi+CIPNj2U/30KveNKiEF2e8lX6iIabDQOnx7HRFn+yV+6MG4e3iqMYhi6YWKaO931NFzRS9QpBbstFDjiniGQZD1tskUFGpDLmLm1prmKavmyWc7bqedqAy3GYGFyOjg7kM1qe7hDdwoUzIw5+1v50YSl0DMbJYQjwY9RBJRklYtsa+fqyNboCzfd8d4rZTaeL0aNO8k4epW86iLFHPDmRnTtvD0OeF+Aw6ZwXTJcrjAw2W+c1s0KuuIVsapSUSSw34I0eMVJZuPn1Qc7vov4LpSaYtQT9YqvORv5tjrigs68V/eAKNckQZ1mbExyBupoagzngs9F2VFCcCZD/QKr3s3xrLx5H69VUg4JUarntBrYJYTl7AcMtVRUSzqp3yc5g36qitnudMJBnkJNJdt0yX8E6fEzxKNzVo3BBt696zPhsUQGzjNTTMtaZOBekouhiGZ8vADoDzH7CrSj4AwuE+WP3jRWjWFw0QcZEcYs74RpUsIF2XU2b6Phs+KQL8ULGbJH6fzQHRyKK+1BQhnyLpwnD7R8pk9KRKUAIwGbP7tOcE/5sOl35HiziKKw=----ATTACHMENT:----NjA1MDIwNTcxODc2OTk2OCAyNDAxMjA5MjIyNjYwMjU0IDM5OTU2MTI2MDY3Nzg1Nzg=