On this page
wp_handle_comment_submission( array $comment_data ): WP_Comment|WP_Error
Handles the submission of a comment, usually posted to wp-comments-post.php via a comment form.
Description
This function expects unslashed data, as opposed to functions such as wp_new_comment() which expect slashed data.
Parameters
$comment_dataarray Required-
Comment data.
comment_post_IDstring|intThe ID of the post that relates to the comment.authorstringThe name of the comment author.emailstringThe comment author email address.urlstringThe comment author URL.commentstringThe content of the comment.comment_parentstring|intThe ID of this comment's parent, if any. Default 0._wp_unfiltered_html_commentstringThe nonce value for allowing unfiltered HTML.
Return
WP_Comment|WP_Error A WP_Comment object on success, a WP_Error object on failure.
Source
File: wp-includes/comment.php. View all references
function wp_handle_comment_submission( $comment_data ) {
$comment_post_id = 0;
$comment_author = '';
$comment_author_email = '';
$comment_author_url = '';
$comment_content = '';
$comment_parent = 0;
$user_id = 0;
if ( isset( $comment_data['comment_post_ID'] ) ) {
$comment_post_id = (int) $comment_data['comment_post_ID'];
}
if ( isset( $comment_data['author'] ) && is_string( $comment_data['author'] ) ) {
$comment_author = trim( strip_tags( $comment_data['author'] ) );
}
if ( isset( $comment_data['email'] ) && is_string( $comment_data['email'] ) ) {
$comment_author_email = trim( $comment_data['email'] );
}
if ( isset( $comment_data['url'] ) && is_string( $comment_data['url'] ) ) {
$comment_author_url = trim( $comment_data['url'] );
}
if ( isset( $comment_data['comment'] ) && is_string( $comment_data['comment'] ) ) {
$comment_content = trim( $comment_data['comment'] );
}
if ( isset( $comment_data['comment_parent'] ) ) {
$comment_parent = absint( $comment_data['comment_parent'] );
}
$post = get_post( $comment_post_id );
if ( empty( $post->comment_status ) ) {
/**
* Fires when a comment is attempted on a post that does not exist.
*
* @since 1.5.0
*
* @param int $comment_post_id Post ID.
*/
do_action( 'comment_id_not_found', $comment_post_id );
return new WP_Error( 'comment_id_not_found' );
}
// get_post_status() will get the parent status for attachments.
$status = get_post_status( $post );
if ( ( 'private' === $status ) && ! current_user_can( 'read_post', $comment_post_id ) ) {
return new WP_Error( 'comment_id_not_found' );
}
$status_obj = get_post_status_object( $status );
if ( ! comments_open( $comment_post_id ) ) {
/**
* Fires when a comment is attempted on a post that has comments closed.
*
* @since 1.5.0
*
* @param int $comment_post_id Post ID.
*/
do_action( 'comment_closed', $comment_post_id );
return new WP_Error( 'comment_closed', __( 'Sorry, comments are closed for this item.' ), 403 );
} elseif ( 'trash' === $status ) {
/**
* Fires when a comment is attempted on a trashed post.
*
* @since 2.9.0
*
* @param int $comment_post_id Post ID.
*/
do_action( 'comment_on_trash', $comment_post_id );
return new WP_Error( 'comment_on_trash' );
} elseif ( ! $status_obj->public && ! $status_obj->private ) {
/**
* Fires when a comment is attempted on a post in draft mode.
*
* @since 1.5.1
*
* @param int $comment_post_id Post ID.
*/
do_action( 'comment_on_draft', $comment_post_id );
if ( current_user_can( 'read_post', $comment_post_id ) ) {
return new WP_Error( 'comment_on_draft', __( 'Sorry, comments are not allowed for this item.' ), 403 );
} else {
return new WP_Error( 'comment_on_draft' );
}
} elseif ( post_password_required( $comment_post_id ) ) {
/**
* Fires when a comment is attempted on a password-protected post.
*
* @since 2.9.0
*
* @param int $comment_post_id Post ID.
*/
do_action( 'comment_on_password_protected', $comment_post_id );
return new WP_Error( 'comment_on_password_protected' );
} else {
/**
* Fires before a comment is posted.
*
* @since 2.8.0
*
* @param int $comment_post_id Post ID.
*/
do_action( 'pre_comment_on_post', $comment_post_id );
}
// If the user is logged in.
$user = wp_get_current_user();
if ( $user->exists() ) {
if ( empty( $user->display_name ) ) {
$user->display_name = $user->user_login;
}
$comment_author = $user->display_name;
$comment_author_email = $user->user_email;
$comment_author_url = $user->user_url;
$user_id = $user->ID;
if ( current_user_can( 'unfiltered_html' ) ) {
if ( ! isset( $comment_data['_wp_unfiltered_html_comment'] )
|| ! wp_verify_nonce( $comment_data['_wp_unfiltered_html_comment'], 'unfiltered-html-comment_' . $comment_post_id )
) {
kses_remove_filters(); // Start with a clean slate.
kses_init_filters(); // Set up the filters.
remove_filter( 'pre_comment_content', 'wp_filter_post_kses' );
add_filter( 'pre_comment_content', 'wp_filter_kses' );
}
}
} else {
if ( get_option( 'comment_registration' ) ) {
return new WP_Error( 'not_logged_in', __( 'Sorry, you must be logged in to comment.' ), 403 );
}
}
$comment_type = 'comment';
if ( get_option( 'require_name_email' ) && ! $user->exists() ) {
if ( '' == $comment_author_email || '' == $comment_author ) {
return new WP_Error( 'require_name_email', __( '<strong>Error:</strong> Please fill the required fields.' ), 200 );
} elseif ( ! is_email( $comment_author_email ) ) {
return new WP_Error( 'require_valid_email', __( '<strong>Error:</strong> Please enter a valid email address.' ), 200 );
}
}
$commentdata = array(
'comment_post_ID' => $comment_post_id,
);
$commentdata += compact(
'comment_author',
'comment_author_email',
'comment_author_url',
'comment_content',
'comment_type',
'comment_parent',
'user_id'
);
/**
* Filters whether an empty comment should be allowed.
*
* @since 5.1.0
*
* @param bool $allow_empty_comment Whether to allow empty comments. Default false.
* @param array $commentdata Array of comment data to be sent to wp_insert_comment().
*/
$allow_empty_comment = apply_filters( 'allow_empty_comment', false, $commentdata );
if ( '' === $comment_content && ! $allow_empty_comment ) {
return new WP_Error( 'require_valid_comment', __( '<strong>Error:</strong> Please type your comment text.' ), 200 );
}
$check_max_lengths = wp_check_comment_data_max_lengths( $commentdata );
if ( is_wp_error( $check_max_lengths ) ) {
return $check_max_lengths;
}
$comment_id = wp_new_comment( wp_slash( $commentdata ), true );
if ( is_wp_error( $comment_id ) ) {
return $comment_id;
}
if ( ! $comment_id ) {
return new WP_Error( 'comment_save_error', __( '<strong>Error:</strong> The comment could not be saved. Please try again later.' ), 500 );
}
return get_comment( $comment_id );
}
Hooks
- apply_filters( 'allow_empty_comment',
bool $allow_empty_comment ,array $commentdata ) -
Filters whether an empty comment should be allowed.
- do_action( 'comment_closed',
int $comment_post_id ) -
Fires when a comment is attempted on a post that has comments closed.
- do_action( 'comment_id_not_found',
int $comment_post_id ) -
Fires when a comment is attempted on a post that does not exist.
- do_action( 'comment_on_draft',
int $comment_post_id ) -
Fires when a comment is attempted on a post in draft mode.
- do_action( 'comment_on_password_protected',
int $comment_post_id ) -
Fires when a comment is attempted on a password-protected post.
- do_action( 'comment_on_trash',
int $comment_post_id ) -
Fires when a comment is attempted on a trashed post.
- do_action( 'pre_comment_on_post',
int $comment_post_id ) -
Fires before a comment is posted.
Related
Uses
| Uses | Description |
|---|---|
| wp_check_comment_data_max_lengths() wp-includes/comment.php | Compares the lengths of comment data against the maximum character limits. |
| post_password_required() wp-includes/post-template.php | Determines whether the post requires password and whether a correct password has been provided. |
| is_email() wp-includes/formatting.php | Verifies that an email is valid. |
| wp_verify_nonce() wp-includes/pluggable.php | Verifies that a correct security nonce was used with time limit. |
| wp_get_current_user() wp-includes/pluggable.php | Retrieves the current user object. |
| kses_remove_filters() wp-includes/kses.php | Removes all KSES input form content filters. |
| kses_init_filters() wp-includes/kses.php | Adds all KSES input form content filters. |
| wp_new_comment() wp-includes/comment.php | Adds a new comment to the database. |
| comments_open() wp-includes/comment-template.php | Determines whether the current post is open for comments. |
| remove_filter() wp-includes/plugin.php | Removes a callback function from a filter hook. |
| get_post_status_object() wp-includes/post.php | Retrieves a post status object by name. |
| get_post_status() wp-includes/post.php | Retrieves the post status based on the post ID. |
| is_wp_error() wp-includes/load.php | Checks whether the given variable is a WordPress Error. |
| get_comment() wp-includes/comment.php | Retrieves comment data given a comment ID or comment object. |
| get_post() wp-includes/post.php | Retrieves post data given a post ID or post object. |
| add_filter() wp-includes/plugin.php | Adds a callback function to a filter hook. |
| get_option() wp-includes/option.php | Retrieves an option value based on an option name. |
| apply_filters() wp-includes/plugin.php | Calls the callback functions that have been added to a filter hook. |
| current_user_can() wp-includes/capabilities.php | Returns whether the current user has the specified capability. |
| do_action() wp-includes/plugin.php | Calls the callback functions that have been added to an action hook. |
| absint() wp-includes/functions.php | Converts a value to non-negative integer. |
| wp_slash() wp-includes/formatting.php | Adds slashes to a string or recursively adds slashes to strings within an array. |
| __() wp-includes/l10n.php | Retrieves the translation of $text. |
| WP_Error::__construct() wp-includes/class-wp-error.php | Initializes the error. |
Changelog
| Version | Description |
|---|---|
| 4.4.0 | Introduced. |
© 2003–2022 WordPress Foundation
Licensed under the GNU GPLv2+ License.
https://developer.wordpress.org/reference/functions/wp_handle_comment_submission