This project does not seem to handle request data directly as such no vulnerable execution paths were found.
include
, or for example
via PHP's auto-loading mechanism.
These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
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 | View Code Duplication | if ( ! wp_revisions_enabled( $post ) && ! wp_is_post_autosave( $revision ) ) { |
|
0 ignored issues
–
show
It seems like
$revision defined by wp_get_post_revision($revision_id) on line 34 can also be of type array ; however, wp_is_post_autosave() does only seem to accept integer|object<WP_Post> , maybe add an additional type check?
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check: /**
* @return array|string
*/
function returnsDifferentValues($x) {
if ($x) {
return 'foo';
}
return array();
}
$x = returnsDifferentValues($y);
if (is_array($x)) {
// $x is an array.
}
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue. ![]() |
|||
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 | View Code Duplication | if ( ! wp_revisions_enabled( $post ) && ! wp_is_post_autosave( $revision ) ) { |
|
0 ignored issues
–
show
It seems like
$post defined by get_post($revision->post_parent) on line 63 can also be of type array ; however, wp_revisions_enabled() does only seem to accept object<WP_Post> , maybe add an additional type check?
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check: /**
* @return array|string
*/
function returnsDifferentValues($x) {
if ($x) {
return 'foo';
}
return array();
}
$x = returnsDifferentValues($y);
if (is_array($x)) {
// $x is an array.
}
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue. ![]() It seems like
$revision defined by wp_get_post_revision($revision_id) on line 61 can also be of type array ; however, wp_is_post_autosave() does only seem to accept integer|object<WP_Post> , maybe add an additional type check?
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check: /**
* @return array|string
*/
function returnsDifferentValues($x) {
if ($x) {
return 'foo';
}
return array();
}
$x = returnsDifferentValues($y);
if (is_array($x)) {
// $x is an array.
}
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue. ![]() |
|||
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 | $h1 = sprintf( __( 'Compare Revisions of “%1$s”' ), $post_title ); |
||
78 | $return_to_post = '<a href="' . $post_edit_link . '">' . __( '← Return to editor' ) . '</a>'; |
||
79 | $title = __( 'Revisions' ); |
||
80 | |||
81 | $redirect = false; |
||
82 | break; |
||
83 | } |
||
84 | |||
85 | // Empty post_type means either malformed object found, or no valid parent was found. |
||
86 | if ( ! $redirect && empty( $post->post_type ) ) |
||
87 | $redirect = 'edit.php'; |
||
88 | |||
89 | if ( ! empty( $redirect ) ) { |
||
90 | wp_redirect( $redirect ); |
||
91 | exit; |
||
92 | } |
||
93 | |||
94 | // This is so that the correct "Edit" menu item is selected. |
||
95 | if ( ! empty( $post->post_type ) && 'post' != $post->post_type ) |
||
96 | $parent_file = $submenu_file = 'edit.php?post_type=' . $post->post_type; |
||
97 | else |
||
98 | $parent_file = $submenu_file = 'edit.php'; |
||
99 | |||
100 | wp_enqueue_script( 'revisions' ); |
||
101 | wp_localize_script( 'revisions', '_wpRevisionsSettings', wp_prepare_revisions_for_js( $post, $revision_id, $from ) ); |
||
0 ignored issues
–
show
It seems like
$post can also be of type array ; however, wp_prepare_revisions_for_js() does only seem to accept object|integer , maybe add an additional type check?
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check: /**
* @return array|string
*/
function returnsDifferentValues($x) {
if ($x) {
return 'foo';
}
return array();
}
$x = returnsDifferentValues($y);
if (is_array($x)) {
// $x is an array.
}
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue. ![]() It seems like
$revision_id can also be of type object<WP_Post> ; however, wp_prepare_revisions_for_js() does only seem to accept integer , maybe add an additional type check?
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check: /**
* @return array|string
*/
function returnsDifferentValues($x) {
if ($x) {
return 'foo';
}
return array();
}
$x = returnsDifferentValues($y);
if (is_array($x)) {
// $x is an array.
}
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue. ![]() |
|||
102 | |||
103 | /* Revisions Help Tab */ |
||
104 | |||
105 | $revisions_overview = '<p>' . __( 'This screen is used for managing your content revisions.' ) . '</p>'; |
||
106 | $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>'; |
||
107 | $revisions_overview .= '<p>' . __( 'From this screen you can review, compare, and restore revisions:' ) . '</p>'; |
||
108 | $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>'; |
||
109 | $revisions_overview .= '<li>' . __( 'Compare two different revisions by <strong>selecting the “Compare any two revisions” box</strong> to the side.' ) . '</li>'; |
||
110 | $revisions_overview .= '<li>' . __( 'To restore a revision, <strong>click Restore This Revision</strong>.' ) . '</li></ul>'; |
||
111 | |||
112 | get_current_screen()->add_help_tab( array( |
||
113 | 'id' => 'revisions-overview', |
||
114 | 'title' => __( 'Overview' ), |
||
115 | 'content' => $revisions_overview |
||
116 | ) ); |
||
117 | |||
118 | $revisions_sidebar = '<p><strong>' . __( 'For more information:' ) . '</strong></p>'; |
||
119 | $revisions_sidebar .= '<p>' . __( '<a href="https://codex.wordpress.org/Revision_Management" target="_blank">Revisions Management</a>' ) . '</p>'; |
||
120 | $revisions_sidebar .= '<p>' . __( '<a href="https://wordpress.org/support/" target="_blank">Support Forums</a>' ) . '</p>'; |
||
121 | |||
122 | get_current_screen()->set_help_sidebar( $revisions_sidebar ); |
||
123 | |||
124 | require_once( ABSPATH . 'wp-admin/admin-header.php' ); |
||
125 | |||
126 | ?> |
||
127 | |||
128 | <div class="wrap"> |
||
129 | <h1 class="long-header"><?php echo $h1; ?></h1> |
||
130 | <?php echo $return_to_post; ?> |
||
131 | </div> |
||
132 | <?php |
||
133 | wp_print_revision_templates(); |
||
134 | |||
135 | require_once( ABSPATH . 'wp-admin/admin-footer.php' ); |
||
136 |
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check:
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue.