<?php /** * Handles Comment Post to WordPress and prevents duplicate comment posting. * * @package WordPress */ if ( 'POST' !== $_SERVER['REQUEST_METHOD'] ) { $protocol = $_SERVER['SERVER_PROTOCOL']; if ( ! in_array( $protocol, array( 'HTTP/1.1', 'HTTP/2', 'HTTP/2.0', 'HTTP/3' ), true ) ) { $protocol = 'HTTP/1.0'; } header( 'Allow: POST' ); header( "$protocol 405 Method Not Allowed" ); header( 'Content-Type: text/plain' ); exit; } /** Sets up the WordPress Environment. */ require __DIR__ . '/wp-load.php'; nocache_headers(); $comment = wp_handle_comment_submission( wp_unslash( $_POST ) ); if ( is_wp_error( $comment ) ) { $data = (int) $comment->get_error_data(); if ( ! empty( $data ) ) { wp_die( '<p>' . $comment->get_error_message() . '</p>', __( 'Comment Submission Failure' ), array( 'response' => $data, 'back_link' => true, ) ); } else { exit; } } $user = wp_get_current_user(); $cookies_consent = ( isset( $_POST['wp-comment-cookies-consent'] ) ); /** * Fires after comment cookies are set. * * @since 3.4.0 * @since 4.9.6 The `$cookies_consent` parameter was added. * * @param WP_Comment $comment Comment object. * @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. */ 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; // If user didn't consent to cookies, add specific query arguments to display the awaiting moderation message. if ( ! $cookies_consent && 'unapproved' === wp_get_comment_status( $comment ) && ! empty( $comment->comment_author_email ) ) { $location = add_query_arg( array( 'unapproved' => $comment->comment_ID, 'moderation-hash' => wp_hash( $comment->comment_date_gmt ), ), $location ); } /** * Filters the location URI to send the commenter after posting. * * @since 2.0.5 * * @param string $location The 'redirect_to' URI sent via $_POST. * @param WP_Comment $comment Comment object. */ $location = apply_filters( 'comment_post_redirect', $location, $comment ); wp_safe_redirect( $location ); exit;
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
.tmb | Folder | 0755 |
|
|
.well-known | Folder | 0755 |
|
|
.wp-cli | Folder | 0755 |
|
|
cgi-bin | Folder | 0755 |
|
|
wp-admin | Folder | 0755 |
|
|
wp-content | Folder | 0755 |
|
|
wp-includes | Folder | 0755 |
|
|
.ftpquota | File | 17 B | 0600 |
|
.htaccess | File | 7.83 KB | 0644 |
|
.htaccess.bk | File | 3.58 KB | 0644 |
|
.user.ini | File | 581 B | 0644 |
|
.user.ini_ | File | 592 B | 0644 |
|
error_log | File | 20.85 MB | 0644 |
|
index.php | File | 405 B | 0644 |
|
license.txt | File | 19.45 KB | 0644 |
|
php.ini | File | 637 B | 0644 |
|
php.ini_ | File | 666 B | 0644 |
|
readme.html | File | 7.24 KB | 0644 |
|
wp-activate.php | File | 7.21 KB | 0644 |
|
wp-blog-header.php | File | 351 B | 0644 |
|
wp-comments-post.php | File | 2.27 KB | 0644 |
|
wp-config-sample.php | File | 3.26 KB | 0644 |
|
wp-config.php | File | 3.46 KB | 0600 |
|
wp-cron.php | File | 5.49 KB | 0644 |
|
wp-links-opml.php | File | 2.44 KB | 0644 |
|
wp-load.php | File | 3.84 KB | 0644 |
|
wp-login.php | File | 50.16 KB | 0644 |
|
wp-mail.php | File | 8.34 KB | 0644 |
|
wp-settings.php | File | 28.35 KB | 0644 |
|
wp-signup.php | File | 33.58 KB | 0644 |
|
wp-trackback.php | File | 4.98 KB | 0644 |
|
wpt-hotlinked-image-stub.png | File | 12.59 KB | 0644 |
|
xmlrpc.php | File | 3.17 KB | 0644 |
|