From 862f6e95693516557214f7dd3831303828a32290 Mon Sep 17 00:00:00 2001 From: hellofromTonya Date: Fri, 5 Nov 2021 23:01:58 +0000 Subject: [PATCH] Posts/Post Types: Add filter to `is_post_type_viewable()`. Introduces a new filter `'is_post_type_viewable'` which allows overriding the check. The expected filtered value is a boolean. As filtered values can change, including the data type, this commit includes a `is_bool()` check, thus ensuring backwards-compatibility. Follow-up to [33666], [36402]. Props audrasjb, deepaklalwani, hellofromTonya, peterwilsoncc, powerbuoy, sergeybiryukov. Fixes #49628. Built from https://develop.svn.wordpress.org/trunk@52024 git-svn-id: http://core.svn.wordpress.org/trunk@51616 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/post.php | 20 +++++++++++++++++++- wp-includes/version.php | 2 +- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/wp-includes/post.php b/wp-includes/post.php index b6ca7c24d3..91edacf76f 100644 --- a/wp-includes/post.php +++ b/wp-includes/post.php @@ -2086,6 +2086,7 @@ function set_post_type( $post_id = 0, $post_type = 'post' ) { * @since 4.4.0 * @since 4.5.0 Added the ability to pass a post type name in addition to object. * @since 4.6.0 Converted the `$post_type` parameter to accept a `WP_Post_Type` object. + * @since 5.9.0 Added `is_post_type_viewable` hook to filter the result. * * @param string|WP_Post_Type $post_type Post type name or object. * @return bool Whether the post type should be considered viewable. @@ -2102,7 +2103,24 @@ function is_post_type_viewable( $post_type ) { return false; } - return $post_type->publicly_queryable || ( $post_type->_builtin && $post_type->public ); + $is_viewable = $post_type->publicly_queryable || ( $post_type->_builtin && $post_type->public ); + + /** + * Filters whether a post type is considered "viewable". + * + * @since 5.9.0 + * + * @param bool $is_viewable Whether the post type is "viewable". + * @param WP_Post_Type $post_type Post type object. + */ + $is_viewable = apply_filters( 'is_post_type_viewable', $is_viewable, $post_type ); + + // Make sure the filtered value is a boolean type before returning it. + if ( ! is_bool( $is_viewable ) ) { + return false; + } + + return $is_viewable; } /** diff --git a/wp-includes/version.php b/wp-includes/version.php index e4d320ee52..cf7877579d 100644 --- a/wp-includes/version.php +++ b/wp-includes/version.php @@ -16,7 +16,7 @@ * * @global string $wp_version */ -$wp_version = '5.9-alpha-52023'; +$wp_version = '5.9-alpha-52024'; /** * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.