芝麻web文件管理V1.00
编辑当前文件:/home/ephorei/www/wp-content/plugins/sureforms/inc/ai-form-builder/ai-auth.php
get_header( 'X-WP-Nonce' ) ); if ( ! wp_verify_nonce( sanitize_text_field( $nonce ), 'wp_rest' ) ) { wp_send_json_error( __( 'Nonce verification failed.', 'sureforms' ) ); } // Generate a random key of 16 characters. $this->key = wp_generate_password( 16, false ); // Prepare the token data. $token_data = [ 'redirect-back' => site_url() . '/wp-admin/admin.php?page=add-new-form&method=ai', 'key' => $this->key, 'site-url' => site_url(), 'nonce' => wp_create_nonce( 'ai_auth_nonce' ), ]; $encoded_token_data = wp_json_encode( $token_data ); if ( empty( $encoded_token_data ) ) { wp_send_json_error( [ 'message' => __( 'Failed to encode the token data.', 'sureforms' ) ] ); } // Send the token data to the frontend for redirection. wp_send_json_success( SRFM_BILLING_PORTAL . 'auth/?token=' . base64_encode( $encoded_token_data ) ); // phpcs:ignore WordPress.PHP.DiscouragedPHPFunctions.obfuscation_base64_encode } /** * Handles the access key. * * @param \WP_REST_Request $request The request object. * @since 0.0.8 * @return void */ public function handle_access_key( $request ) { $nonce = Helper::get_string_value( $request->get_header( 'X-WP-Nonce' ) ); if ( ! wp_verify_nonce( sanitize_text_field( $nonce ), 'wp_rest' ) ) { wp_send_json_error( __( 'Nonce verification failed.', 'sureforms' ) ); } // get body data. $body = json_decode( $request->get_body(), true ); if ( empty( $body ) ) { wp_send_json_error( [ 'message' => __( 'Error processing Access Key.', 'sureforms' ) ] ); } // get access key. $access_key = is_array( $body ) && ! empty( $body['accessKey'] ) ? Helper::get_string_value( $body['accessKey'] ) : ''; // decrypt the access key. if ( ! empty( $access_key ) ) { $this->decrypt_access_key( $access_key, $this->key ); } else { wp_send_json_error( [ 'message' => __( 'No access key provided.', 'sureforms' ) ] ); } } /** * Decrypts a string using OpenSSL decryption. * * @param string $data The data to decrypt. * @param string $key The encryption key. * @param string $method The encryption method (e.g., AES-256-CBC). * @since 0.0.8 * @return string|false The decrypted string or false on failure. */ public function decrypt_access_key( $data, $key, $method = 'AES-256-CBC' ) { // Decode the data and split IV and encrypted data. $decoded_data = base64_decode( $data ); // phpcs:ignore WordPress.PHP.DiscouragedPHPFunctions.obfuscation_base64_decode // if the data is not base64 encoded then return false. if ( empty( $decoded_data ) ) { return false; } // split the key and encrypted data. [$key, $encrypted] = explode( '::', $decoded_data, 2 ); // Decrypt the data using the key. $decrypted = openssl_decrypt( $encrypted, $method, $key, 0, $key ); // if the decryption returns false then send error. if ( empty( $decrypted ) ) { wp_send_json_error( [ 'message' => __( 'Failed to decrypt the access key.', 'sureforms' ) ] ); } // json decode the decrypted data. $decrypted_data_array = json_decode( $decrypted, true ); if ( ! is_array( $decrypted_data_array ) || empty( $decrypted_data_array ) ) { wp_send_json_error( [ 'message' => __( 'Failed to json decode the decrypted data.', 'sureforms' ) ] ); } // verify the nonce that comes in $encrypted_email_array. if ( ! empty( $decrypted_data_array['nonce'] ) && ! wp_verify_nonce( $decrypted_data_array['nonce'], 'ai_auth_nonce' ) ) { wp_send_json_error( [ 'message' => __( 'Nonce verification failed.', 'sureforms' ) ] ); } // check if the user email is present in the decrypted data. if ( empty( $decrypted_data_array['user_email'] ) ) { wp_send_json_error( [ 'message' => __( 'No user email found in the decrypted data.', 'sureforms' ) ] ); } // remove the nonce from the decrypted data before saving it to the options. unset( $decrypted_data_array['nonce'] ); // save the user email to the options. update_option( 'srfm_ai_auth_user_email', $decrypted_data_array ); wp_send_json_success(); } }