HEX
Server: LiteSpeed
System: Linux php-prod-3.spaceapp.ru 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC 2025 x86_64
User: sarli3128 (1010)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/marketing.cfbon.ru/public_html/vendor/google/cloud-core/src/Testing/KeyPairGenerateTrait.php
<?php
/**
 * Copyright 2017 Google Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

namespace Google\Cloud\Core\Testing;

use Google\Cloud\Storage\EncryptionTrait;
use phpseclib\Crypt\RSA as RSA2;
use phpseclib3\Crypt\RSA as RSA3;

/**
 * Trait KeyPairGenerateTrait implements key pair generation functions used for testing
 *
 * @experimental
 * @internal
 */
trait KeyPairGenerateTrait
{
    use EncryptionTrait;

    private function getKeyPair()
    {
        if (class_exists(RSA3::class)) {
            $key = RSA3::createKey();
            $key = $key->withPadding(RSA3::SIGNATURE_PKCS1)
                ->withHash('sha256');

            return [$key->toString('PKCS1'), $key->getPublicKey()];
        }

        $rsa = new RSA2;
        $rsa->setSignatureMode(RSA2::SIGNATURE_PKCS1);
        $rsa->setHash('sha256');

        $key = $rsa->createKey();
        usleep(500);
        return [$key['privatekey'], $key['publickey']];
    }

    private function verifySignature($privateKey, $input, $signature)
    {
        $verify = $this->signString($privateKey, $input);

        return urlencode(base64_encode($verify)) === $signature;
    }
}