292 lines
8.9 KiB
PHP
292 lines
8.9 KiB
PHP
<?php
|
|
// Exit if accessed directly.
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit;
|
|
}
|
|
|
|
/**
|
|
* Property_Api
|
|
*
|
|
* @since 1.0.0
|
|
* @package Property_Api
|
|
*/
|
|
class Property_Api extends Base_Api {
|
|
|
|
/**
|
|
* The unique identifier of the route resource.
|
|
*
|
|
* @since 1.0.0
|
|
* @access public
|
|
* @var string $base .
|
|
*/
|
|
public $base = '/properties';
|
|
|
|
/**
|
|
* Post type.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $post_type = 'opalestate_property';
|
|
|
|
/**
|
|
* Register Routes
|
|
*
|
|
* Register all CURD actions with POST/GET/PUT and calling function for each
|
|
*
|
|
* @since 1.0
|
|
*
|
|
*/
|
|
public function register_routes() {
|
|
/**
|
|
* Get list of properties.
|
|
*
|
|
* Call http://domain.com/wp-json/estate-api/v1/properties
|
|
*/
|
|
register_rest_route(
|
|
$this->namespace,
|
|
'/' . $this->base,
|
|
[
|
|
[
|
|
'methods' => WP_REST_Server::READABLE,
|
|
'callback' => [ $this, 'get_items' ],
|
|
// 'permission_callback' => [ $this, 'get_items_permissions_check' ],
|
|
'args' => $this->get_collection_params(),
|
|
],
|
|
// [
|
|
// 'methods' => WP_REST_Server::CREATABLE,
|
|
// 'callback' => [ $this, 'create_item' ],
|
|
// // 'permission_callback' => [ $this, 'create_item_permissions_check' ],
|
|
// ],
|
|
]
|
|
);
|
|
|
|
register_rest_route(
|
|
$this->namespace,
|
|
'/' . $this->base . '/(?P<id>[\d]+)',
|
|
[
|
|
'args' => [
|
|
'id' => [
|
|
'description' => __( 'Unique identifier for the resource.', 'opalestate-pro' ),
|
|
'type' => 'integer',
|
|
],
|
|
],
|
|
[
|
|
'methods' => WP_REST_Server::READABLE,
|
|
'callback' => [ $this, 'get_item' ],
|
|
// 'permission_callback' => [ $this, 'get_item_permissions_check' ],
|
|
],
|
|
[
|
|
'methods' => WP_REST_Server::EDITABLE,
|
|
'callback' => [ $this, 'update_item' ],
|
|
// 'permission_callback' => [ $this, 'update_item_permissions_check' ],
|
|
],
|
|
[
|
|
'methods' => WP_REST_Server::DELETABLE,
|
|
'callback' => [ $this, 'delete_item' ],
|
|
// 'permission_callback' => [ $this, 'delete_item_permissions_check' ],
|
|
'args' => [
|
|
'force' => [
|
|
'default' => false,
|
|
'description' => __( 'Whether to bypass trash and force deletion.', 'opalestate-pro' ),
|
|
'type' => 'boolean',
|
|
],
|
|
],
|
|
],
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get List Of Properties
|
|
*
|
|
* Based on request to get collection
|
|
*
|
|
* @return WP_REST_Response is json data
|
|
* @since 1.0
|
|
*
|
|
*/
|
|
public function get_items( $request ) {
|
|
$properties = [];
|
|
|
|
$per_page = isset( $request['per_page'] ) && $request['per_page'] ? $request['per_page'] : 5;
|
|
$paged = isset( $request['page'] ) && $request['page'] ? $request['page'] : 1;
|
|
|
|
$property_list = get_posts( [
|
|
'post_type' => $this->post_type,
|
|
'posts_per_page' => $per_page,
|
|
'paged' => $paged,
|
|
'suppress_filters' => true,
|
|
] );
|
|
|
|
if ( $property_list ) {
|
|
$i = 0;
|
|
foreach ( $property_list as $property_info ) {
|
|
$properties[ $i ] = $this->get_property_data( $property_info );
|
|
$i++;
|
|
}
|
|
}
|
|
|
|
$response['collection'] = $properties;
|
|
$response['pages'] = 4;
|
|
$response['current'] = 1;
|
|
|
|
return $this->get_response( 200, $response );
|
|
}
|
|
|
|
/**
|
|
* Get Property
|
|
*
|
|
* Based on request to get a property.
|
|
*
|
|
* @return WP_REST_Response is json data
|
|
* @since 1.0
|
|
*
|
|
*/
|
|
public function get_item( $request ) {
|
|
$response = [];
|
|
if ( $request['id'] > 0 ) {
|
|
$post = get_post( $request['id'] );
|
|
if ( $post && $this->post_type == get_post_type( $request['id'] ) ) {
|
|
$property = $this->get_property_data( $post );
|
|
$response['property'] = $property ? $property : [];
|
|
$code = 200;
|
|
} else {
|
|
$code = 404;
|
|
$response['error'] = sprintf( esc_html__( 'Property ID: %s does not exist!', 'opalestate-pro' ), $request['id'] );
|
|
}
|
|
} else {
|
|
$code = 404;
|
|
$response['error'] = sprintf( esc_html__( 'Invalid ID.', 'opalestate-pro' ), $request['id'] );
|
|
}
|
|
|
|
return $this->get_response( $code, $response );
|
|
}
|
|
|
|
/**
|
|
* The opalestate_property post object, generate the data for the API output
|
|
*
|
|
* @param object $property_info The Download Post Object
|
|
*
|
|
* @return array Array of post data to return back in the API
|
|
* @since 1.0
|
|
*
|
|
*/
|
|
private function get_property_data( $property_info ) {
|
|
$property = [];
|
|
|
|
$property['info']['id'] = $property_info->ID;
|
|
$property['info']['slug'] = $property_info->post_name;
|
|
$property['info']['title'] = $property_info->post_title;
|
|
$property['info']['create_date'] = $property_info->post_date;
|
|
$property['info']['modified_date'] = $property_info->post_modified;
|
|
$property['info']['status'] = $property_info->post_status;
|
|
$property['info']['link'] = html_entity_decode( $property_info->guid );
|
|
$property['info']['content'] = $property_info->post_content;
|
|
$property['info']['thumbnail'] = wp_get_attachment_url( get_post_thumbnail_id( $property_info->ID ) );
|
|
|
|
$data = opalesetate_property( $property_info->ID );
|
|
$gallery = $data->get_gallery();
|
|
$gallery_count = $data->get_gallery_count();
|
|
|
|
$gallery_data = [];
|
|
if ( $gallery_count ) {
|
|
foreach ( $gallery as $id => $url ) {
|
|
$gallery_data[] = [
|
|
'id' => $id,
|
|
'url' => $url,
|
|
];
|
|
}
|
|
}
|
|
|
|
$property['info']['gallery'] = $gallery_data;
|
|
$property['info']['price'] = opalestate_price_format( $data->get_price() );
|
|
$property['info']['saleprice'] = opalestate_price_format( $data->get_sale_price() );
|
|
$property['info']['before_price_label'] = $data->get_before_price_label();
|
|
$property['info']['price_label'] = $data->get_price_label();
|
|
$property['info']['map'] = $data->get_map();
|
|
$property['info']['address'] = $data->get_address();
|
|
$property['meta'] = $data->get_meta_shortinfo();
|
|
$property['fullinfo'] = $data->get_meta_fullinfo();
|
|
$property['video'] = $data->get_video_url();
|
|
$property['virtual_tour'] = $data->get_virtual_tour();
|
|
$property['attachments'] = $data->get_attachments();
|
|
$property['floor_plans'] = $data->get_floor_plans();
|
|
$property['is_featured'] = $data->is_featured();
|
|
$property['status'] = $data->get_status();
|
|
$property['labels'] = $data->get_labels();
|
|
$property['locations'] = $data->get_locations();
|
|
$property['facilities'] = $data->get_facilities();
|
|
$property['amenities'] = $data->get_amenities();
|
|
$property['types'] = $data->get_types_tax();
|
|
$property['author_type'] = $data->get_author_type();
|
|
$property['author_data'] = $data->get_author_link_data();
|
|
|
|
$limit = opalestate_get_option( 'single_views_statistics_limit', 8 );
|
|
$stats = new Opalestate_View_Stats( $data->get_id(), $limit );
|
|
$array_label = json_encode( $stats->get_traffic_labels() );
|
|
$array_values = json_encode( $stats->get_traffic_data_accordion() );
|
|
$property['view_stats'] = [
|
|
'labels' => $array_label,
|
|
'values' => $array_values,
|
|
];
|
|
|
|
return apply_filters( 'opalestate_api_properties_property', $property );
|
|
}
|
|
|
|
/**
|
|
* Create a single item.
|
|
*
|
|
* @param WP_REST_Request $request Full details about the request.
|
|
* @return WP_Error|WP_REST_Response
|
|
*/
|
|
public function create_item( $request ) {
|
|
if ( ! empty( $request['id'] ) ) {
|
|
/* translators: %s: post type */
|
|
return new WP_Error( "opalestate_rest_{$this->post_type}_exists", sprintf( __( 'Cannot create existing %s.', 'opalestate-pro' ), $this->post_type ), [ 'status' => 400 ] );
|
|
}
|
|
|
|
$data = [
|
|
'post_title' => $request['post_title'],
|
|
'post_type' => $this->post_type,
|
|
'post_content' => $request['post_content'],
|
|
];
|
|
|
|
$data['post_status'] = 'pending';
|
|
$post_id = wp_insert_post( $data, true );
|
|
|
|
$response['id'] = $post_id;
|
|
$response = rest_ensure_response( $response );
|
|
$response->set_status( 201 );
|
|
$response->header( 'Location', rest_url( sprintf( '/%s/%s/%d', $this->namespace, $this->base, $post_id ) ) );
|
|
|
|
return $response;
|
|
}
|
|
|
|
/**
|
|
* Get the query params for collections of attachments.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function get_collection_params() {
|
|
$params['page'] = [
|
|
'description' => __( 'Current page of the collection.', 'opalestate-pro' ),
|
|
'type' => 'integer',
|
|
'default' => 1,
|
|
'sanitize_callback' => 'absint',
|
|
'validate_callback' => 'rest_validate_request_arg',
|
|
'minimum' => 1,
|
|
];
|
|
$params['per_page'] = [
|
|
'description' => __( 'Maximum number of items to be returned in result set.', 'opalestate-pro' ),
|
|
'type' => 'integer',
|
|
'default' => 10,
|
|
'minimum' => 1,
|
|
'maximum' => 100,
|
|
'sanitize_callback' => 'absint',
|
|
'validate_callback' => 'rest_validate_request_arg',
|
|
];
|
|
|
|
return $params;
|
|
}
|
|
}
|