HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ns3133907 6.8.0-86-generic #87-Ubuntu SMP PREEMPT_DYNAMIC Mon Sep 22 18:03:36 UTC 2025 x86_64
User: cssnetorguk (1024)
PHP: 8.2.28
Disabled: NONE
Upload Files
File: //home/davidrendel.org.uk/public_html/wp-content/plugins/sg-security/core/Rest/Rest_Helper.php
<?php
namespace SG_Security\Rest;

use SG_Security\Options_Service\Options_Service;
use SG_Security\Message_Service\Message_Service;

/**
 * Rest Helper class that process all rest requests and provide json output for react app.
 */
abstract class Rest_Helper {

	/**
	 * Checks if the `option_key` paramether exists in rest data.
	 *
	 * @since  1.0.0
	 *
	 * @param  object $request Request data.
	 * @param  string $key     The option key.
	 * @param  bool   $bail    Whether to send json error or to return a response.
	 *
	 * @return string          The option value.
	 */
	public function validate_and_get_option_value( $request, $key, $bail = true ) {
		$data = json_decode( $request->get_body(), true );

		// Bail if the option key is not set.
		if ( ! isset( $data[ $key ] ) ) {
			return true === $bail ? self::send_response( 'Something went wrong', 400 ) : false;
		}

		return $data[ $key ];
	}

	/**
	 * Change the option value.
	 *
	 * @since  1.0.0
	 *
	 * @param  object $key Request data.
	 * @param  string $value   The option value.
	 *
	 * @return bool            True if the option is enabled, false otherwise.
	 */
	public function change_option( $key, $value ) {
		return Options_Service::change_option( $key, $value );
	}

	/**
	 * Custom json response.
	 *
	 * @since  1.0.0
	 *
	 * @param  string  $message     The response message.
	 * @param  integer $result      The result of the optimization.
	 * @param  array   $data        Additional data to be send.
	 */
	public static function send_response( $message, $result = 1, $data = array() ) {
		// Prepare the status code, based on the optimization result.
		$status_code = 1 === $result ? 200 : 400;

		$response = \rest_ensure_response(
			array(
				'data'    => $data,
				'message' => $message,
				'status'  => $status_code,
			)
		);

		$response->set_status( $status_code );

		if ( ! headers_sent() ) {
			$response->header( 'Content-Type', 'application/json; charset=' . get_option( 'blog_charset' ) );
		}

		return $response;
	}

	/**
	 * Prepare the response message for the plugin interface.
	 *
	 * @since  1.0.0
	 *
	 * @param  int    $result The result of the optimization.
	 * @param  string $option The option name.
	 *
	 * @return string         The response message.
	 */
	public function get_response_message( $result, $option ) {
		return Message_Service::get_response_message( $result, $option );
	}

	/**
	 * Prepare dropdown options and selected values to be sent to react.
	 *
	 * @since 1.3.3
	 *
	 * @param      array $options  The options/label array.
	 * @param      bool  $value    The current value.
	 *
	 * @return     array  Data sent to the react.
	 */
	public function prepare_options_selected_values( $options, $value ) {
		// Prepare the data array.
		$data = array();

		// Generate the data array for the react app.
		foreach ( $options as $key => $label ) {
			$data[] = array(
				'value'    => $key,
				'selected' => $key === $value ? 1 : 0,
				'label'    => $label,
			);
		}

		// Return the data.
		return $data;
	}
}