From 695307ba29b7d4cd7081690ea850c3e5e4745ef7 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 15:00:26 -0300 Subject: [PATCH 01/19] make WP_Font_Collection object properties public --- .../fonts/font-library/class-wp-font-collection.php | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-font-collection.php b/lib/experimental/fonts/font-library/class-wp-font-collection.php index 1ff96b1343b453..c6bf24ec34fd5a 100644 --- a/lib/experimental/fonts/font-library/class-wp-font-collection.php +++ b/lib/experimental/fonts/font-library/class-wp-font-collection.php @@ -27,7 +27,7 @@ class WP_Font_Collection { * * @var string */ - private $slug; + public $slug; /** * The name of the font collection. @@ -36,7 +36,7 @@ class WP_Font_Collection { * * @var string */ - private $name; + public $name; /** * Description of the font collection. @@ -45,7 +45,7 @@ class WP_Font_Collection { * * @var string */ - private $description; + public $description; /** * Source of the font collection. @@ -54,7 +54,7 @@ class WP_Font_Collection { * * @var string */ - private $src; + public $src; /** * Array of font families in the collection. @@ -63,7 +63,7 @@ class WP_Font_Collection { * * @var array */ - private $font_families; + public $font_families; /** * Categories associated with the font collection. @@ -72,7 +72,7 @@ class WP_Font_Collection { * * @var array */ - private $categories; + public $categories; /** From 2dcbfa8b337c1f94af28e347826b9edafb7778cf Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:07:14 -0300 Subject: [PATCH 02/19] remove class method no longer used --- .../font-library/class-wp-font-collection.php | 21 ----- .../wpFontCollection/getConfig.php | 76 ------------------- 2 files changed, 97 deletions(-) delete mode 100644 phpunit/tests/fonts/font-library/wpFontCollection/getConfig.php diff --git a/lib/experimental/fonts/font-library/class-wp-font-collection.php b/lib/experimental/fonts/font-library/class-wp-font-collection.php index c6bf24ec34fd5a..7f8d5842d81247 100644 --- a/lib/experimental/fonts/font-library/class-wp-font-collection.php +++ b/lib/experimental/fonts/font-library/class-wp-font-collection.php @@ -145,27 +145,6 @@ public static function is_config_valid( $config ) { return true; } - /** - * Gets the font collection config. - * - * @since 6.5.0 - * - * @return array { - * An array of font collection config. - * - * @type string $slug The font collection's unique slug. - * @type string $name The font collection's name. - * @type string $description The font collection's description. - * } - */ - public function get_config() { - return array( - 'slug' => $this->slug, - 'name' => $this->name, - 'description' => $this->description, - ); - } - /** * Gets the font collection content. * diff --git a/phpunit/tests/fonts/font-library/wpFontCollection/getConfig.php b/phpunit/tests/fonts/font-library/wpFontCollection/getConfig.php deleted file mode 100644 index 393de7d22614da..00000000000000 --- a/phpunit/tests/fonts/font-library/wpFontCollection/getConfig.php +++ /dev/null @@ -1,76 +0,0 @@ -assertSame( $expected_data, $collection->get_config() ); - } - - /** - * Data provider. - * - * @return array[] - */ - public function data_should_get_config() { - $mock_file = wp_tempnam( 'my-collection-data-' ); - file_put_contents( $mock_file, '{"this is mock data":true}' ); - - return array( - 'with a file' => array( - 'config' => array( - 'slug' => 'my-collection', - 'name' => 'My Collection', - 'description' => 'My collection description', - 'src' => $mock_file, - ), - 'expected_data' => array( - 'slug' => 'my-collection', - 'name' => 'My Collection', - 'description' => 'My collection description', - ), - ), - 'with a url' => array( - 'config' => array( - 'slug' => 'my-collection-with-url', - 'name' => 'My Collection with URL', - 'description' => 'My collection description', - 'src' => 'https://localhost/fonts/mock-font-collection.json', - ), - 'expected_data' => array( - 'slug' => 'my-collection-with-url', - 'name' => 'My Collection with URL', - 'description' => 'My collection description', - ), - ), - 'with font_families' => array( - 'config' => array( - 'slug' => 'my-collection', - 'name' => 'My Collection', - 'description' => 'My collection description', - 'font_families' => array( array() ), - ), - 'expected_data' => array( - 'slug' => 'my-collection', - 'name' => 'My Collection', - 'description' => 'My collection description', - ), - ), - ); - } -} From f2082c3302f5e8a43be24a236f6e2c7c7fb8428a Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:07:41 -0300 Subject: [PATCH 03/19] simplify the acces to the font collection properties --- lib/experimental/fonts/font-library/class-wp-font-library.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-font-library.php b/lib/experimental/fonts/font-library/class-wp-font-library.php index 51a84b957ea117..b826ffa62aad25 100644 --- a/lib/experimental/fonts/font-library/class-wp-font-library.php +++ b/lib/experimental/fonts/font-library/class-wp-font-library.php @@ -69,7 +69,7 @@ public static function register_font_collection( $config ) { $new_collection = new WP_Font_Collection( $config ); - if ( self::is_collection_registered( $new_collection->get_config()['slug'] ) ) { + if ( self::is_collection_registered( $new_collection->slug ) ) { $error_message = sprintf( /* translators: %s: Font collection slug. */ __( 'Font collection with slug: "%s" is already registered.', 'gutenberg' ), @@ -82,7 +82,7 @@ public static function register_font_collection( $config ) { ); return new WP_Error( 'font_collection_registration_error', $error_message ); } - self::$collections[ $new_collection->get_config()['slug'] ] = $new_collection; + self::$collections[ $new_collection->slug ] = $new_collection; return $new_collection; } From 0edb6cd0f0a07fe2c22123787659222be8d1476b Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:20:37 -0300 Subject: [PATCH 04/19] add schema, args, fields and pagination to font collections rest controller --- ...ss-wp-rest-font-collections-controller.php | 188 ++++++++++++++++-- 1 file changed, 175 insertions(+), 13 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 51fd14fffaa953..70966215ff20fb 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -44,7 +44,9 @@ public function register_routes() { 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_items' ), 'permission_callback' => array( $this, 'get_items_permissions_check' ), + 'args' => $this->get_collection_params(), ), + 'schema' => array( $this, 'get_public_item_schema' ), ) ); @@ -57,6 +59,7 @@ public function register_routes() { 'callback' => array( $this, 'get_item' ), 'permission_callback' => array( $this, 'get_items_permissions_check' ), ), + 'schema' => array( $this, 'get_public_item_schema' ), ) ); } @@ -68,13 +71,61 @@ public function register_routes() { * * @return WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure. */ - public function get_items( $request ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable - $collections = array(); - foreach ( WP_Font_Library::get_font_collections() as $collection ) { - $collections[] = $collection->get_config(); + public function get_items( $request ) { + $collections_all = WP_Font_Library::get_font_collections(); + + $page = $request['page']; + $per_page = $request['per_page']; + $total_items = count( $collections_all ); + $max_pages = ceil( $total_items / $per_page ); + + if ( $page > $max_pages && $total_items > 0 ) { + return new WP_Error( + 'rest_post_invalid_page_number', + __( 'The page number requested is larger than the number of pages available.' ), + array( 'status' => 400 ) + ); + } + + $collections_page = array_slice( $collections_all, ( $page - 1 ) * $per_page, $per_page ); + + $items = array(); + foreach ( $collections_page as $collection ) { + $item = $this->prepare_item_for_response( $collection, $request ); + if ( is_wp_error( $item ) ) { + return $item; + } + $item = $this->prepare_response_for_collection( $item ); + $items[] = $item; + } + + $response = rest_ensure_response( $items ); + + $response->header( 'X-WP-Total', (int) $total_items ); + $response->header( 'X-WP-TotalPages', (int) $max_pages ); + + $request_params = $request->get_query_params(); + $collection_url = rest_url( $this->namespace . '/' . $this->rest_base ); + $base = add_query_arg( urlencode_deep( $request_params ), $collection_url ); + + if ( $page > 1 ) { + $prev_page = $page - 1; + + if ( $prev_page > $max_pages ) { + $prev_page = $max_pages; + } + + $prev_link = add_query_arg( 'page', $prev_page, $base ); + $response->link_header( 'prev', $prev_link ); + } + if ( $max_pages > $page ) { + $next_page = $page + 1; + $next_link = add_query_arg( 'page', $next_page, $base ); + + $response->link_header( 'next', $next_link ); } - return rest_ensure_response( $collections, 200 ); + return $response; } /** @@ -95,17 +146,128 @@ public function get_item( $request ) { return $collection; } - $config = $collection->get_config(); - $contents = $collection->get_content(); + $item = $this->prepare_item_for_response( $collection, $request ); + + if ( is_wp_error( $item ) ) { + return $item; + } + + return $item; + } + + /* + * Prepare a single collection output for response + * + * @since 6.5.0 + * + * @param WP_Font_Collection $collection Collection object. + * @param WP_REST_Request $request Request object. + * @return array|WP_Error + */ + public function prepare_item_for_response( $collection, $request ) { + $fields = $this->get_fields_for_response( $request ); + $item = array(); + + $config_fields = array( 'slug', 'name', 'description' ); + foreach ( $config_fields as $field ) { + if ( in_array( $field, $fields ) ) { + $item[ $field ] = $collection->$field; + } + } + + $data_fields = array( 'font_families', 'categories' ); + if ( in_array( 'font_families', $fields ) || in_array( 'categories', $fields ) ) { + $content = $collection->get_content(); + + // If there was an error getting the collection data, return the error. + if ( is_wp_error( $content ) ) { + $content->add_data( array( 'status' => 500 ) ); + return $content; + } + + foreach ( $data_fields as $field ) { + if ( in_array( $field, $fields ) ) { + $item[ $field ] = $content[ $field ]; + } + } + } + + return rest_ensure_response( $item ); + } - // If there was an error getting the collection data, return the error. - if ( is_wp_error( $contents ) ) { - $contents->add_data( array( 'status' => 500 ) ); - return $contents; + /** + * Retrieves the font collection's schema, conforming to JSON Schema. + * + * @since 6.5.0 + * + * @return array Item schema data. + */ + public function get_item_schema() { + if ( $this->schema ) { + return $this->add_additional_fields_schema( $this->schema ); } - $collection_data = array_merge( $config, $contents ); - return rest_ensure_response( $collection_data ); + $schema = array( + '$schema' => 'http://json-schema.org/draft-04/schema#', + 'title' => 'font-collection', + 'type' => 'object', + 'properties' => array( + 'slug' => array( + 'description' => __( 'Unique identifier for the font collection.', 'gutenberg' ), + 'type' => 'string', + 'context' => array( 'view', 'edit' ), + 'readonly' => true, + ), + 'name' => array( + 'description' => __( 'The name for the font collection.', 'gutenberg' ), + 'type' => 'string', + 'context' => array( 'view', 'edit' ), + ), + 'description' => array( + 'description' => __( 'The description for the font collection.', 'gutenberg' ), + 'type' => 'string', + 'context' => array( 'view', 'edit' ), + ), + 'font_families' => array( + 'description' => __( 'The font families for the font collection.', 'gutenberg' ), + 'type' => 'array', + 'context' => array( 'view', 'edit' ), + ), + 'categories' => array( + 'description' => __( 'The categories for the font collection.', 'gutenberg' ), + 'type' => 'array', + 'context' => array( 'view', 'edit' ), + ), + ), + ); + + $this->schema = $schema; + + return $this->add_additional_fields_schema( $this->schema ); + } + + /** + * Retrieves the search params for the font collections. + * + * @since 6.5.0 + * + * @return array Collection parameters. + */ + public function get_collection_params() { + $query_params = parent::get_collection_params(); + + $query_params['context']['default'] = 'view'; + + unset( $query_params['search'] ); + + /** + * Filters REST API collection parameters for the font collections controller. + * + * @since 5.5.0 + * + * @param array $query_params JSON Schema-formatted collection parameters. + */ + return apply_filters( 'rest_font_collections_collection_params', $query_params ); } /** From 619162ef2b885a1c3fdcf29d3ee4cc7a8e19f993 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:21:07 -0300 Subject: [PATCH 05/19] add one test case for params --- .../wpRestFontCollectionsController.php | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/phpunit/tests/fonts/font-library/wpRestFontCollectionsController.php b/phpunit/tests/fonts/font-library/wpRestFontCollectionsController.php index 164f88f3f7b4b2..f2140267672d2b 100644 --- a/phpunit/tests/fonts/font-library/wpRestFontCollectionsController.php +++ b/phpunit/tests/fonts/font-library/wpRestFontCollectionsController.php @@ -154,10 +154,18 @@ public function test_prepare_item() { // Controller does not use test_prepare_item(). } - /** - * @doesNotPerformAssertions - */ public function test_get_item_schema() { - // Controller does not use test_get_item_schema(). + $request = new WP_REST_Request( 'OPTIONS', '/wp/v2/font-collections' ); + $response = rest_get_server()->dispatch( $request ); + $data = $response->get_data(); + + $this->assertSame( 200, $response->get_status() ); + $properties = $data['schema']['properties']; + $this->assertCount( 5, $properties ); + $this->assertArrayHasKey( 'slug', $properties ); + $this->assertArrayHasKey( 'name', $properties ); + $this->assertArrayHasKey( 'description', $properties ); + $this->assertArrayHasKey( 'font_families', $properties ); + $this->assertArrayHasKey( 'categories', $properties ); } } From d9c1255deadb41040dd326889161985169d53f58 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:21:39 -0300 Subject: [PATCH 06/19] request a subset of font collection fields --- .../components/global-styles/font-library-modal/resolvers.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/edit-site/src/components/global-styles/font-library-modal/resolvers.js b/packages/edit-site/src/components/global-styles/font-library-modal/resolvers.js index a75fc6cbe78ffb..a114630cfc08d1 100644 --- a/packages/edit-site/src/components/global-styles/font-library-modal/resolvers.js +++ b/packages/edit-site/src/components/global-styles/font-library-modal/resolvers.js @@ -63,7 +63,7 @@ export async function fetchUninstallFontFamily( fontFamilyId ) { export async function fetchFontCollections() { const config = { - path: FONT_COLLECTIONS_URL, + path: `${ FONT_COLLECTIONS_URL }?_fields=slug,name,description`, method: 'GET', }; return await apiFetch( config ); From 918dcb23349f124ce925d2368cb7dcf71fe747de Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:39:05 -0300 Subject: [PATCH 07/19] lint --- .../class-wp-rest-font-collections-controller.php | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 70966215ff20fb..034f31294fdfc4 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -82,7 +82,7 @@ public function get_items( $request ) { if ( $page > $max_pages && $total_items > 0 ) { return new WP_Error( 'rest_post_invalid_page_number', - __( 'The page number requested is larger than the number of pages available.' ), + __( 'The page number requested is larger than the number of pages available.', 'gutenberg' ), array( 'status' => 400 ) ); } @@ -170,13 +170,13 @@ public function prepare_item_for_response( $collection, $request ) { $config_fields = array( 'slug', 'name', 'description' ); foreach ( $config_fields as $field ) { - if ( in_array( $field, $fields ) ) { + if ( in_array( $field, $fields, true ) ) { $item[ $field ] = $collection->$field; } } $data_fields = array( 'font_families', 'categories' ); - if ( in_array( 'font_families', $fields ) || in_array( 'categories', $fields ) ) { + if ( in_array( 'font_families', $fields, true ) || in_array( 'categories', $fields, true ) ) { $content = $collection->get_content(); // If there was an error getting the collection data, return the error. @@ -186,7 +186,7 @@ public function prepare_item_for_response( $collection, $request ) { } foreach ( $data_fields as $field ) { - if ( in_array( $field, $fields ) ) { + if ( in_array( $field, $fields, true ) ) { $item[ $field ] = $content[ $field ]; } } From 3f2b5566e05876c56164d1cbe9eb5ae1e9ca0911 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:47:40 -0300 Subject: [PATCH 08/19] remove not needed default change --- .../font-library/class-wp-rest-font-collections-controller.php | 2 -- 1 file changed, 2 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 034f31294fdfc4..472a28b47bb6da 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -256,8 +256,6 @@ public function get_item_schema() { public function get_collection_params() { $query_params = parent::get_collection_params(); - $query_params['context']['default'] = 'view'; - unset( $query_params['search'] ); /** From 6a5971ce1cee119e37617ecf6db0400ca2ef8d29 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Wed, 24 Jan 2024 18:48:02 -0300 Subject: [PATCH 09/19] update version since --- .../font-library/class-wp-rest-font-collections-controller.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 472a28b47bb6da..4f792f9271ba49 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -261,7 +261,7 @@ public function get_collection_params() { /** * Filters REST API collection parameters for the font collections controller. * - * @since 5.5.0 + * @since 6.5.0 * * @param array $query_params JSON Schema-formatted collection parameters. */ From 18f996342b4ba37542eaa87a727a409997bd162f Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Thu, 25 Jan 2024 09:35:06 -0300 Subject: [PATCH 10/19] use placeholder for translation --- .../fonts/font-library/class-wp-font-collection.php | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-font-collection.php b/lib/experimental/fonts/font-library/class-wp-font-collection.php index 7f8d5842d81247..c196ffa5e02c52 100644 --- a/lib/experimental/fonts/font-library/class-wp-font-collection.php +++ b/lib/experimental/fonts/font-library/class-wp-font-collection.php @@ -138,7 +138,16 @@ public static function is_config_valid( $config ) { ( empty( $config['src'] ) && empty( $config['font_families'] ) ) || ( ! empty( $config['src'] ) && ! empty( $config['font_families'] ) ) ) { - _doing_it_wrong( __METHOD__, __( 'Font Collection config "src" option OR "font_families" option are required.', 'gutenberg' ), '6.5.0' ); + _doing_it_wrong( + __METHOD__, + sprintf( + /* translators: %1$s: src, %2$s: font_families */ + __( 'Font Collection config "%1$s" option OR "%2$s" option are required.', 'gutenberg' ), + 'src', + 'font_families' + ), + '6.5.0' + ); return false; } From 82fd8a2e574bf94a7d04098e3754d1fe80cd2727 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Thu, 25 Jan 2024 14:15:21 -0300 Subject: [PATCH 11/19] update comment Co-authored-by: Sarah Norris <1645628+mikachan@users.noreply.github.com> --- .../font-library/class-wp-rest-font-collections-controller.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 4f792f9271ba49..37f561fd65f608 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -156,7 +156,7 @@ public function get_item( $request ) { } /* - * Prepare a single collection output for response + * Prepare a single collection output for response. * * @since 6.5.0 * From 3964fdf00bd9356996bc88de51f6f0b48b26a3a9 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Thu, 25 Jan 2024 16:23:48 -0300 Subject: [PATCH 12/19] update translation domain Co-authored-by: Grant Kinney --- .../font-library/class-wp-rest-font-collections-controller.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 37f561fd65f608..27ed0fad0779dc 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -82,7 +82,7 @@ public function get_items( $request ) { if ( $page > $max_pages && $total_items > 0 ) { return new WP_Error( 'rest_post_invalid_page_number', - __( 'The page number requested is larger than the number of pages available.', 'gutenberg' ), + __( 'The page number requested is larger than the number of pages available.', 'default' ), array( 'status' => 400 ) ); } From d3456f9c17addac94a393aea285b7eaa7c7d850a Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Thu, 25 Jan 2024 16:31:41 -0300 Subject: [PATCH 13/19] update wording --- .../fonts/font-library/class-wp-font-collection.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-font-collection.php b/lib/experimental/fonts/font-library/class-wp-font-collection.php index c196ffa5e02c52..fedcfc2d02e6cf 100644 --- a/lib/experimental/fonts/font-library/class-wp-font-collection.php +++ b/lib/experimental/fonts/font-library/class-wp-font-collection.php @@ -142,7 +142,7 @@ public static function is_config_valid( $config ) { __METHOD__, sprintf( /* translators: %1$s: src, %2$s: font_families */ - __( 'Font Collection config "%1$s" option OR "%2$s" option are required.', 'gutenberg' ), + __( 'Font Collection config "%1$s" option OR "%2$s" option is required.', 'gutenberg' ), 'src', 'font_families' ), From e1062356e52edf994994461805e78f7c8fb8fd1e Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Thu, 25 Jan 2024 16:34:44 -0300 Subject: [PATCH 14/19] set context to edit only --- .../class-wp-rest-font-collections-controller.php | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 27ed0fad0779dc..1fee435009af79 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -215,28 +215,28 @@ public function get_item_schema() { 'slug' => array( 'description' => __( 'Unique identifier for the font collection.', 'gutenberg' ), 'type' => 'string', - 'context' => array( 'view', 'edit' ), + 'context' => array( 'edit' ), 'readonly' => true, ), 'name' => array( 'description' => __( 'The name for the font collection.', 'gutenberg' ), 'type' => 'string', - 'context' => array( 'view', 'edit' ), + 'context' => array( 'edit' ), ), 'description' => array( 'description' => __( 'The description for the font collection.', 'gutenberg' ), 'type' => 'string', - 'context' => array( 'view', 'edit' ), + 'context' => array( 'edit' ), ), 'font_families' => array( 'description' => __( 'The font families for the font collection.', 'gutenberg' ), 'type' => 'array', - 'context' => array( 'view', 'edit' ), + 'context' => array( 'edit' ), ), 'categories' => array( 'description' => __( 'The categories for the font collection.', 'gutenberg' ), 'type' => 'array', - 'context' => array( 'view', 'edit' ), + 'context' => array( 'edit' ), ), ), ); From d0d8a750bc60135f2f9f0a6d942e144cc79e6dd4 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Fri, 26 Jan 2024 10:40:40 -0300 Subject: [PATCH 15/19] use 'view', 'edit' and 'embed' on the context of all the schema properties --- .../class-wp-rest-font-collections-controller.php | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 1fee435009af79..5a20afed615f2c 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -215,28 +215,28 @@ public function get_item_schema() { 'slug' => array( 'description' => __( 'Unique identifier for the font collection.', 'gutenberg' ), 'type' => 'string', - 'context' => array( 'edit' ), + 'context' => array( 'view', 'edit', 'embed' ), 'readonly' => true, ), 'name' => array( 'description' => __( 'The name for the font collection.', 'gutenberg' ), 'type' => 'string', - 'context' => array( 'edit' ), + 'context' => array( 'view', 'edit', 'embed' ), ), 'description' => array( 'description' => __( 'The description for the font collection.', 'gutenberg' ), 'type' => 'string', - 'context' => array( 'edit' ), + 'context' => array( 'view', 'edit', 'embed' ), ), 'font_families' => array( 'description' => __( 'The font families for the font collection.', 'gutenberg' ), 'type' => 'array', - 'context' => array( 'edit' ), + 'context' => array( 'view', 'edit', 'embed' ), ), 'categories' => array( 'description' => __( 'The categories for the font collection.', 'gutenberg' ), 'type' => 'array', - 'context' => array( 'edit' ), + 'context' => array( 'view', 'edit', 'embed' ), ), ), ); From 7372ddce73078a70145d1840121299272ef3723f Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Fri, 26 Jan 2024 11:13:57 -0300 Subject: [PATCH 16/19] prepare_item_for_response --- ...ss-wp-rest-font-collections-controller.php | 44 ++++++++++++++++++- 1 file changed, 43 insertions(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 5a20afed615f2c..cad72af20558cf 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -192,7 +192,29 @@ public function prepare_item_for_response( $collection, $request ) { } } - return rest_ensure_response( $item ); + $response = rest_ensure_response( $item ); + + if ( rest_is_field_included( '_links', $fields ) ) { + $links = $this->prepare_links( $collection ); + $response->add_links( $links ); + } + + $context = ! empty( $request['context'] ) ? $request['context'] : 'view'; + $response->data = $this->add_additional_fields_to_object( $response->data, $request ); + $response->data = $this->filter_response_by_context( $response->data, $context ); + + /** + * Filters a font collection returned from the REST API. + * + * Allows modification of the font collection right before it is returned. + * + * @since 6.5.0 + * + * @param WP_REST_Response $response The response object. + * @param WP_Font_Collection $collection The Font Collection object. + * @param WP_REST_Request $request Request used to generate the response. + */ + return apply_filters( 'rest_prepare_font_collection', $response, $collection, $request ); } /** @@ -246,6 +268,26 @@ public function get_item_schema() { return $this->add_additional_fields_schema( $this->schema ); } + /** + * Prepares links for the request. + * + * @since 6.5.0 + * + * @param WP_Font_Collection $collection Font collection data + * @return array Links for the given font collection. + */ + protected function prepare_links( $collection ) { + $links = array( + 'self' => array( + 'href' => rest_url( sprintf( '%s/%s/%s', $this->namespace, $this->rest_base, $collection->slug ) ), + ), + 'collection' => array( + 'href' => rest_url( sprintf( '%s/%s', $this->namespace, $this->rest_base ) ), + ), + ); + return $links; + } + /** * Retrieves the search params for the font collections. * From e545be01d31aab9f05e7f38fbc0a13720ddb7b22 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Fri, 26 Jan 2024 11:24:05 -0300 Subject: [PATCH 17/19] default context param --- .../class-wp-rest-font-collections-controller.php | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index cad72af20558cf..971baace8476d6 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -43,8 +43,10 @@ public function register_routes() { array( 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_items' ), - 'permission_callback' => array( $this, 'get_items_permissions_check' ), - 'args' => $this->get_collection_params(), + // 'permission_callback' => array( $this, 'get_items_permissions_check' ), + 'permission_callback' => '__return_true', + // 'args' => $this->get_collection_params(), + ), 'schema' => array( $this, 'get_public_item_schema' ), ) @@ -57,7 +59,9 @@ public function register_routes() { array( 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_item' ), - 'permission_callback' => array( $this, 'get_items_permissions_check' ), + // 'permission_callback' => array( $this, 'get_items_permissions_check' ), + 'permission_callback' => '__return_true', + 'args' => $this->get_endpoint_args_for_item_schema( WP_REST_Server::READABLE ), ), 'schema' => array( $this, 'get_public_item_schema' ), ) @@ -298,6 +302,8 @@ protected function prepare_links( $collection ) { public function get_collection_params() { $query_params = parent::get_collection_params(); + $query_params['context'] = $this->get_context_param( array( 'default' => 'view' ) ); + unset( $query_params['search'] ); /** From a0e5d722a60949b1c978cc536ec25d6189bcc0a1 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Fri, 26 Jan 2024 11:29:42 -0300 Subject: [PATCH 18/19] args for item endpoint --- .../class-wp-rest-font-collections-controller.php | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index 971baace8476d6..bc8d0917b1bab9 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -43,9 +43,8 @@ public function register_routes() { array( 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_items' ), - // 'permission_callback' => array( $this, 'get_items_permissions_check' ), - 'permission_callback' => '__return_true', - // 'args' => $this->get_collection_params(), + 'permission_callback' => array( $this, 'get_items_permissions_check' ), + 'args' => $this->get_collection_params(), ), 'schema' => array( $this, 'get_public_item_schema' ), @@ -59,9 +58,10 @@ public function register_routes() { array( 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_item' ), - // 'permission_callback' => array( $this, 'get_items_permissions_check' ), - 'permission_callback' => '__return_true', - 'args' => $this->get_endpoint_args_for_item_schema( WP_REST_Server::READABLE ), + 'permission_callback' => array( $this, 'get_items_permissions_check' ), + 'args' => array( + 'context' => $this->get_context_param( array( 'default' => 'view' ) ), + ), ), 'schema' => array( $this, 'get_public_item_schema' ), ) From a4c2bc405d76f60b8b198802a5574a8e18c66a7b Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Fri, 26 Jan 2024 11:35:51 -0300 Subject: [PATCH 19/19] format php --- .../font-library/class-wp-rest-font-collections-controller.php | 2 +- phpunit-watcher.yml.dist | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php index bc8d0917b1bab9..dd8301c71371e0 100644 --- a/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php +++ b/lib/experimental/fonts/font-library/class-wp-rest-font-collections-controller.php @@ -45,7 +45,7 @@ public function register_routes() { 'callback' => array( $this, 'get_items' ), 'permission_callback' => array( $this, 'get_items_permissions_check' ), 'args' => $this->get_collection_params(), - + ), 'schema' => array( $this, 'get_public_item_schema' ), ) diff --git a/phpunit-watcher.yml.dist b/phpunit-watcher.yml.dist index f2f9da5fbcdbfd..165a4d8e66e0b6 100644 --- a/phpunit-watcher.yml.dist +++ b/phpunit-watcher.yml.dist @@ -6,3 +6,6 @@ watch: notifications: passingTests: false failingTests: false + +phpunit: + arguments: '--filter Tests_Fonts_WpFontCollection_GetContent'