From 696b3f1347699a6d3a3496500d21ef572061a393 Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Thu, 5 Sep 2024 16:29:36 +0200 Subject: [PATCH 1/8] Add `label` arg to `register_meta` --- src/wp-includes/meta.php | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/wp-includes/meta.php b/src/wp-includes/meta.php index 96ace4e9726ba..a9a98e99cfc1f 100644 --- a/src/wp-includes/meta.php +++ b/src/wp-includes/meta.php @@ -1379,6 +1379,7 @@ function sanitize_meta( $meta_key, $meta_value, $object_type, $object_subtype = * the meta key will be registered on the entire object type. Default empty. * @type string $type The type of data associated with this meta key. * Valid values are 'string', 'boolean', 'integer', 'number', 'array', and 'object'. + * @type string $label A human-readable label of the data attached to this meta key. * @type string $description A description of the data attached to this meta key. * @type bool $single Whether the meta key has one value per object, or an array of values per object. * @type mixed $default The default value returned from get_metadata() if no value has been set yet. @@ -1411,6 +1412,7 @@ function register_meta( $object_type, $meta_key, $args, $deprecated = null ) { $defaults = array( 'object_subtype' => '', 'type' => 'string', + 'label' => '', 'description' => '', 'default' => '', 'single' => false, From 7593c511a53ce26bef7e6e330118dde0f7339c8e Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Thu, 5 Sep 2024 16:29:53 +0200 Subject: [PATCH 2/8] Add label to REST API schema --- src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php b/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php index 5f3b55843e23a..f523285fb9608 100644 --- a/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php +++ b/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php @@ -478,6 +478,7 @@ protected function get_registered_fields() { $default_schema = array( 'type' => $default_args['type'], + 'label' => empty( $args['label'] ) ? '' : $args['label'], 'description' => empty( $args['description'] ) ? '' : $args['description'], 'default' => isset( $args['default'] ) ? $args['default'] : null, ); From edc444cb9b5258a000fbecfc76d267b634f2b3e9 Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Thu, 5 Sep 2024 16:30:27 +0200 Subject: [PATCH 3/8] Adapt unit tests --- tests/phpunit/tests/meta/registerMeta.php | 15 +++++++++++++++ .../user/wpRegisterPersistedPreferencesMeta.php | 1 + 2 files changed, 16 insertions(+) diff --git a/tests/phpunit/tests/meta/registerMeta.php b/tests/phpunit/tests/meta/registerMeta.php index 329321dd9bc67..a3526a728889f 100644 --- a/tests/phpunit/tests/meta/registerMeta.php +++ b/tests/phpunit/tests/meta/registerMeta.php @@ -92,6 +92,7 @@ public function test_register_meta_with_post_object_type_populates_wp_meta_keys( '' => array( 'flight_number' => array( 'type' => 'string', + 'label' => '', 'description' => '', 'single' => false, 'sanitize_callback' => null, @@ -117,6 +118,7 @@ public function test_register_meta_with_term_object_type_populates_wp_meta_keys( '' => array( 'category_icon' => array( 'type' => 'string', + 'label' => '', 'description' => '', 'single' => false, 'sanitize_callback' => null, @@ -172,6 +174,7 @@ public function test_register_meta_with_current_sanitize_callback_populates_wp_m '' => array( 'flight_number' => array( 'type' => 'string', + 'label' => '', 'description' => '', 'single' => false, 'sanitize_callback' => array( $this, '_new_sanitize_meta_cb' ), @@ -256,6 +259,16 @@ public function test_get_registered_meta_keys_with_invalid_type_is_empty() { $this->assertEmpty( $meta_keys ); } + public function test_get_registered_meta_keys_label_arg() { + register_meta( 'post', 'registered_key1', array( 'label' => 'Field label' ) ); + + $meta_keys = get_registered_meta_keys( 'post' ); + + unregister_meta_key( 'post', 'registered_key1' ); + + $this->assertSame( 'Field label', $meta_keys['registered_key1']['label'] ); + } + public function test_get_registered_meta_keys_description_arg() { register_meta( 'post', 'registered_key1', array( 'description' => 'I\'m just a field, take a good look at me' ) ); @@ -340,6 +353,7 @@ public function test_register_meta_with_subtype_populates_wp_meta_keys( $type, $ $subtype => array( 'flight_number' => array( 'type' => 'string', + 'label' => '', 'description' => '', 'single' => false, 'sanitize_callback' => null, @@ -394,6 +408,7 @@ public function test_unregister_meta_without_subtype_keeps_subtype_meta_key( $ty $subtype => array( 'flight_number' => array( 'type' => 'string', + 'label' => '', 'description' => '', 'single' => false, 'sanitize_callback' => null, diff --git a/tests/phpunit/tests/user/wpRegisterPersistedPreferencesMeta.php b/tests/phpunit/tests/user/wpRegisterPersistedPreferencesMeta.php index 8af6ae9b81533..a45b015ad9728 100644 --- a/tests/phpunit/tests/user/wpRegisterPersistedPreferencesMeta.php +++ b/tests/phpunit/tests/user/wpRegisterPersistedPreferencesMeta.php @@ -31,6 +31,7 @@ public function test_should_register_persisted_preferences_meta() { $this->assertSame( array( 'type' => 'object', + 'label' => '', 'description' => '', 'single' => true, 'sanitize_callback' => null, From c307b4fe6f7079c498fa1d20f22c8147676c6449 Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Fri, 6 Sep 2024 09:41:04 +0200 Subject: [PATCH 4/8] Use 'title' instead of 'label' in schema --- src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php b/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php index f523285fb9608..aa0bc644bc1ce 100644 --- a/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php +++ b/src/wp-includes/rest-api/fields/class-wp-rest-meta-fields.php @@ -478,7 +478,7 @@ protected function get_registered_fields() { $default_schema = array( 'type' => $default_args['type'], - 'label' => empty( $args['label'] ) ? '' : $args['label'], + 'title' => empty( $args['label'] ) ? '' : $args['label'], 'description' => empty( $args['description'] ) ? '' : $args['description'], 'default' => isset( $args['default'] ) ? $args['default'] : null, ); From 74e3465c4059478fd87b99f8edd1a1c66c222e12 Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Fri, 6 Sep 2024 13:01:08 +0200 Subject: [PATCH 5/8] Add unit test to check title in schema --- .../tests/rest-api/rest-post-meta-fields.php | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/tests/phpunit/tests/rest-api/rest-post-meta-fields.php b/tests/phpunit/tests/rest-api/rest-post-meta-fields.php index 2546076b2ae1d..fdb39ec657fff 100644 --- a/tests/phpunit/tests/rest-api/rest-post-meta-fields.php +++ b/tests/phpunit/tests/rest-api/rest-post-meta-fields.php @@ -243,6 +243,18 @@ public function set_up() { ) ); + register_post_meta( + 'post', + 'with_label', + array( + 'type' => 'string', + 'single' => true, + 'show_in_rest' => true, + 'label' => 'Meta Label', + 'default' => '', + ) + ); + /** @var WP_REST_Server $wp_rest_server */ global $wp_rest_server; $wp_rest_server = new Spy_REST_Server(); @@ -3095,6 +3107,19 @@ public function test_default_is_added_to_schema() { $this->assertSame( 'Goodnight Moon', $schema['default'] ); } + /** + * @ticket 61998 + */ + public function test_title_is_added_to_schema() { + $request = new WP_REST_Request( 'OPTIONS', '/wp/v2/posts' ); + $response = rest_do_request( $request ); + + $schema = $response->get_data()['schema']['properties']['meta']['properties']['with_label']; + + $this->assertArrayHasKey( 'default', $schema ); + $this->assertSame( 'Meta Label', $schema['title'] ); + } + /** * Ensures that REST API calls with post meta containing the default value for the * registered meta field stores the default value into the database. From 0abab555f4918717758351aef54c860a927a5b28 Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Fri, 6 Sep 2024 13:47:42 +0200 Subject: [PATCH 6/8] Add since tag --- src/wp-includes/meta.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/wp-includes/meta.php b/src/wp-includes/meta.php index a9a98e99cfc1f..0e2873b535477 100644 --- a/src/wp-includes/meta.php +++ b/src/wp-includes/meta.php @@ -1368,6 +1368,7 @@ function sanitize_meta( $meta_key, $meta_value, $object_type, $object_subtype = * @since 5.3.0 Valid meta types expanded to include "array" and "object". * @since 5.5.0 The `$default` argument was added to the arguments array. * @since 6.4.0 The `$revisions_enabled` argument was added to the arguments array. + * @since 6.7.0 The `label` argument was added to the arguments array. * * @param string $object_type Type of object metadata is for. Accepts 'post', 'comment', 'term', 'user', * or any other object type with an associated meta table. From 7211ec96ced0d52d5cd97467480fd90b3ca99f31 Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Fri, 6 Sep 2024 13:52:04 +0200 Subject: [PATCH 7/8] Inherit `show_in_rest` from `label` --- src/wp-includes/meta.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/wp-includes/meta.php b/src/wp-includes/meta.php index 0e2873b535477..1acb116552ab5 100644 --- a/src/wp-includes/meta.php +++ b/src/wp-includes/meta.php @@ -1454,6 +1454,9 @@ function register_meta( $object_type, $meta_key, $args, $deprecated = null ) { * @param string $meta_key Meta key. */ $args = apply_filters( 'register_meta_args', $args, $defaults, $object_type, $meta_key ); + if ( isset( $args['label'] ) && ! isset( $args['show_in_rest'] ) ) { + $args['show_in_rest'] = true; + } unset( $defaults['default'] ); $args = wp_parse_args( $args, $defaults ); From 41ae82bf751122f204eceefea80a1b642b8f1d6a Mon Sep 17 00:00:00 2001 From: Mario Santos Date: Fri, 6 Sep 2024 13:52:04 +0200 Subject: [PATCH 8/8] Add unit test --- .../tests/rest-api/rest-post-meta-fields.php | 30 +++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/tests/phpunit/tests/rest-api/rest-post-meta-fields.php b/tests/phpunit/tests/rest-api/rest-post-meta-fields.php index fdb39ec657fff..fe95bd4e3299d 100644 --- a/tests/phpunit/tests/rest-api/rest-post-meta-fields.php +++ b/tests/phpunit/tests/rest-api/rest-post-meta-fields.php @@ -80,6 +80,7 @@ public function set_up() { 'post', 'test_rest_disabled', array( + 'label' => 'Test REST Disabled', 'show_in_rest' => false, 'type' => 'string', ) @@ -255,6 +256,17 @@ public function set_up() { ) ); + register_post_meta( + 'post', + 'test_label_and_no_rest', + array( + 'type' => 'string', + 'single' => true, + 'label' => 'Meta Label', + 'default' => '', + ) + ); + /** @var WP_REST_Server $wp_rest_server */ global $wp_rest_server; $wp_rest_server = new Spy_REST_Server(); @@ -3975,6 +3987,24 @@ public function test_revisioned_single_post_meta_with_posts_endpoint_page_and_cp wp_delete_post( $post_id, true ); } + /** + * @ticket 61998 + */ + public function test_get_registered_label_without_rest() { + add_post_meta( self::$post_id, 'test_label_and_no_rest', 'val1' ); + $request = new WP_REST_Request( 'GET', sprintf( '/wp/v2/posts/%d', self::$post_id ) ); + + $response = rest_get_server()->dispatch( $request ); + $this->assertSame( 200, $response->get_status() ); + + $data = $response->get_data(); + $this->assertArrayHasKey( 'meta', $data ); + + $meta = (array) $data['meta']; + $this->assertArrayHasKey( 'test_label_and_no_rest', $meta ); + $this->assertSame( 'val1', $meta['test_label_and_no_rest'] ); + } + /** * Provide data for the meta revision checks. */