Server IP : 172.67.158.161 / Your IP : 18.119.143.138 Web Server : LiteSpeed System : Linux business53.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : giankuin ( 1871) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/giankuin/dietcontrungnhanh.com/wp-content/plugins/ithemes-security-pro/pro/webauthn/ |
Upload File : |
<?php namespace iThemesSecurity\WebAuthn; use iThemesSecurity\Lib\Result; use iThemesSecurity\WebAuthn\DTO\BinaryString; use iThemesSecurity\WebAuthn\DTO\PublicKeyCredentialRequestOptions; use iThemesSecurity\WebAuthn\DTO\UserVerificationRequirement; final class PublicKeyCredentialRequestOptions_Factory_Default implements PublicKeyCredentialRequestOptions_Factory { /** @var PublicKeyCredentialUserEntity_Factory */ protected $user_factory; /** @var PublicKeyCredentialRpEntity_Factory */ protected $rp_factory; /** @var PublicKeyCredential_Record_Repository */ protected $credentials_repository; public function __construct( PublicKeyCredentialUserEntity_Factory $user_factory, PublicKeyCredentialRpEntity_Factory $rp_factory, PublicKeyCredential_Record_Repository $credentials_repository ) { $this->user_factory = $user_factory; $this->rp_factory = $rp_factory; $this->credentials_repository = $credentials_repository; } public function make( ?\WP_User $user ): Result { $rp_entity = $this->rp_factory->make(); $user_entity = $user ? $this->user_factory->make( $user ) : null; $credentials = $user && $user_entity->is_success() ? $this->credentials_repository->get_credentials_for_user( $user_entity->get_data() ) : Result::success( [] ); try { $challenge = Result::success( new BinaryString( random_bytes( 64 ) ) ); } catch ( \Exception $e ) { $challenge = Result::error( new \WP_Error( 'itsec.webauthn.request-options.no-random-bytes', __( 'Could not generate a random WebAuthn challenge.', 'it-l10n-ithemes-security-pro' ) ) ); } $result = Result::combine( $rp_entity, $user_entity, $credentials ); if ( ! $result->is_success() ) { return Result::combine( Result::error( new \WP_Error( 'itsec.webauthn.request-options.error', __( 'Could not prepare to access a WebAuthn credential.', 'it-l10n-ithemes-security-pro' ) ) ), $result ); } $allow_credentials = array_map( function ( PublicKeyCredential_Record $record ) { return $record->as_descriptor(); }, $credentials->get_data() ); if ( 'required' === \ITSEC_Modules::get_setting( 'passwordless-login', 'passkey_user_verification' ) ) { $userVerification = UserVerificationRequirement::REQUIRED; } else { $userVerification = UserVerificationRequirement::PREFERRED; } return Result::success( new PublicKeyCredentialRequestOptions( $challenge->get_data(), $rp_entity->get_data()->get_id(), $allow_credentials, $userVerification ) ); } }