mirror of
git://develop.git.wordpress.org/
synced 2025-01-17 12:58:25 +01:00
REST API: Always include title.raw
/content.raw
for Blocks in context=view
.
Demarcations for reusable blocks are always expected to be accessible by clients. Props noisysocks, youknowriad. See #45145 for the patch, #45098 for the original ticket. git-svn-id: https://develop.svn.wordpress.org/branches/5.0@43917 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
8e8dca6069
commit
8ef1b05bfe
@ -36,4 +36,57 @@ class WP_REST_Blocks_Controller extends WP_REST_Posts_Controller {
|
|||||||
|
|
||||||
return parent::check_read_permission( $post );
|
return parent::check_read_permission( $post );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filters a response based on the context defined in the schema.
|
||||||
|
*
|
||||||
|
* @since 5.0.0
|
||||||
|
*
|
||||||
|
* @param array $data Response data to fiter.
|
||||||
|
* @param string $context Context defined in the schema.
|
||||||
|
* @return array Filtered response.
|
||||||
|
*/
|
||||||
|
public function filter_response_by_context( $data, $context ) {
|
||||||
|
$data = parent::filter_response_by_context( $data, $context );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove `title.rendered` and `content.rendered` from the response. It
|
||||||
|
* doesn't make sense for a reusable block to have rendered content on its
|
||||||
|
* own, since rendering a block requires it to be inside a post or a page.
|
||||||
|
*/
|
||||||
|
unset( $data['title']['rendered'] );
|
||||||
|
unset( $data['content']['rendered'] );
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the block's schema, conforming to JSON Schema.
|
||||||
|
*
|
||||||
|
* @since 5.0.0
|
||||||
|
*
|
||||||
|
* @return array Item schema data.
|
||||||
|
*/
|
||||||
|
public function get_item_schema() {
|
||||||
|
$schema = parent::get_item_schema();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Allow all contexts to access `title.raw` and `content.raw`. Clients always
|
||||||
|
* need the raw markup of a reusable block to do anything useful, e.g. parse
|
||||||
|
* it or display it in an editor.
|
||||||
|
*/
|
||||||
|
$schema['properties']['title']['properties']['raw']['context'] = array( 'view', 'edit' );
|
||||||
|
$schema['properties']['content']['properties']['raw']['context'] = array( 'view', 'edit' );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove `title.rendered` and `content.rendered` from the schema. It doesn’t
|
||||||
|
* make sense for a reusable block to have rendered content on its own, since
|
||||||
|
* rendering a block requires it to be inside a post or a page.
|
||||||
|
*/
|
||||||
|
unset( $schema['properties']['title']['properties']['rendered'] );
|
||||||
|
unset( $schema['properties']['content']['properties']['rendered'] );
|
||||||
|
|
||||||
|
return $schema;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -29,13 +29,13 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
protected static $post_id;
|
protected static $post_id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Our fake user's ID.
|
* Our fake user IDs, keyed by their role.
|
||||||
*
|
*
|
||||||
* @since 5.0.0
|
* @since 5.0.0
|
||||||
*
|
*
|
||||||
* @var int
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected static $user_id;
|
protected static $user_ids;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create fake data before our tests run.
|
* Create fake data before our tests run.
|
||||||
@ -50,14 +50,14 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
'post_type' => 'wp_block',
|
'post_type' => 'wp_block',
|
||||||
'post_status' => 'publish',
|
'post_status' => 'publish',
|
||||||
'post_title' => 'My cool block',
|
'post_title' => 'My cool block',
|
||||||
'post_content' => '<!-- wp:core/paragraph --><p>Hello!</p><!-- /wp:core/paragraph -->',
|
'post_content' => '<!-- wp:paragraph --><p>Hello!</p><!-- /wp:paragraph -->',
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
self::$user_id = $factory->user->create(
|
self::$user_ids = array(
|
||||||
array(
|
'editor' => $factory->user->create( array( 'role' => 'editor' ) ),
|
||||||
'role' => 'editor',
|
'author' => $factory->user->create( array( 'role' => 'author' ) ),
|
||||||
)
|
'contributor' => $factory->user->create( array( 'role' => 'contributor' ) ),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,7 +69,9 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
public static function wpTearDownAfterClass() {
|
public static function wpTearDownAfterClass() {
|
||||||
wp_delete_post( self::$post_id );
|
wp_delete_post( self::$post_id );
|
||||||
|
|
||||||
self::delete_user( self::$user_id );
|
foreach ( self::$user_ids as $user_id ) {
|
||||||
|
self::delete_user( $user_id );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -114,7 +116,7 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
*/
|
*/
|
||||||
public function test_capabilities( $action, $role, $expected_status ) {
|
public function test_capabilities( $action, $role, $expected_status ) {
|
||||||
if ( $role ) {
|
if ( $role ) {
|
||||||
$user_id = $this->factory->user->create( array( 'role' => $role ) );
|
$user_id = self::$user_ids[ $role ];
|
||||||
wp_set_current_user( $user_id );
|
wp_set_current_user( $user_id );
|
||||||
} else {
|
} else {
|
||||||
wp_set_current_user( 0 );
|
wp_set_current_user( 0 );
|
||||||
@ -126,7 +128,7 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
$request->set_body_params(
|
$request->set_body_params(
|
||||||
array(
|
array(
|
||||||
'title' => 'Test',
|
'title' => 'Test',
|
||||||
'content' => '<!-- wp:core/paragraph --><p>Test</p><!-- /wp:core/paragraph -->',
|
'content' => '<!-- wp:paragraph --><p>Test</p><!-- /wp:paragraph -->',
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -149,7 +151,7 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
'post_type' => 'wp_block',
|
'post_type' => 'wp_block',
|
||||||
'post_status' => 'publish',
|
'post_status' => 'publish',
|
||||||
'post_title' => 'My cool block',
|
'post_title' => 'My cool block',
|
||||||
'post_content' => '<!-- wp:core/paragraph --><p>Hello!</p><!-- /wp:core/paragraph -->',
|
'post_content' => '<!-- wp:paragraph --><p>Hello!</p><!-- /wp:paragraph -->',
|
||||||
'post_author' => $user_id,
|
'post_author' => $user_id,
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -158,7 +160,7 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
$request->set_body_params(
|
$request->set_body_params(
|
||||||
array(
|
array(
|
||||||
'title' => 'Test',
|
'title' => 'Test',
|
||||||
'content' => '<!-- wp:core/paragraph --><p>Test</p><!-- /wp:core/paragraph -->',
|
'content' => '<!-- wp:paragraph --><p>Test</p><!-- /wp:paragraph -->',
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -179,7 +181,7 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
$request->set_body_params(
|
$request->set_body_params(
|
||||||
array(
|
array(
|
||||||
'title' => 'Test',
|
'title' => 'Test',
|
||||||
'content' => '<!-- wp:core/paragraph --><p>Test</p><!-- /wp:core/paragraph -->',
|
'content' => '<!-- wp:paragraph --><p>Test</p><!-- /wp:paragraph -->',
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -196,9 +198,32 @@ class REST_Blocks_Controller_Test extends WP_UnitTestCase {
|
|||||||
default:
|
default:
|
||||||
$this->fail( "'$action' is not a valid action." );
|
$this->fail( "'$action' is not a valid action." );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ( isset( $user_id ) ) {
|
/**
|
||||||
self::delete_user( $user_id );
|
* Check that the raw title and content of a block can be accessed when there
|
||||||
}
|
* is no set schema, and that the rendered content of a block is not included
|
||||||
|
* in the response.
|
||||||
|
*/
|
||||||
|
public function test_content() {
|
||||||
|
wp_set_current_user( self::$user_ids['author'] );
|
||||||
|
|
||||||
|
$request = new WP_REST_Request( 'GET', '/wp/v2/blocks/' . self::$post_id );
|
||||||
|
$response = rest_get_server()->dispatch( $request );
|
||||||
|
$data = $response->get_data();
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
array(
|
||||||
|
'raw' => 'My cool block',
|
||||||
|
),
|
||||||
|
$data['title']
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
array(
|
||||||
|
'raw' => '<!-- wp:paragraph --><p>Hello!</p><!-- /wp:paragraph -->',
|
||||||
|
'protected' => false,
|
||||||
|
),
|
||||||
|
$data['content']
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user