<?php /** * Comment Management Screen * * @package WordPress * @subpackage Administration */ /** Load WordPress Bootstrap */ require_once __DIR__ . '/admin.php'; $parent_file = 'edit-comments.php'; $submenu_file = 'edit-comments.php'; /** * @global string $action */ global $action; $action = ! empty( $_REQUEST['action'] ) ? sanitize_text_field( $_REQUEST['action'] ) : ''; if ( isset( $_POST['deletecomment'] ) ) { $action = 'deletecomment'; } if ( 'cdc' === $action ) { $action = 'delete'; } elseif ( 'mac' === $action ) { $action = 'approve'; } if ( isset( $_GET['dt'] ) ) { if ( 'spam' === $_GET['dt'] ) { $action = 'spam'; } elseif ( 'trash' === $_GET['dt'] ) { $action = 'trash'; } } if ( isset( $_REQUEST['c'] ) ) { $comment_id = absint( $_REQUEST['c'] ); $comment = get_comment( $comment_id ); // Prevent actions on a comment associated with a trashed post. if ( $comment && 'trash' === get_post_status( $comment->comment_post_ID ) ) { wp_die( __( 'You cannot edit this comment because the associated post is in the Trash. Please restore the post first, then try again.' ) ); } } else { $comment = null; } switch ( $action ) { case 'editcomment': // Used in the HTML title tag. $title = __( 'Edit Comment' ); get_current_screen()->add_help_tab( array( 'id' => 'overview', 'title' => __( 'Overview' ), 'content' => '<p>' . __( 'You can edit the information left in a comment if needed. This is often useful when you notice that a commenter has made a typographical error.' ) . '</p>' . '<p>' . __( 'You can also moderate the comment from this screen using the Status box, where you can also change the timestamp of the comment.' ) . '</p>', ) ); get_current_screen()->set_help_sidebar( '<p><strong>' . __( 'For more information:' ) . '</strong></p>' . '<p>' . __( '<a href="https://wordpress.org/documentation/article/comments-screen/">Documentation on Comments</a>' ) . '</p>' . '<p>' . __( '<a href="https://wordpress.org/support/forums/">Support forums</a>' ) . '</p>' ); wp_enqueue_script( 'comment' ); require_once ABSPATH . 'wp-admin/admin-header.php'; if ( ! $comment ) { comment_footer_die( __( 'Invalid comment ID.' ) . sprintf( ' <a href="%s">' . __( 'Go back' ) . '</a>.', 'javascript:history.go(-1)' ) ); } if ( ! current_user_can( 'edit_comment', $comment_id ) ) { comment_footer_die( __( 'Sorry, you are not allowed to edit this comment.' ) ); } if ( 'trash' === $comment->comment_approved ) { comment_footer_die( __( 'This comment is in the Trash. Please move it out of the Trash if you want to edit it.' ) ); } $comment = get_comment_to_edit( $comment_id ); require ABSPATH . 'wp-admin/edit-form-comment.php'; break; case 'delete': case 'approve': case 'trash': case 'spam': // Used in the HTML title tag. $title = __( 'Moderate Comment' ); if ( ! $comment ) { wp_redirect( admin_url( 'edit-comments.php?error=1' ) ); die(); } if ( ! current_user_can( 'edit_comment', $comment->comment_ID ) ) { wp_redirect( admin_url( 'edit-comments.php?error=2' ) ); die(); } // No need to re-approve/re-trash/re-spam a comment. if ( str_replace( '1', 'approve', $comment->comment_approved ) === $action ) { wp_redirect( admin_url( 'edit-comments.php?same=' . $comment_id ) ); die(); } require_once ABSPATH . 'wp-admin/admin-header.php'; $formaction = $action . 'comment'; $nonce_action = ( 'approve' === $action ) ? 'approve-comment_' : 'delete-comment_'; $nonce_action .= $comment_id; ?> <div class="wrap"> <h1><?php echo esc_html( $title ); ?></h1> <?php switch ( $action ) { case 'spam': $caution_msg = __( 'You are about to mark the following comment as spam:' ); $button = _x( 'Mark as spam', 'comment' ); break; case 'trash': $caution_msg = __( 'You are about to move the following comment to the Trash:' ); $button = __( 'Move to Trash' ); break; case 'delete': $caution_msg = __( 'You are about to delete the following comment:' ); $button = __( 'Permanently delete comment' ); break; default: $caution_msg = __( 'You are about to approve the following comment:' ); $button = __( 'Approve comment' ); break; } if ( '0' !== $comment->comment_approved ) { // If not unapproved. $message = ''; switch ( $comment->comment_approved ) { case '1': $message = __( 'This comment is currently approved.' ); break; case 'spam': $message = __( 'This comment is currently marked as spam.' ); break; case 'trash': $message = __( 'This comment is currently in the Trash.' ); break; } if ( $message ) { wp_admin_notice( $message, array( 'type' => 'info', 'id' => 'message', ) ); } } wp_admin_notice( '<strong>' . __( 'Caution:' ) . '</strong> ' . $caution_msg, array( 'type' => 'warning', 'id' => 'message', ) ); ?> <table class="form-table comment-ays"> <tr> <th scope="row"><?php _e( 'Author' ); ?></th> <td><?php comment_author( $comment ); ?></td> </tr> <?php if ( get_comment_author_email( $comment ) ) { ?> <tr> <th scope="row"><?php _e( 'Email' ); ?></th> <td><?php comment_author_email( $comment ); ?></td> </tr> <?php } ?> <?php if ( get_comment_author_url( $comment ) ) { ?> <tr> <th scope="row"><?php _e( 'URL' ); ?></th> <td><a href="<?php comment_author_url( $comment ); ?>"><?php comment_author_url( $comment ); ?></a></td> </tr> <?php } ?> <tr> <th scope="row"><?php /* translators: Column name or table row header. */ _e( 'In response to' ); ?></th> <td> <?php $post_id = $comment->comment_post_ID; if ( current_user_can( 'edit_post', $post_id ) ) { $post_link = "<a href='" . esc_url( get_edit_post_link( $post_id ) ) . "'>"; $post_link .= esc_html( get_the_title( $post_id ) ) . '</a>'; } else { $post_link = esc_html( get_the_title( $post_id ) ); } echo $post_link; if ( $comment->comment_parent ) { $parent = get_comment( $comment->comment_parent ); $parent_link = esc_url( get_comment_link( $parent ) ); $name = get_comment_author( $parent ); printf( /* translators: %s: Comment link. */ ' | ' . __( 'In reply to %s.' ), '<a href="' . $parent_link . '">' . $name . '</a>' ); } ?> </td> </tr> <tr> <th scope="row"><?php _e( 'Submitted on' ); ?></th> <td> <?php $submitted = sprintf( /* translators: 1: Comment date, 2: Comment time. */ __( '%1$s at %2$s' ), /* translators: Comment date format. See https://www.php.net/manual/datetime.format.php */ get_comment_date( __( 'Y/m/d' ), $comment ), /* translators: Comment time format. See https://www.php.net/manual/datetime.format.php */ get_comment_date( __( 'g:i a' ), $comment ) ); if ( 'approved' === wp_get_comment_status( $comment ) && ! empty( $comment->comment_post_ID ) ) { echo '<a href="' . esc_url( get_comment_link( $comment ) ) . '">' . $submitted . '</a>'; } else { echo $submitted; } ?> </td> </tr> <tr> <th scope="row"><?php /* translators: Field name in comment form. */ _ex( 'Comment', 'noun' ); ?></th> <td class="comment-content"> <?php comment_text( $comment ); ?> <p class="edit-comment"> <a href="<?php echo esc_url( admin_url( "comment.php?action=editcomment&c={$comment->comment_ID}" ) ); ?>"><?php esc_html_e( 'Edit' ); ?></a> </p> </td> </tr> </table> <form action="comment.php" method="get" class="comment-ays-submit"> <p> <?php submit_button( $button, 'primary', 'submit', false ); ?> <a href="<?php echo esc_url( admin_url( 'edit-comments.php' ) ); ?>" class="button-cancel"><?php esc_html_e( 'Cancel' ); ?></a> </p> <?php wp_nonce_field( $nonce_action ); ?> <input type="hidden" name="action" value="<?php echo esc_attr( $formaction ); ?>" /> <input type="hidden" name="c" value="<?php echo esc_attr( $comment->comment_ID ); ?>" /> <input type="hidden" name="noredir" value="1" /> </form> </div> <?php break; case 'deletecomment': case 'trashcomment': case 'untrashcomment': case 'spamcomment': case 'unspamcomment': case 'approvecomment': case 'unapprovecomment': $comment_id = absint( $_REQUEST['c'] ); if ( in_array( $action, array( 'approvecomment', 'unapprovecomment' ), true ) ) { check_admin_referer( 'approve-comment_' . $comment_id ); } else { check_admin_referer( 'delete-comment_' . $comment_id ); } $noredir = isset( $_REQUEST['noredir'] ); $comment = get_comment( $comment_id ); if ( ! $comment ) { comment_footer_die( __( 'Invalid comment ID.' ) . sprintf( ' <a href="%s">' . __( 'Go back' ) . '</a>.', 'edit-comments.php' ) ); } if ( ! current_user_can( 'edit_comment', $comment->comment_ID ) ) { comment_footer_die( __( 'Sorry, you are not allowed to edit comments on this post.' ) ); } if ( wp_get_referer() && ! $noredir && ! str_contains( wp_get_referer(), 'comment.php' ) ) { $redir = wp_get_referer(); } elseif ( wp_get_original_referer() && ! $noredir ) { $redir = wp_get_original_referer(); } elseif ( in_array( $action, array( 'approvecomment', 'unapprovecomment' ), true ) ) { $redir = admin_url( 'edit-comments.php?p=' . absint( $comment->comment_post_ID ) ); } else { $redir = admin_url( 'edit-comments.php' ); } $redir = remove_query_arg( array( 'spammed', 'unspammed', 'trashed', 'untrashed', 'deleted', 'ids', 'approved', 'unapproved' ), $redir ); switch ( $action ) { case 'deletecomment': wp_delete_comment( $comment ); $redir = add_query_arg( array( 'deleted' => '1' ), $redir ); break; case 'trashcomment': wp_trash_comment( $comment ); $redir = add_query_arg( array( 'trashed' => '1', 'ids' => $comment_id, ), $redir ); break; case 'untrashcomment': wp_untrash_comment( $comment ); $redir = add_query_arg( array( 'untrashed' => '1' ), $redir ); break; case 'spamcomment': wp_spam_comment( $comment ); $redir = add_query_arg( array( 'spammed' => '1', 'ids' => $comment_id, ), $redir ); break; case 'unspamcomment': wp_unspam_comment( $comment ); $redir = add_query_arg( array( 'unspammed' => '1' ), $redir ); break; case 'approvecomment': wp_set_comment_status( $comment, 'approve' ); $redir = add_query_arg( array( 'approved' => 1 ), $redir ); break; case 'unapprovecomment': wp_set_comment_status( $comment, 'hold' ); $redir = add_query_arg( array( 'unapproved' => 1 ), $redir ); break; } wp_redirect( $redir ); die; case 'editedcomment': $comment_id = absint( $_POST['comment_ID'] ); $comment_post_id = absint( $_POST['comment_post_ID'] ); check_admin_referer( 'update-comment_' . $comment_id ); $updated = edit_comment(); if ( is_wp_error( $updated ) ) { wp_die( $updated->get_error_message() ); } $location = ( empty( $_POST['referredby'] ) ? "edit-comments.php?p=$comment_post_id" : $_POST['referredby'] ) . '#comment-' . $comment_id; /** * Filters the URI the user is redirected to after editing a comment in the admin. * * @since 2.1.0 * * @param string $location The URI the user will be redirected to. * @param int $comment_id The ID of the comment being edited. */ $location = apply_filters( 'comment_edit_redirect', $location, $comment_id ); wp_redirect( $location ); exit; default: wp_die( __( 'Unknown action.' ) ); } // End switch. require_once ABSPATH . 'wp-admin/admin-footer.php';
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
css | Folder | 0755 |
|
|
images | Folder | 0755 |
|
|
includes | Folder | 0755 |
|
|
js | Folder | 0755 |
|
|
maint | Folder | 0755 |
|
|
network | Folder | 0755 |
|
|
user | Folder | 0755 |
|
|
about.php | File | 15.95 KB | 0644 |
|
admin-ajax.php | File | 5.03 KB | 0644 |
|
admin-footer.php | File | 2.77 KB | 0644 |
|
admin-functions.php | File | 406 B | 0644 |
|
admin-header.php | File | 8.86 KB | 0644 |
|
admin-post.php | File | 2.02 KB | 0644 |
|
admin.php | File | 12.27 KB | 0644 |
|
async-upload.php | File | 4.71 KB | 0644 |
|
authorize-application.php | File | 10.09 KB | 0644 |
|
comment.php | File | 11.35 KB | 0644 |
|
contribute.php | File | 5.59 KB | 0644 |
|
credits.php | File | 3.75 KB | 0644 |
|
custom-background.php | File | 416 B | 0644 |
|
custom-header.php | File | 426 B | 0644 |
|
customize.php | File | 10.87 KB | 0644 |
|
edit-comments.php | File | 14.38 KB | 0644 |
|
edit-form-advanced.php | File | 28.86 KB | 0644 |
|
edit-form-blocks.php | File | 12.96 KB | 0644 |
|
edit-form-comment.php | File | 8.34 KB | 0644 |
|
edit-link-form.php | File | 6.21 KB | 0644 |
|
edit-link-user.php | File | 452.92 KB | 0644 |
|
edit-tag-form.php | File | 10.44 KB | 0644 |
|
edit-tags.php | File | 21.92 KB | 0644 |
|
edit.php | File | 19.48 KB | 0644 |
|
erase-personal-data.php | File | 7.33 KB | 0644 |
|
error_log | File | 867.51 KB | 0644 |
|
export-personal-data.php | File | 7.75 KB | 0644 |
|
export.php | File | 11.02 KB | 0644 |
|
freedoms.php | File | 4.5 KB | 0644 |
|
import.php | File | 7.48 KB | 0644 |
|
index.php | File | 7.68 KB | 0644 |
|
install-helper.php | File | 6.8 KB | 0644 |
|
install.php | File | 17.1 KB | 0644 |
|
link-add.php | File | 938 B | 0644 |
|
link-manager.php | File | 4.26 KB | 0644 |
|
link-parse-opml.php | File | 2.63 KB | 0644 |
|
link.php | File | 2.89 KB | 0644 |
|
load-scripts.php | File | 2.02 KB | 0644 |
|
load-styles.php | File | 2.92 KB | 0644 |
|
media-new.php | File | 3.18 KB | 0644 |
|
media-upload.php | File | 3.49 KB | 0644 |
|
media.php | File | 819 B | 0644 |
|
menu-footer.php | File | 452.92 KB | 0644 |
|
menu-header.php | File | 9.83 KB | 0644 |
|
menu.php | File | 16.67 KB | 0644 |
|
moderation.php | File | 307 B | 0644 |
|
ms-admin.php | File | 196 B | 0644 |
|
ms-delete-site.php | File | 4.19 KB | 0644 |
|
ms-edit.php | File | 216 B | 0644 |
|
ms-options.php | File | 229 B | 0644 |
|
ms-sites.php | File | 215 B | 0644 |
|
ms-themes.php | File | 217 B | 0644 |
|
ms-upgrade-network.php | File | 219 B | 0644 |
|
ms-users.php | File | 215 B | 0644 |
|
my-sites.php | File | 4.74 KB | 0644 |
|
nav-menus.php | File | 48.12 KB | 0644 |
|
network.php | File | 5.39 KB | 0644 |
|
options-discussion.php | File | 15.4 KB | 0644 |
|
options-general.php | File | 21.51 KB | 0644 |
|
options-head.php | File | 548 B | 0644 |
|
options-media.php | File | 6.35 KB | 0644 |
|
options-permalink.php | File | 21.21 KB | 0644 |
|
options-privacy.php | File | 9.95 KB | 0644 |
|
options-reading.php | File | 10.03 KB | 0644 |
|
options-writing.php | File | 9.1 KB | 0644 |
|
options.php | File | 13.45 KB | 0644 |
|
plugin-editor.php | File | 13.42 KB | 0644 |
|
plugin-install.php | File | 6.96 KB | 0644 |
|
plugins.php | File | 30.01 KB | 0644 |
|
post-new.php | File | 2.7 KB | 0644 |
|
post.php | File | 9.97 KB | 0644 |
|
press-this.php | File | 2.34 KB | 0644 |
|
privacy-policy-guide.php | File | 3.67 KB | 0644 |
|
privacy.php | File | 2.48 KB | 0644 |
|
profile.php | File | 283 B | 0644 |
|
revision.php | File | 5.71 KB | 0644 |
|
setup-config.php | File | 17.48 KB | 0644 |
|
site-editor.php | File | 7.05 KB | 0644 |
|
site-health-info.php | File | 3.99 KB | 0644 |
|
site-health.php | File | 10.2 KB | 0644 |
|
term.php | File | 2.2 KB | 0644 |
|
theme-editor.php | File | 15.42 KB | 0644 |
|
theme-install.php | File | 23.37 KB | 0644 |
|
themes.php | File | 46.95 KB | 0644 |
|
tools.php | File | 3.43 KB | 0644 |
|
update-core.php | File | 45.43 KB | 0644 |
|
update.php | File | 12.79 KB | 0644 |
|
upgrade-functions.php | File | 341 B | 0644 |
|
upgrade.php | File | 5.57 KB | 0644 |
|
upload.php | File | 14.85 KB | 0644 |
|
user-edit.php | File | 39.6 KB | 0644 |
|
user-new.php | File | 23.97 KB | 0644 |
|
user.php | File | 452.92 KB | 0644 |
|
users.php | File | 23.29 KB | 0644 |
|
widgets-form-blocks.php | File | 4.97 KB | 0644 |
|
widgets-form.php | File | 19.17 KB | 0644 |
|
widgets.php | File | 1.09 KB | 0644 |
|