HEX
Server: Apache/2.4.65 (Debian)
System: Linux 88f31f35b0b8 6.1.0-38-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.147-1 (2025-08-02) x86_64
User: www-data (33)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/wp-seopress/src/Actions/Api/TitleDescriptionMeta.php
<?php // phpcs:ignore

namespace SEOPress\Actions\Api;

if ( ! defined( 'ABSPATH' ) ) {
	exit;
}

use SEOPress\Core\Hooks\ExecuteHooks;

/**
 * Title Description Meta
 */
class TitleDescriptionMeta implements ExecuteHooks {
	/**
	 * The Title Description Meta hooks.
	 *
	 * @since 4.7.0
	 */
	public function hooks() {
		add_action( 'rest_api_init', array( $this, 'register' ) );
	}

	/**
	 * The Title Description Meta register.
	 *
	 * @since 4.7.0
	 *
	 * @return void
	 */
	public function register() {
		register_rest_route(
			'seopress/v1',
			'/posts/(?P<id>\d+)/title-description-metas',
			array(
				'methods'             => 'GET',
				'callback'            => array( $this, 'processGet' ),
				'args'                => array(
					'id' => array(
						'validate_callback' => function ( $param, $request, $key ) { // phpcs:ignore
							return is_numeric( $param );
						},
					),
				),
				'permission_callback' => function ( $request ) {
					return current_user_can( 'edit_post', (int) $request['id'] );
				},
			)
		);

		register_rest_route(
			'seopress/v1',
			'/posts/(?P<id>\d+)/title-description-metas',
			array(
				'methods'             => 'PUT',
				'callback'            => array( $this, 'processPut' ),
				'args'                => array(
					'id' => array(
						'validate_callback' => function ( $param, $request, $key ) { // phpcs:ignore
							return is_numeric( $param );
						},
					),
				),
				'permission_callback' => function ( $request ) {
					$post_id = $request['id'];
					return current_user_can( 'edit_post', $post_id );
				},
			)
		);
	}

	/**
	 * The Title Description Meta process get.
	 *
	 * @param \WP_REST_Request $request The request.
	 *
	 * @since 4.7.0
	 */
	public function processGet( \WP_REST_Request $request ) {
		$id = $request->get_param( 'id' );

		$title       = get_post_meta( $id, '_seopress_titles_title', true );
		$description = get_post_meta( $id, '_seopress_titles_desc', true );

		return new \WP_REST_Response(
			array(
				'title'       => html_entity_decode( $title, ENT_QUOTES | ENT_XML1, 'UTF-8' ),
				'description' => html_entity_decode( $description, ENT_QUOTES | ENT_XML1, 'UTF-8' ),
			)
		);
	}

	/**
	 * The Title Description Meta process put.
	 *
	 * @param \WP_REST_Request $request The request.
	 *
	 * @since 4.7.0
	 */
	public function processPut( \WP_REST_Request $request ) {
		$id     = $request->get_param( 'id' );
		$params = $request->get_params();

		$data_keys_save = array(
			'title'       => '_seopress_titles_title',
			'description' => '_seopress_titles_desc',
		);

		foreach ( $data_keys_save as $key => $value ) {
			if ( ! isset( $params[ $key ] ) ) {
				continue;
			}

			if ( empty( $params[ $key ] ) ) {
				delete_post_meta( $id, $value );
				continue;
			}

			$sanitized_value = '';
			if ( 'title' === $key ) {
				$sanitized_value = sanitize_text_field( $params[ $key ] );
			} elseif ( 'description' === $key ) {
				$sanitized_value = sanitize_textarea_field( $params[ $key ] );
			}

			update_post_meta( $id, $value, $sanitized_value );
		}

		return new \WP_REST_Response(
			array(
				'code' => 'success',
			)
		);
	}
}