| Server IP : 8.134.250.228 / Your IP : 216.73.217.111 Web Server : Apache System : Linux iZ7xv33p9e9ivk7yhmj7ibZ 5.10.134-18.al8.x86_64 #1 SMP Fri Dec 13 16:56:53 CST 2024 x86_64 User : www ( 1000) PHP Version : 8.0.26 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,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_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /www/wwwroot/www.gobluemade.com/wp-content/plugins/elementor/includes/ |
Upload File : |
<?php
namespace Elementor;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
class User_Data {
const API_NAMESPACE = 'elementor/v1';
const API_BASE = '/user-data/current-user';
public static function init() {
add_action( 'rest_api_init', fn() => self::register_routes() );
}
private static function register_routes() {
register_rest_route( self::API_NAMESPACE, self::API_BASE, [
[
'methods' => 'GET',
'callback' => fn( $request ) => self::route_wrapper( fn() => self::get_current_user( $request ) ),
'permission_callback' => fn() => is_user_logged_in(),
],
[
'methods' => 'PATCH',
'callback' => fn( $request ) => self::route_wrapper( fn() => self::update_current_user( $request ) ),
'permission_callback' => fn() => is_user_logged_in(),
'args' => [
'suppressedMessages' => [
'required' => false,
'type' => 'array',
'description' => 'Array of suppressed message keys',
'items' => [
'type' => 'string',
],
'validate_callback' => function( $param, $request, $key ) {
return is_array( $param );
},
'sanitize_callback' => fn( $param, $request, $key ) => self::sanitize_suppressed_messages( $param, $request, $key ),
],
],
],
] );
}
/**
* @param \WP_REST_Request $request The request object.
* @return \WP_REST_Response|\WP_Error Response object or error.
*/
public static function get_current_user( $request ) {
$current_user = wp_get_current_user();
$introduction_meta = User::get_introduction_meta();
$suppressed_messages = [];
if ( is_array( $introduction_meta ) ) {
foreach ( $introduction_meta as $key => $value ) {
if ( $value ) {
$suppressed_messages[] = $key;
}
}
}
$capabilities = array_keys( $current_user->allcaps );
$data = [
'suppressedMessages' => $suppressed_messages,
'capabilities' => $capabilities,
];
return new \WP_REST_Response( $data, 200 );
}
/**
* @param \WP_REST_Request $request The request object.
* @return \WP_REST_Response|\WP_Error Response object or error.
*/
public static function update_current_user( $request ) {
$user_id = get_current_user_id();
$suppressed_messages = $request->get_param( 'suppressedMessages' );
if ( $request->has_param( 'suppressedMessages' ) && is_array( $suppressed_messages ) ) {
$introduction_meta = [];
foreach ( $suppressed_messages as $message ) {
$introduction_meta[ $message ] = true;
}
update_user_meta( $user_id, User::INTRODUCTION_KEY, $introduction_meta );
}
return self::get_current_user( $request );
}
/**
* @param array $param The parameter value.
* @param \WP_REST_Request $request The request object.
* @param string $key The parameter key.
*
* @return array|null The sanitized array or null.
*/
public static function sanitize_suppressed_messages( $param, $request, $key ) {
if ( ! is_array( $param ) ) {
return null;
}
$sanitized_messages = [];
foreach ( $param as $message ) {
if ( is_string( $message ) ) {
$sanitized_message = sanitize_text_field( $message );
if ( ! empty( $sanitized_message ) ) {
$sanitized_messages[] = $sanitized_message;
}
}
}
return $sanitized_messages;
}
private static function route_wrapper( callable $cb ) {
try {
$response = $cb();
} catch ( \Exception $e ) {
return new \WP_Error( 'unexpected_error', 'Something went wrong', [ 'status' => 500 ] );
}
return $response;
}
}