MMCT TEAM
Server IP : 162.214.80.37  /  Your IP : 216.73.216.68
Web Server : Apache
System : Linux sh013.webhostingservices.com 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64
User : imyrqtmy ( 2189)
PHP Version : 8.2.18
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /opt/wp/plugins/bluehost-wordpress-plugin/inc/RestApi/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : //opt/wp/plugins/bluehost-wordpress-plugin/inc/RestApi/MojoItemsController.php
<?php

namespace Bluehost\RestApi;

/**
 * Class MojoItemsController
 */
class MojoItemsController extends \WP_REST_Controller {

	/**
	 * The controller's namespace.
	 *
	 * @var string
	 */
	protected $namespace = 'mojo/v1';

	/**
	 * The base of this controller's route.
	 *
	 * @var string
	 */
	protected $rest_base = 'items';

	/**
	 * Query the Mojo items endpoint.
	 *
	 * @param array            $params  Collection of request parameters.
	 * @param \WP_REST_Request $request WP request model.
	 *
	 * @return array|mixed|object|null
	 */
	public function query_mojo_items( $params, \WP_REST_Request $request ) {
		$params       = wp_parse_args( $request->get_params(), $params );
		$api_url      = add_query_arg( $params, 'https://api.mojomarketplace.com/api/v2/items' );
		$api_response = bh_api_cache( $api_url );

		return $this->get_response( $api_response );
	}

	/**
	 * Query the Mojo search endpoint.
	 *
	 * @param array            $params  Collection of request parameters.
	 * @param \WP_REST_Request $request WP request model.
	 *
	 * @return array|mixed|object|null
	 */
	public function query_mojo_search( $params, \WP_REST_Request $request ) {
		$params = wp_parse_args( $request->get_params(), $params );

		// Rename 'count' to 'size' for Mojo search endpoint.
		if ( ! empty( $params['count'] ) ) {
			$params['size'] = $params['count'];
			unset( $params['count'] );
		}

		// Rename 'type' to 'item_type' for Mojo search endpoint.
		if ( ! empty( $params['item_type'] ) ) {
			unset( $params['type'] );
		}

		if ( ! empty( $params['type'] ) ) {
			$params['item_type'] = $params['type'];
			unset( $params['type'] );
		}

		$api_url      = add_query_arg( $params, 'https://api.mojomarketplace.com/api/v2/search' );
		$api_response = bh_api_cache( $api_url );

		return $this->get_response( $api_response );
	}

	/**
	 * Get the REST response from the Mojo API response.
	 *
	 * @param array|\WP_Error $api_response API response from Mojo to be converted.
	 *
	 * @return array
	 */
	public function get_response( $api_response ) {

		$status_code = absint( wp_remote_retrieve_response_code( $api_response ) );

		$response = array(
			'status'     => 'error',
			'statusCode' => $status_code,
			'message'    => 'An unknown error occurred.',
		);

		if ( is_wp_error( $api_response ) ) {
			return $response;
		}

		$body = wp_remote_retrieve_body( $api_response );
		if ( empty( $body ) ) {
			$response['message'] = 'Unable to parse response body.';
		}

		$data = json_decode( $body, true );
		if ( ! $data ) {
			$response['message'] = 'Unable to parse response JSON.';
		}

		$response = array_merge( $data, array( 'statusCode' => $status_code ) );

		// Ensure page property is always an integer.
		if ( isset( $response['page'] ) && ! is_int( $response['page'] ) ) {
			$response['page'] = absint( $response['page'] );
		}

		$response['items'] = array_map(
			function ( array $item ) {

				if ( isset( $item['id'] ) ) {

					$item['buy_url'] = mojo_build_link(
						add_query_arg( array( 'item_id' => $item['id'] ), 'https://www.mojomarketplace.com/cart' ),
						array(
							'utm_medium'  => 'plugin_admin',
							'utm_content' => 'buy_now_preview',
						)
					);

					if ( isset( $item['type'] ) && 'themes' === $item['type'] ) {
						$item['preview_url'] = admin_url( 'admin.php?page=mojo-theme-preview&id=' . $item['id'] );
					}
				}

				return $item;
			},
			$response['items']
		);

		return rest_ensure_response( $response );
	}

	/**
	 * Check if a given request has access to get items
	 *
	 * @param \WP_REST_Request $request Full data about the request.
	 *
	 * @return \WP_Error|bool
	 */
	public function get_items_permissions_check( $request ) {
		return current_user_can( 'manage_options' );
	}

	/**
	 * Prepare the item for the REST response
	 *
	 * @param mixed            $item    WordPress representation of the item.
	 * @param \WP_REST_Request $request Request object.
	 *
	 * @return mixed
	 */
	public function prepare_item_for_response( $item, $request ) {
		return array();
	}

	/**
	 * Get the query params for collections
	 *
	 * @return array
	 */
	public function get_collection_params() {
		return array(
			'category'     => array(
				'description' => 'Category ID or slug (this is ItemTypeCategory).',
				'type'        => 'string',
				'enum'        => array(
					'',
					'wordpress',
				),
				'default'     => 'wordpress',
			),
			'count'        => array(
				'description' => 'Maximum number of items to return (maximum allowed is 50).',
				'type'        => 'integer',
				'default'     => 12,
			),
			'direction'    => array(
				'description' => 'Sort direction.',
				'type'        => 'string',
				'enum'        => array(
					'asc',
					'desc',
				),
				'default'     => 'desc',
			),
			'itemCategory' => array(
				'description'       => 'Item Category slug (this is ItemCategory).',
				'type'              => 'string',
				'sanitize_callback' => 'sanitize_text_field',
			),
			'order'        => array(
				'description' => 'Order to sort items by.',
				'type'        => 'string',
				'enum'        => array(
					'popular',
					'price',
					'latest',
					'random',
					'sales',
				),
				'default'     => 'sales',
			),
			'page'         => array(
				'description' => 'Offset from the first several items (maximum allowed is 10).',
				'type'        => 'integer',
			),
			'query'        => array(
				'description' => 'A search query.',
				'type'        => 'string',
			),
			'seller'       => array(
				'description'       => 'User ID or brand profile name.',
				'type'              => 'string',
				'sanitize_callback' => 'sanitize_text_field',
			),
			'services'     => array(
				'description' => 'Indicates that services should be returned instead of purchasable items. If you define the type as services then you can ignore this flag.',
				'type'        => 'boolean',
				'default'     => false,
			),
			'type'         => array(
				'description' => 'Item type.',
				'type'        => 'string',
				'enum'        => array(
					'themes',
					'graphics',
					'plugins',
					'services',
				),
				'default'     => 'themes',
			),
		);
	}
}

MMCT - 2023