Revisions: only create autosave when content changed.
In the autosave REST API endpoint, avoid excessive database writes when an autosave is sent with content that is unchanged from the saved post. Before this fix, clicking "preview" in the editor (which uses the autosave feature) multiple times would cause an identical autosave entry to be deleted and re-created repeatedly. Props inwerpsel, aduth, mukesh27, ironprogrammer. Fixes #49532. Built from https://develop.svn.wordpress.org/trunk@55154 git-svn-id: http://core.svn.wordpress.org/trunk@54687 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
0d27540b5e
commit
5df3679f34
|
@ -360,35 +360,34 @@ class WP_REST_Autosaves_Controller extends WP_REST_Revisions_Controller {
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Only create an autosave when it is different from the saved post.
|
||||||
|
$autosave_is_different = false;
|
||||||
|
$new_autosave = _wp_post_revision_data( $post_data, true );
|
||||||
|
|
||||||
|
foreach ( array_intersect( array_keys( $new_autosave ), array_keys( _wp_post_revision_fields( $post ) ) ) as $field ) {
|
||||||
|
if ( normalize_whitespace( $new_autosave[ $field ] ) !== normalize_whitespace( $post->$field ) ) {
|
||||||
|
$autosave_is_different = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! $autosave_is_different ) {
|
||||||
|
return new WP_Error(
|
||||||
|
'rest_autosave_no_changes',
|
||||||
|
__( 'There is nothing to save. The autosave and the post content are the same.' ),
|
||||||
|
array( 'status' => 400 )
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
$user_id = get_current_user_id();
|
$user_id = get_current_user_id();
|
||||||
|
|
||||||
// Store one autosave per author. If there is already an autosave, overwrite it.
|
// Store one autosave per author. If there is already an autosave, overwrite it.
|
||||||
$old_autosave = wp_get_post_autosave( $post_id, $user_id );
|
$old_autosave = wp_get_post_autosave( $post_id, $user_id );
|
||||||
|
|
||||||
if ( $old_autosave ) {
|
if ( $old_autosave ) {
|
||||||
$new_autosave = _wp_post_revision_data( $post_data, true );
|
|
||||||
$new_autosave['ID'] = $old_autosave->ID;
|
$new_autosave['ID'] = $old_autosave->ID;
|
||||||
$new_autosave['post_author'] = $user_id;
|
$new_autosave['post_author'] = $user_id;
|
||||||
|
|
||||||
// If the new autosave has the same content as the post, delete the autosave.
|
|
||||||
$autosave_is_different = false;
|
|
||||||
|
|
||||||
foreach ( array_intersect( array_keys( $new_autosave ), array_keys( _wp_post_revision_fields( $post ) ) ) as $field ) {
|
|
||||||
if ( normalize_whitespace( $new_autosave[ $field ] ) !== normalize_whitespace( $post->$field ) ) {
|
|
||||||
$autosave_is_different = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( ! $autosave_is_different ) {
|
|
||||||
wp_delete_post_revision( $old_autosave->ID );
|
|
||||||
return new WP_Error(
|
|
||||||
'rest_autosave_no_changes',
|
|
||||||
__( 'There is nothing to save. The autosave and the post content are the same.' ),
|
|
||||||
array( 'status' => 400 )
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** This filter is documented in wp-admin/post.php */
|
/** This filter is documented in wp-admin/post.php */
|
||||||
do_action( 'wp_creating_autosave', $new_autosave );
|
do_action( 'wp_creating_autosave', $new_autosave );
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.2-alpha-55153';
|
$wp_version = '6.2-alpha-55154';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue