Comments: Revert the introduction of the opt-in comment approval notification feature.
This reverts the following commits: [50113], [50112], [50109]. See #33717 Built from https://develop.svn.wordpress.org/trunk@50375 git-svn-id: http://core.svn.wordpress.org/trunk@49986 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
dcbe3cb7b8
commit
dd53775247
|
@ -22,24 +22,8 @@ require __DIR__ . '/wp-load.php';
|
||||||
|
|
||||||
nocache_headers();
|
nocache_headers();
|
||||||
|
|
||||||
if ( isset( $_POST['wp-comment-approved-notification-optin'], $_POST['comment_ID'], $_POST['moderation-hash'] ) ) {
|
$comment = wp_handle_comment_submission( wp_unslash( $_POST ) );
|
||||||
$comment = get_comment( $_POST['comment_ID'] );
|
if ( is_wp_error( $comment ) ) {
|
||||||
|
|
||||||
if ( $comment && hash_equals( $_POST['moderation-hash'], wp_hash( $comment->comment_date_gmt ) ) ) {
|
|
||||||
update_comment_meta( $comment->comment_ID, '_wp_comment_author_notification_optin', true );
|
|
||||||
} else {
|
|
||||||
wp_die(
|
|
||||||
'<p>' . __( 'Invalid comment ID.' ) . '</p>',
|
|
||||||
__( 'Comment Notification Opt-in Failure' ),
|
|
||||||
array(
|
|
||||||
'response' => 404,
|
|
||||||
'back_link' => true,
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$comment = wp_handle_comment_submission( wp_unslash( $_POST ) );
|
|
||||||
if ( is_wp_error( $comment ) ) {
|
|
||||||
$data = (int) $comment->get_error_data();
|
$data = (int) $comment->get_error_data();
|
||||||
if ( ! empty( $data ) ) {
|
if ( ! empty( $data ) ) {
|
||||||
wp_die(
|
wp_die(
|
||||||
|
@ -53,12 +37,12 @@ if ( isset( $_POST['wp-comment-approved-notification-optin'], $_POST['comment_ID
|
||||||
} else {
|
} else {
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$user = wp_get_current_user();
|
$user = wp_get_current_user();
|
||||||
$cookies_consent = ( isset( $_POST['wp-comment-cookies-consent'] ) );
|
$cookies_consent = ( isset( $_POST['wp-comment-cookies-consent'] ) );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Perform other actions when comment cookies are set.
|
* Perform other actions when comment cookies are set.
|
||||||
*
|
*
|
||||||
* @since 3.4.0
|
* @since 3.4.0
|
||||||
|
@ -68,8 +52,7 @@ if ( isset( $_POST['wp-comment-approved-notification-optin'], $_POST['comment_ID
|
||||||
* @param WP_User $user Comment author's user object. The user may not exist.
|
* @param WP_User $user Comment author's user object. The user may not exist.
|
||||||
* @param bool $cookies_consent Comment author's consent to store cookies.
|
* @param bool $cookies_consent Comment author's consent to store cookies.
|
||||||
*/
|
*/
|
||||||
do_action( 'set_comment_cookies', $comment, $user, $cookies_consent );
|
do_action( 'set_comment_cookies', $comment, $user, $cookies_consent );
|
||||||
}
|
|
||||||
|
|
||||||
$location = empty( $_POST['redirect_to'] ) ? get_comment_link( $comment ) : $_POST['redirect_to'] . '#comment-' . $comment->comment_ID;
|
$location = empty( $_POST['redirect_to'] ) ? get_comment_link( $comment ) : $_POST['redirect_to'] . '#comment-' . $comment->comment_ID;
|
||||||
|
|
||||||
|
|
|
@ -40,16 +40,6 @@ class Walker_Comment extends Walker {
|
||||||
'id' => 'comment_ID',
|
'id' => 'comment_ID',
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
|
||||||
* Whether the comment approval notification opt-in form or message needs to be
|
|
||||||
* output automatically.
|
|
||||||
*
|
|
||||||
* @since 5.7.0
|
|
||||||
*
|
|
||||||
* @var bool
|
|
||||||
*/
|
|
||||||
protected $needs_comment_approval_notification_output = true;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts the list before the elements are added.
|
* Starts the list before the elements are added.
|
||||||
*
|
*
|
||||||
|
@ -265,13 +255,10 @@ class Walker_Comment extends Walker {
|
||||||
/**
|
/**
|
||||||
* Filters the comment text.
|
* Filters the comment text.
|
||||||
*
|
*
|
||||||
* - Removes links from the pending comment's text if the commenter did not consent
|
* Removes links from the pending comment's text if the commenter did not consent
|
||||||
* to the comment cookies
|
* to the comment cookies.
|
||||||
* - Prepends the approval notification opt-in form or message to pending comments
|
|
||||||
*
|
*
|
||||||
* @since 5.4.2
|
* @since 5.4.2
|
||||||
* @since 5.7.0 Comment approval notification opt-in form is now automatically
|
|
||||||
* appended if necessary.
|
|
||||||
*
|
*
|
||||||
* @param string $comment_text Text of the current comment.
|
* @param string $comment_text Text of the current comment.
|
||||||
* @param WP_Comment|null $comment The comment object. Null if not found.
|
* @param WP_Comment|null $comment The comment object. Null if not found.
|
||||||
|
@ -285,90 +272,9 @@ class Walker_Comment extends Walker {
|
||||||
$comment_text = wp_kses( $comment_text, array() );
|
$comment_text = wp_kses( $comment_text, array() );
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Checks if we need to output the comment approval notification opt-in form.
|
|
||||||
*/
|
|
||||||
if ( $this->needs_comment_approval_notification_output ) {
|
|
||||||
$comment_text = $this->comment_approval_notification_form( $comment ) . "\n" . $comment_text;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->needs_comment_approval_notification_output = true;
|
|
||||||
|
|
||||||
return $comment_text;
|
return $comment_text;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Outputs the awaiting moderation text.
|
|
||||||
*
|
|
||||||
* @since 5.7.0
|
|
||||||
*
|
|
||||||
* @param WP_Comment $comment Comment to display.
|
|
||||||
*/
|
|
||||||
protected function awaiting_moderation_text( $comment ) {
|
|
||||||
if ( '0' !== $comment->comment_approved ) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$commenter = wp_get_current_commenter();
|
|
||||||
|
|
||||||
if ( $commenter['comment_author_email'] ) {
|
|
||||||
$moderation_note = __( 'Your comment is awaiting moderation.' );
|
|
||||||
} else {
|
|
||||||
$moderation_note = __( 'Your comment is awaiting moderation. This is a preview, your comment will be visible after it has been approved.' );
|
|
||||||
}
|
|
||||||
|
|
||||||
printf(
|
|
||||||
'<em class="comment-awaiting-moderation">%s</em>',
|
|
||||||
esc_html( $moderation_note )
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the comment approval notification opt-in form or message for a pending comment.
|
|
||||||
*
|
|
||||||
* @since 5.7.0
|
|
||||||
*
|
|
||||||
* @param WP_Comment $comment Comment to display.
|
|
||||||
* @return string HTML output.
|
|
||||||
*/
|
|
||||||
protected function comment_approval_notification_form( $comment ) {
|
|
||||||
$comment_approval_output = '';
|
|
||||||
|
|
||||||
if ( '0' === $comment->comment_approved && has_action( 'comment_unapproved_to_approved', 'wp_new_comment_notify_comment_author' ) ) {
|
|
||||||
if ( get_comment_meta( $comment->comment_ID, '_wp_comment_author_notification_optin', true ) ) {
|
|
||||||
$comment_approval_output = sprintf(
|
|
||||||
'<p><em class="wp-comment-approved-notification-optedin">%s</em></p>',
|
|
||||||
esc_html__( 'You will receive an email when your comment is approved.' )
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
$comment_approval_output = sprintf(
|
|
||||||
'<form action="%1$s" method="post">
|
|
||||||
<p>
|
|
||||||
<input type="checkbox" id="wp-comment-approved-notification-optin" name="wp-comment-approved-notification-optin">
|
|
||||||
<label for="wp-comment-approved-notification-optin">
|
|
||||||
%2$s
|
|
||||||
</label>
|
|
||||||
</p>
|
|
||||||
<input type="hidden" name="comment_ID" value="%3$s">
|
|
||||||
<input type="hidden" name="moderation-hash" value="%4$s">
|
|
||||||
<input type="submit" class="button" value="%5$s">
|
|
||||||
</form>',
|
|
||||||
esc_url( site_url( '/wp-comments-post.php' ) ),
|
|
||||||
esc_html__( 'I want to be notified by email when my comment is approved.' ),
|
|
||||||
absint( $comment->comment_ID ),
|
|
||||||
wp_hash( $comment->comment_date_gmt ),
|
|
||||||
esc_html_x( 'Save', 'comment approval notification form' )
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Disable the backcompat output.
|
|
||||||
$this->needs_comment_approval_notification_output = false;
|
|
||||||
|
|
||||||
// Return the approval notification opt-in form.
|
|
||||||
return $comment_approval_output;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Outputs a single comment.
|
* Outputs a single comment.
|
||||||
*
|
*
|
||||||
|
@ -391,6 +297,12 @@ class Walker_Comment extends Walker {
|
||||||
|
|
||||||
$commenter = wp_get_current_commenter();
|
$commenter = wp_get_current_commenter();
|
||||||
$show_pending_links = isset( $commenter['comment_author'] ) && $commenter['comment_author'];
|
$show_pending_links = isset( $commenter['comment_author'] ) && $commenter['comment_author'];
|
||||||
|
|
||||||
|
if ( $commenter['comment_author_email'] ) {
|
||||||
|
$moderation_note = __( 'Your comment is awaiting moderation.' );
|
||||||
|
} else {
|
||||||
|
$moderation_note = __( 'Your comment is awaiting moderation. This is a preview; your comment will be visible after it has been approved.' );
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
<<?php echo $tag; ?> <?php comment_class( $this->has_children ? 'parent' : '', $comment ); ?> id="comment-<?php comment_ID(); ?>">
|
<<?php echo $tag; ?> <?php comment_class( $this->has_children ? 'parent' : '', $comment ); ?> id="comment-<?php comment_ID(); ?>">
|
||||||
<?php if ( 'div' !== $args['style'] ) : ?>
|
<?php if ( 'div' !== $args['style'] ) : ?>
|
||||||
|
@ -416,14 +328,10 @@ class Walker_Comment extends Walker {
|
||||||
);
|
);
|
||||||
?>
|
?>
|
||||||
</div>
|
</div>
|
||||||
|
<?php if ( '0' == $comment->comment_approved ) : ?>
|
||||||
<?php
|
<em class="comment-awaiting-moderation"><?php echo $moderation_note; ?></em>
|
||||||
// Output the comment moderation feedback if needed.
|
<br />
|
||||||
$this->awaiting_moderation_text( $comment );
|
<?php endif; ?>
|
||||||
|
|
||||||
// Output the comment approval notification opt-in form if needed.
|
|
||||||
echo $this->comment_approval_notification_form( $comment );
|
|
||||||
?>
|
|
||||||
|
|
||||||
<div class="comment-meta commentmetadata">
|
<div class="comment-meta commentmetadata">
|
||||||
<?php
|
<?php
|
||||||
|
@ -493,6 +401,12 @@ class Walker_Comment extends Walker {
|
||||||
|
|
||||||
$commenter = wp_get_current_commenter();
|
$commenter = wp_get_current_commenter();
|
||||||
$show_pending_links = ! empty( $commenter['comment_author'] );
|
$show_pending_links = ! empty( $commenter['comment_author'] );
|
||||||
|
|
||||||
|
if ( $commenter['comment_author_email'] ) {
|
||||||
|
$moderation_note = __( 'Your comment is awaiting moderation.' );
|
||||||
|
} else {
|
||||||
|
$moderation_note = __( 'Your comment is awaiting moderation. This is a preview; your comment will be visible after it has been approved.' );
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
<<?php echo $tag; ?> id="comment-<?php comment_ID(); ?>" <?php comment_class( $this->has_children ? 'parent' : '', $comment ); ?>>
|
<<?php echo $tag; ?> id="comment-<?php comment_ID(); ?>" <?php comment_class( $this->has_children ? 'parent' : '', $comment ); ?>>
|
||||||
<article id="div-comment-<?php comment_ID(); ?>" class="comment-body">
|
<article id="div-comment-<?php comment_ID(); ?>" class="comment-body">
|
||||||
|
@ -536,13 +450,9 @@ class Walker_Comment extends Walker {
|
||||||
?>
|
?>
|
||||||
</div><!-- .comment-metadata -->
|
</div><!-- .comment-metadata -->
|
||||||
|
|
||||||
<?php
|
<?php if ( '0' == $comment->comment_approved ) : ?>
|
||||||
// Output the comment moderation feedback if needed.
|
<em class="comment-awaiting-moderation"><?php echo $moderation_note; ?></em>
|
||||||
$this->awaiting_moderation_text( $comment );
|
<?php endif; ?>
|
||||||
|
|
||||||
// Output the comment approval notification opt-in form if needed.
|
|
||||||
echo $this->comment_approval_notification_form( $comment );
|
|
||||||
?>
|
|
||||||
</footer><!-- .comment-meta -->
|
</footer><!-- .comment-meta -->
|
||||||
|
|
||||||
<div class="comment-content">
|
<div class="comment-content">
|
||||||
|
|
|
@ -2350,114 +2350,6 @@ function wp_new_comment_notify_postauthor( $comment_ID ) {
|
||||||
return wp_notify_postauthor( $comment_ID );
|
return wp_notify_postauthor( $comment_ID );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Notifies the comment author when their comment gets approved.
|
|
||||||
*
|
|
||||||
* This notification is only sent once when the comment status
|
|
||||||
* changes from unapproved to approved.
|
|
||||||
*
|
|
||||||
* @since 5.7.0
|
|
||||||
*
|
|
||||||
* @param int|WP_Comment $comment_id Comment ID or WP_Comment object.
|
|
||||||
* @return bool Whether the email was sent.
|
|
||||||
*/
|
|
||||||
function wp_new_comment_notify_comment_author( $comment_id ) {
|
|
||||||
$comment = get_comment( $comment_id );
|
|
||||||
|
|
||||||
if ( ! $comment ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$post = get_post( $comment->comment_post_ID );
|
|
||||||
|
|
||||||
if ( ! $post ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Make sure the comment author can be notified by email.
|
|
||||||
if ( empty( $comment->comment_author_email ) ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( ! get_comment_meta( $comment->comment_ID, '_wp_comment_author_notification_optin', true ) ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The blogname option is escaped with esc_html when
|
|
||||||
* saved into the database, we need to reverse this for
|
|
||||||
* the plain text area of the email.
|
|
||||||
*/
|
|
||||||
$blogname = wp_specialchars_decode( get_option( 'blogname' ), ENT_QUOTES );
|
|
||||||
|
|
||||||
$subject = sprintf(
|
|
||||||
/* translators: 1: Blog name, 2: Post title. */
|
|
||||||
__( '[%1$s] Your comment on "%2$s" has been approved' ),
|
|
||||||
$blogname,
|
|
||||||
$post->post_title
|
|
||||||
);
|
|
||||||
|
|
||||||
if ( ! empty( $comment->comment_author ) ) {
|
|
||||||
$notify_message = sprintf(
|
|
||||||
/* translators: %s: Comment author's name. */
|
|
||||||
__( 'Howdy %s,' ),
|
|
||||||
$comment->comment_author
|
|
||||||
) . "\r\n\r\n";
|
|
||||||
} else {
|
|
||||||
$notify_message = __( 'Howdy,' ) . "\r\n\r\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
$notify_message .= sprintf(
|
|
||||||
/* translators: %s: Post title. */
|
|
||||||
__( 'Your comment on "%s" has been approved.' ),
|
|
||||||
$post->post_title
|
|
||||||
) . "\r\n\r\n";
|
|
||||||
|
|
||||||
$notify_message .= sprintf(
|
|
||||||
/* translators: %s: Comment permalink. */
|
|
||||||
__( 'View comment: %s' ),
|
|
||||||
get_comment_link( $comment )
|
|
||||||
) . "\r\n";
|
|
||||||
|
|
||||||
$email = array(
|
|
||||||
'to' => $comment->comment_author_email,
|
|
||||||
'subject' => $subject,
|
|
||||||
'message' => $notify_message,
|
|
||||||
'headers' => '',
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Filters the contents of the email sent to notify a comment author that their comment was approved.
|
|
||||||
*
|
|
||||||
* Content should be formatted for transmission via wp_mail().
|
|
||||||
*
|
|
||||||
* @since 5.7.0
|
|
||||||
*
|
|
||||||
* @param array $email {
|
|
||||||
* Used to build wp_mail().
|
|
||||||
*
|
|
||||||
* @type string $to The email address of the comment author.
|
|
||||||
* @type string $subject The subject of the email.
|
|
||||||
* @type string $message The content of the email.
|
|
||||||
* @type string $headers Headers.
|
|
||||||
* }
|
|
||||||
* @param WP_Comment $comment Comment object.
|
|
||||||
*/
|
|
||||||
$email = apply_filters( 'comment_approval_notification', $email, $comment );
|
|
||||||
|
|
||||||
$sent = wp_mail(
|
|
||||||
$email['to'],
|
|
||||||
wp_specialchars_decode( $email['subject'] ),
|
|
||||||
$email['message'],
|
|
||||||
$email['headers']
|
|
||||||
);
|
|
||||||
|
|
||||||
// Delete the opt-in now the notification has been sent.
|
|
||||||
delete_comment_meta( $comment->comment_ID, '_wp_comment_author_notification_optin' );
|
|
||||||
|
|
||||||
return $sent;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the status of a comment.
|
* Sets the status of a comment.
|
||||||
*
|
*
|
||||||
|
|
|
@ -478,7 +478,6 @@ add_action( 'comment_post', 'wp_new_comment_notify_postauthor' );
|
||||||
add_action( 'after_password_reset', 'wp_password_change_notification' );
|
add_action( 'after_password_reset', 'wp_password_change_notification' );
|
||||||
add_action( 'register_new_user', 'wp_send_new_user_notifications' );
|
add_action( 'register_new_user', 'wp_send_new_user_notifications' );
|
||||||
add_action( 'edit_user_created_user', 'wp_send_new_user_notifications', 10, 2 );
|
add_action( 'edit_user_created_user', 'wp_send_new_user_notifications', 10, 2 );
|
||||||
add_action( 'comment_unapproved_to_approved', 'wp_new_comment_notify_comment_author' );
|
|
||||||
|
|
||||||
// REST API actions.
|
// REST API actions.
|
||||||
add_action( 'init', 'rest_api_init' );
|
add_action( 'init', 'rest_api_init' );
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '5.7-beta3-50374';
|
$wp_version = '5.7-beta3-50375';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue