<?php
/**
* Get options page endpoint
*/
class Jet_Engine_Rest_Get_Options_Page extends Jet_Engine_Base_API_Endpoint {
/**
* Returns route name
*
* @return string
*/
public function get_name() {
return 'get-options-page';
}
/**
* API callback
*
* @return void
*/
public function callback( $request ) {
$params = $request->get_params();
$id = isset( $params['id'] ) ? intval( $params['id'] ) : false;
if ( ! $id ) {
jet_engine()->options_pages->add_notice(
'error',
__( 'Item ID not found in request', 'jet-engine' )
);
return rest_ensure_response( array(
'success' => false,
'notices' => jet_engine()->options_pages->get_notices(),
) );
}
$data = jet_engine()->options_pages->data->get_item_for_edit( $id );
if ( ! $data ) {
jet_engine()->options_pages->add_notice(
'error',
__( 'Page not found', 'jet-engine' )
);
return rest_ensure_response( array(
'success' => false,
'notices' => jet_engine()->options_pages->get_notices(),
) );
}
return rest_ensure_response( array(
'success' => true,
'data' => $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]+)';
}
}