From 9eb5abbccb28c89040eff687c9dafb89b032816d Mon Sep 17 00:00:00 2001 From: Scott Taylor Date: Sat, 12 Sep 2015 15:58:09 +0000 Subject: [PATCH] `wp_delete_post()`: add a filter, 'pre_delete_post', to allow bailout from the function if the filter returns a non-null value. Props boonebgorges. Fixes #32933. git-svn-id: https://develop.svn.wordpress.org/trunk@34082 602fd350-edb4-49c9-b593-d223f7449a82 --- src/wp-includes/post-functions.php | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/wp-includes/post-functions.php b/src/wp-includes/post-functions.php index 7c0786239a..1d6ae6fc39 100644 --- a/src/wp-includes/post-functions.php +++ b/src/wp-includes/post-functions.php @@ -2317,6 +2317,20 @@ function wp_delete_post( $postid = 0, $force_delete = false ) { if ( $post->post_type == 'attachment' ) return wp_delete_attachment( $postid, $force_delete ); + /** + * Filter whether a post deletion should take place. + * + * @since 4.4.0 + * + * @param bool $delete Whether to go forward with deletion. + * @param WP_Post $post Post object. + * @param bool $force_delete Whether to bypass the trash. + */ + $check = apply_filters( 'pre_delete_post', null, $post, $force_delete ); + if ( null !== $check ) { + return $check; + } + /** * Fires before a post is deleted, at the start of wp_delete_post(). *