1
|
|
|
<?php |
2
|
|
|
/** |
3
|
|
|
* Link Management Administration Screen. |
4
|
|
|
* |
5
|
|
|
* @package WordPress |
6
|
|
|
* @subpackage Administration |
7
|
|
|
*/ |
8
|
|
|
|
9
|
|
|
/** Load WordPress Administration Bootstrap */ |
10
|
|
|
require_once( dirname( __FILE__ ) . '/admin.php' ); |
11
|
|
|
if ( ! current_user_can( 'manage_links' ) ) |
12
|
|
|
wp_die( __( 'Sorry, you are not allowed to edit the links for this site.' ) ); |
13
|
|
|
|
14
|
|
|
$wp_list_table = _get_list_table('WP_Links_List_Table'); |
15
|
|
|
|
16
|
|
|
// Handle bulk deletes |
17
|
|
|
$doaction = $wp_list_table->current_action(); |
18
|
|
|
|
19
|
|
|
if ( $doaction && isset( $_REQUEST['linkcheck'] ) ) { |
20
|
|
|
check_admin_referer( 'bulk-bookmarks' ); |
21
|
|
|
|
22
|
|
|
$redirect_to = admin_url( 'link-manager.php' ); |
23
|
|
|
$bulklinks = (array) $_REQUEST['linkcheck']; |
24
|
|
|
|
25
|
|
|
if ( 'delete' == $doaction ) { |
26
|
|
|
foreach ( $bulklinks as $link_id ) { |
27
|
|
|
$link_id = (int) $link_id; |
28
|
|
|
|
29
|
|
|
wp_delete_link( $link_id ); |
30
|
|
|
} |
31
|
|
|
|
32
|
|
|
$redirect_to = add_query_arg( 'deleted', count( $bulklinks ), $redirect_to ); |
33
|
|
|
} else { |
34
|
|
|
/** This action is documented in wp-admin/edit-comments.php */ |
35
|
|
|
$redirect_to = apply_filters( 'handle_bulk_actions-' . get_current_screen()->id, $redirect_to, $doaction, $bulklinks ); |
36
|
|
|
} |
37
|
|
|
wp_redirect( $redirect_to ); |
38
|
|
|
exit; |
39
|
|
View Code Duplication |
} elseif ( ! empty( $_GET['_wp_http_referer'] ) ) { |
40
|
|
|
wp_redirect( remove_query_arg( array( '_wp_http_referer', '_wpnonce' ), wp_unslash( $_SERVER['REQUEST_URI'] ) ) ); |
|
|
|
|
41
|
|
|
exit; |
42
|
|
|
} |
43
|
|
|
|
44
|
|
|
$wp_list_table->prepare_items(); |
45
|
|
|
|
46
|
|
|
$title = __('Links'); |
47
|
|
|
$this_file = $parent_file = 'link-manager.php'; |
48
|
|
|
|
49
|
|
|
get_current_screen()->add_help_tab( array( |
50
|
|
|
'id' => 'overview', |
51
|
|
|
'title' => __('Overview'), |
52
|
|
|
'content' => |
53
|
|
|
'<p>' . sprintf(__('You can add links here to be displayed on your site, usually using <a href="%s">Widgets</a>. By default, links to several sites in the WordPress community are included as examples.'), 'widgets.php') . '</p>' . |
54
|
|
|
'<p>' . __('Links may be separated into Link Categories; these are different than the categories used on your posts.') . '</p>' . |
55
|
|
|
'<p>' . __('You can customize the display of this screen using the Screen Options tab and/or the dropdown filters above the links table.') . '</p>' |
56
|
|
|
) ); |
57
|
|
|
get_current_screen()->add_help_tab( array( |
58
|
|
|
'id' => 'deleting-links', |
59
|
|
|
'title' => __('Deleting Links'), |
60
|
|
|
'content' => |
61
|
|
|
'<p>' . __('If you delete a link, it will be removed permanently, as Links do not have a Trash function yet.') . '</p>' |
62
|
|
|
) ); |
63
|
|
|
|
64
|
|
|
get_current_screen()->set_help_sidebar( |
65
|
|
|
'<p><strong>' . __('For more information:') . '</strong></p>' . |
66
|
|
|
'<p>' . __('<a href="https://codex.wordpress.org/Links_Screen">Documentation on Managing Links</a>') . '</p>' . |
67
|
|
|
'<p>' . __('<a href="https://wordpress.org/support/">Support Forums</a>') . '</p>' |
68
|
|
|
); |
69
|
|
|
|
70
|
|
|
get_current_screen()->set_screen_reader_content( array( |
71
|
|
|
'heading_list' => __( 'Links list' ), |
72
|
|
|
) ); |
73
|
|
|
|
74
|
|
|
include_once( ABSPATH . 'wp-admin/admin-header.php' ); |
75
|
|
|
|
76
|
|
|
if ( ! current_user_can('manage_links') ) |
77
|
|
|
wp_die(__('Sorry, you are not allowed to edit the links for this site.')); |
78
|
|
|
|
79
|
|
|
?> |
80
|
|
|
|
81
|
|
|
<div class="wrap nosubsub"> |
82
|
|
|
<h1 class="wp-heading-inline"><?php |
83
|
|
|
echo esc_html( $title ); |
84
|
|
|
?></h1> |
85
|
|
|
|
86
|
|
|
<a href="link-add.php" class="page-title-action"><?php echo esc_html_x( 'Add New', 'link' ); ?></a> |
87
|
|
|
|
88
|
|
|
<?php |
89
|
|
View Code Duplication |
if ( isset( $_REQUEST['s'] ) && strlen( $_REQUEST['s'] ) ) { |
90
|
|
|
/* translators: %s: search keywords */ |
91
|
|
|
printf( '<span class="subtitle">' . __( 'Search results for “%s”' ) . '</span>', esc_html( wp_unslash( $_REQUEST['s'] ) ) ); |
|
|
|
|
92
|
|
|
} |
93
|
|
|
?> |
94
|
|
|
|
95
|
|
|
<hr class="wp-header-end"> |
96
|
|
|
|
97
|
|
|
<?php |
98
|
|
|
if ( isset($_REQUEST['deleted']) ) { |
99
|
|
|
echo '<div id="message" class="updated notice is-dismissible"><p>'; |
100
|
|
|
$deleted = (int) $_REQUEST['deleted']; |
101
|
|
|
printf(_n('%s link deleted.', '%s links deleted', $deleted), $deleted); |
102
|
|
|
echo '</p></div>'; |
103
|
|
|
$_SERVER['REQUEST_URI'] = remove_query_arg(array('deleted'), $_SERVER['REQUEST_URI']); |
104
|
|
|
} |
105
|
|
|
?> |
106
|
|
|
|
107
|
|
|
<form id="posts-filter" method="get"> |
108
|
|
|
|
109
|
|
|
<?php $wp_list_table->search_box( __( 'Search Links' ), 'link' ); ?> |
110
|
|
|
|
111
|
|
|
<?php $wp_list_table->display(); ?> |
112
|
|
|
|
113
|
|
|
<div id="ajax-response"></div> |
114
|
|
|
</form> |
115
|
|
|
|
116
|
|
|
</div> |
117
|
|
|
|
118
|
|
|
<?php |
119
|
|
|
include( ABSPATH . 'wp-admin/admin-footer.php' ); |
120
|
|
|
|
This check looks at variables that are passed out again to other methods.
If the outgoing method call has stricter type requirements than the method itself, an issue is raised.
An additional type check may prevent trouble.