oont-contents/plugins/jetpack/json-endpoints/class.wpcom-json-api-get-post-v1-1-endpoint.php
2025-02-08 15:10:23 +01:00

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;
}
}