wp/wp-admin/erase-personal-data.php
changeset 16 a86126ab1dd4
child 18 be944660c56a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/wp/wp-admin/erase-personal-data.php	Tue Dec 15 13:49:49 2020 +0100
@@ -0,0 +1,92 @@
+<?php
+/**
+ * Privacy tools, Erase Personal Data screen.
+ *
+ * @package WordPress
+ * @subpackage Administration
+ */
+
+/** WordPress Administration Bootstrap */
+require_once __DIR__ . '/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 ltr" 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
+require_once ABSPATH . 'wp-admin/admin-footer.php';