diff options
Diffstat (limited to 'srcs/wordpress/wp-admin/erase-personal-data.php')
| -rw-r--r-- | srcs/wordpress/wp-admin/erase-personal-data.php | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/srcs/wordpress/wp-admin/erase-personal-data.php b/srcs/wordpress/wp-admin/erase-personal-data.php new file mode 100644 index 0000000..dc80022 --- /dev/null +++ b/srcs/wordpress/wp-admin/erase-personal-data.php @@ -0,0 +1,92 @@ +<?php +/** + * Privacy tools, Erase Personal Data screen. + * + * @package WordPress + * @subpackage Administration + */ + +/** WordPress Administration Bootstrap */ +require_once( dirname( __FILE__ ) . '/admin.php' ); + +if ( ! current_user_can( 'erase_others_personal_data' ) || ! current_user_can( 'delete_users' ) ) { + wp_die( __( 'Sorry, you are not allowed to erase data on this site.' ) ); +} + +// Handle list table actions. +_wp_personal_data_handle_actions(); + +// Cleans up failed and expired requests before displaying the list table. +_wp_personal_data_cleanup_requests(); + +wp_enqueue_script( 'privacy-tools' ); + +add_screen_option( + 'per_page', + array( + 'default' => 20, + 'option' => 'remove_personal_data_requests_per_page', + ) +); + +$_list_table_args = array( + 'plural' => 'privacy_requests', + 'singular' => 'privacy_request', +); + +$requests_table = _get_list_table( 'WP_Privacy_Data_Removal_Requests_List_Table', $_list_table_args ); + +$requests_table->screen->set_screen_reader_content( + array( + 'heading_views' => __( 'Filter erase personal data list' ), + 'heading_pagination' => __( 'Erase personal data list navigation' ), + 'heading_list' => __( 'Erase personal data list' ), + ) +); + +$requests_table->process_bulk_action(); +$requests_table->prepare_items(); + +require_once( ABSPATH . 'wp-admin/admin-header.php' ); +?> + +<div class="wrap nosubsub"> + <h1><?php esc_html_e( 'Erase Personal Data' ); ?></h1> + <hr class="wp-header-end" /> + + <?php settings_errors(); ?> + + <form action="<?php echo esc_url( admin_url( 'erase-personal-data.php' ) ); ?>" method="post" class="wp-privacy-request-form"> + <h2><?php esc_html_e( 'Add Data Erasure Request' ); ?></h2> + <p><?php esc_html_e( 'An email will be sent to the user at this email address asking them to verify the request.' ); ?></p> + + <div class="wp-privacy-request-form-field"> + <label for="username_or_email_for_privacy_request"><?php esc_html_e( 'Username or email address' ); ?></label> + <input type="text" required class="regular-text" id="username_or_email_for_privacy_request" name="username_or_email_for_privacy_request" /> + <?php submit_button( __( 'Send Request' ), 'secondary', 'submit', false ); ?> + </div> + <?php wp_nonce_field( 'personal-data-request' ); ?> + <input type="hidden" name="action" value="add_remove_personal_data_request" /> + <input type="hidden" name="type_of_action" value="remove_personal_data" /> + </form> + <hr /> + + <?php $requests_table->views(); ?> + + <form class="search-form wp-clearfix"> + <?php $requests_table->search_box( __( 'Search Requests' ), 'requests' ); ?> + <input type="hidden" name="filter-status" value="<?php echo isset( $_REQUEST['filter-status'] ) ? esc_attr( sanitize_text_field( $_REQUEST['filter-status'] ) ) : ''; ?>" /> + <input type="hidden" name="orderby" value="<?php echo isset( $_REQUEST['orderby'] ) ? esc_attr( sanitize_text_field( $_REQUEST['orderby'] ) ) : ''; ?>" /> + <input type="hidden" name="order" value="<?php echo isset( $_REQUEST['order'] ) ? esc_attr( sanitize_text_field( $_REQUEST['order'] ) ) : ''; ?>" /> + </form> + + <form method="post"> + <?php + $requests_table->display(); + $requests_table->embed_scripts(); + ?> + </form> +</div> + +<?php +include( ABSPATH . 'wp-admin/admin-footer.php' ); |
