<?php
/**
* Add/Update post type endpoint
*/
class Jet_Engine_CPT_Rest_Get_Post_Type extends Jet_Engine_Base_API_Endpoint {
/**
* Returns route name
*
* @return string
*/
public function get_name() {
return 'get-post-type';
}
/**
* API callback
*
* @return void
*/
public function callback( $request ) {
$params = $request->get_params();
$id = isset( $params['id'] ) ? intval( $params['id'] ) : false;
if ( ! $id ) {
jet_engine()->cpt->add_notice(
'error',
__( 'Item ID not found in request', 'jet-engine' )
);
return rest_ensure_response( array(
'success' => false,
'notices' => jet_engine()->cpt->get_notices(),
) );
}
$post_type_data = jet_engine()->cpt->data->get_item_for_edit( $id );
if ( ! $post_type_data ) {
jet_engine()->cpt->add_notice(
'error',
__( 'Post type not found', 'jet-engine' )
);
return rest_ensure_response( array(
'success' => false,
'notices' => jet_engine()->cpt->get_notices(),
) );
}
if ( empty( $post_type_data['labels'] ) ) {
$post_type_data['labels']['singular_name'] = '';
}
return rest_ensure_response( array(
'success' => true,
'data' => $post_type_data,
) );
}
/**
* Returns endpoint request method - GET/POST/PUT/DELTE
*
* @return string
*/
public function get_method() {
return 'GET';
}
/**
* Check user access to current end-popint
*
* @return bool
*/
public function permission_callback( $request ) {
return current_user_can( 'manage_options' );
}
/**
* Get query param. Regex with query parameters
*
* @return string
*/
public function get_query_params() {
return '(?P<id>[\d]+)';
}
}