WordPress 4.7
[autoinstalls/wordpress.git] / wp-admin / revision.php
1 <?php
2 /**
3  * Revisions administration panel
4  *
5  * Requires wp-admin/includes/revision.php.
6  *
7  * @package WordPress
8  * @subpackage Administration
9  * @since 2.6.0
10  *
11  * @param int    revision Optional. The revision ID.
12  * @param string action   The action to take.
13  *                        Accepts 'restore', 'view' or 'edit'.
14  * @param int    from     The revision to compare from.
15  * @param int    to       Optional, required if revision missing. The revision to compare to.
16  */
17
18 /** WordPress Administration Bootstrap */
19 require_once( dirname( __FILE__ ) . '/admin.php' );
20
21 require ABSPATH . 'wp-admin/includes/revision.php';
22
23 wp_reset_vars( array( 'revision', 'action', 'from', 'to' ) );
24
25 $revision_id = absint( $revision );
26
27 $from = is_numeric( $from ) ? absint( $from ) : null;
28 if ( ! $revision_id )
29         $revision_id = absint( $to );
30 $redirect = 'edit.php';
31
32 switch ( $action ) {
33 case 'restore' :
34         if ( ! $revision = wp_get_post_revision( $revision_id ) )
35                 break;
36
37         if ( ! current_user_can( 'edit_post', $revision->post_parent ) )
38                 break;
39
40         if ( ! $post = get_post( $revision->post_parent ) )
41                 break;
42
43         // Restore if revisions are enabled or this is an autosave.
44         if ( ! wp_revisions_enabled( $post ) && ! wp_is_post_autosave( $revision ) ) {
45                 $redirect = 'edit.php?post_type=' . $post->post_type;
46                 break;
47         }
48
49         // Don't allow revision restore when post is locked
50         if ( wp_check_post_lock( $post->ID ) )
51                 break;
52
53         check_admin_referer( "restore-post_{$revision->ID}" );
54
55         wp_restore_post_revision( $revision->ID );
56         $redirect = add_query_arg( array( 'message' => 5, 'revision' => $revision->ID ), get_edit_post_link( $post->ID, 'url' ) );
57         break;
58 case 'view' :
59 case 'edit' :
60 default :
61         if ( ! $revision = wp_get_post_revision( $revision_id ) )
62                 break;
63         if ( ! $post = get_post( $revision->post_parent ) )
64                 break;
65
66         if ( ! current_user_can( 'read_post', $revision->ID ) || ! current_user_can( 'edit_post', $revision->post_parent ) )
67                 break;
68
69         // Revisions disabled and we're not looking at an autosave
70         if ( ! wp_revisions_enabled( $post ) && ! wp_is_post_autosave( $revision ) ) {
71                 $redirect = 'edit.php?post_type=' . $post->post_type;
72                 break;
73         }
74
75         $post_edit_link = get_edit_post_link();
76         $post_title     = '<a href="' . $post_edit_link . '">' . _draft_or_post_title() . '</a>';
77         /* translators: 1: Post title */
78         $h1             = sprintf( __( 'Compare Revisions of &#8220;%1$s&#8221;' ), $post_title );
79         $return_to_post = '<a href="' . $post_edit_link . '">' . __( '&larr; Return to editor' ) . '</a>';
80         $title          = __( 'Revisions' );
81
82         $redirect = false;
83         break;
84 }
85
86 // Empty post_type means either malformed object found, or no valid parent was found.
87 if ( ! $redirect && empty( $post->post_type ) )
88         $redirect = 'edit.php';
89
90 if ( ! empty( $redirect ) ) {
91         wp_redirect( $redirect );
92         exit;
93 }
94
95 // This is so that the correct "Edit" menu item is selected.
96 if ( ! empty( $post->post_type ) && 'post' != $post->post_type )
97         $parent_file = $submenu_file = 'edit.php?post_type=' . $post->post_type;
98 else
99         $parent_file = $submenu_file = 'edit.php';
100
101 wp_enqueue_script( 'revisions' );
102 wp_localize_script( 'revisions', '_wpRevisionsSettings', wp_prepare_revisions_for_js( $post, $revision_id, $from ) );
103
104 /* Revisions Help Tab */
105
106 $revisions_overview  = '<p>' . __( 'This screen is used for managing your content revisions.' ) . '</p>';
107 $revisions_overview .= '<p>' . __( 'Revisions are saved copies of your post or page, which are periodically created as you update your content. The red text on the left shows the content that was removed. The green text on the right shows the content that was added.' ) . '</p>';
108 $revisions_overview .= '<p>' . __( 'From this screen you can review, compare, and restore revisions:' ) . '</p>';
109 $revisions_overview .= '<ul><li>' . __( 'To navigate between revisions, <strong>drag the slider handle left or right</strong> or <strong>use the Previous or Next buttons</strong>.' ) . '</li>';
110 $revisions_overview .= '<li>' . __( 'Compare two different revisions by <strong>selecting the &#8220;Compare any two revisions&#8221; box</strong> to the side.' ) . '</li>';
111 $revisions_overview .= '<li>' . __( 'To restore a revision, <strong>click Restore This Revision</strong>.' ) . '</li></ul>';
112
113 get_current_screen()->add_help_tab( array(
114         'id'      => 'revisions-overview',
115         'title'   => __( 'Overview' ),
116         'content' => $revisions_overview
117 ) );
118
119 $revisions_sidebar  = '<p><strong>' . __( 'For more information:' ) . '</strong></p>';
120 $revisions_sidebar .= '<p>' . __( '<a href="https://codex.wordpress.org/Revision_Management">Revisions Management</a>' ) . '</p>';
121 $revisions_sidebar .= '<p>' . __( '<a href="https://wordpress.org/support/">Support Forums</a>' ) . '</p>';
122
123 get_current_screen()->set_help_sidebar( $revisions_sidebar );
124
125 require_once( ABSPATH . 'wp-admin/admin-header.php' );
126
127 ?>
128
129 <div class="wrap">
130         <h1 class="long-header"><?php echo $h1; ?></h1>
131         <?php echo $return_to_post; ?>
132 </div>
133 <?php
134 wp_print_revision_templates();
135
136 require_once( ABSPATH . 'wp-admin/admin-footer.php' );