113 lines
3.6 KiB
PHP
113 lines
3.6 KiB
PHP
<?php // phpcs:ignore WordPress.Files.FileName.InvalidClassFileName
|
|
|
|
new WPCOM_JSON_API_Get_Post_v1_1_Endpoint(
|
|
array(
|
|
'description' => 'Get a single post (by ID).',
|
|
'min_version' => '1.1',
|
|
'max_version' => '1.1',
|
|
'group' => 'posts',
|
|
'stat' => 'posts:1',
|
|
'method' => 'GET',
|
|
'path' => '/sites/%s/posts/%d',
|
|
'path_labels' => array(
|
|
'$site' => '(int|string) Site ID or domain',
|
|
'$post_ID' => '(int) The post ID',
|
|
),
|
|
|
|
'allow_fallback_to_jetpack_blog_token' => true,
|
|
|
|
'example_request' => 'https://public-api.wordpress.com/rest/v1.1/sites/en.blog.wordpress.com/posts/7',
|
|
)
|
|
);
|
|
|
|
new WPCOM_JSON_API_Get_Post_v1_1_Endpoint(
|
|
array(
|
|
'description' => 'Get a single post (by slug).',
|
|
'min_version' => '1.1',
|
|
'max_version' => '1.1',
|
|
'group' => 'posts',
|
|
'stat' => 'posts:slug',
|
|
'method' => 'GET',
|
|
'path' => '/sites/%s/posts/slug:%s',
|
|
'path_labels' => array(
|
|
'$site' => '(int|string) Site ID or domain',
|
|
'$post_slug' => '(string) The post slug (a.k.a. sanitized name)',
|
|
),
|
|
|
|
'allow_fallback_to_jetpack_blog_token' => true,
|
|
|
|
'example_request' => 'https://public-api.wordpress.com/rest/v1.1/sites/en.blog.wordpress.com/posts/slug:blogging-and-stuff',
|
|
)
|
|
);
|
|
|
|
/**
|
|
* Get Post v1_1 endpoint.
|
|
*/
|
|
class WPCOM_JSON_API_Get_Post_v1_1_Endpoint extends WPCOM_JSON_API_Post_v1_1_Endpoint { // phpcs:ignore
|
|
/**
|
|
*
|
|
* API callback.
|
|
*
|
|
* /sites/%s/posts/%d -> $blog_id, $post_id
|
|
* /sites/%s/posts/slug:%s -> $blog_id, $post_id
|
|
*
|
|
* @param string $path - the path.
|
|
* @param int $blog_id - the blog ID.
|
|
* @param int $post_id - the post ID.
|
|
*/
|
|
public function callback( $path = '', $blog_id = 0, $post_id = 0 ) {
|
|
$blog_id = $this->api->switch_to_blog_and_validate_user( $this->api->get_blog_id( $blog_id ) );
|
|
if ( is_wp_error( $blog_id ) ) {
|
|
return $blog_id;
|
|
}
|
|
|
|
$args = $this->query_args();
|
|
|
|
if ( str_contains( $path, '/posts/slug:' ) ) {
|
|
$site = $this->get_platform()->get_site( $blog_id );
|
|
|
|
$post_id = $site->get_post_id_by_name( $post_id );
|
|
if ( is_wp_error( $post_id ) ) {
|
|
return $post_id;
|
|
}
|
|
}
|
|
|
|
return $this->fetch_post( $blog_id, $post_id, $args['context'] );
|
|
}
|
|
|
|
/**
|
|
* Helper function to fetch the content of a post. User validation
|
|
* should be handled by the caller.
|
|
*
|
|
* @param int $blog_id The blog ID for the post.
|
|
* @param int $post_id The post ID.
|
|
* @param string $context The context we're fetching for.
|
|
* @return array|SAL_Post|WP_Error
|
|
*/
|
|
public function fetch_post( $blog_id, $post_id, $context ) {
|
|
$site = $this->get_platform()->get_site( $blog_id );
|
|
|
|
if (
|
|
defined( 'IS_WPCOM' )
|
|
&& IS_WPCOM
|
|
&& ! in_array( get_post_type( $post_id ), array( false, 'post', 'revision' ), true )
|
|
) {
|
|
$this->load_theme_functions();
|
|
}
|
|
|
|
$post = $this->get_post_by( 'ID', $post_id, $context );
|
|
|
|
if ( ! $post || is_wp_error( $post ) ) {
|
|
return $post;
|
|
}
|
|
|
|
if ( ! $site->current_user_can_access_post_type( $post['type'], $context ) ) {
|
|
return new WP_Error( 'unknown_post', 'Unknown post', 404 );
|
|
}
|
|
|
|
/** This action is documented in json-endpoints/class.wpcom-json-api-site-settings-endpoint.php */
|
|
do_action( 'wpcom_json_api_objects', 'posts' );
|
|
|
|
return $post;
|
|
}
|
|
}
|