/var/www/hkosl.com/aga/wp-comments-post.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<?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' ) ) ) {
        
$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( dirname__FILE__ ) . '/wp-load.php' );

nocache_headers();

$comment wp_handle_comment_submissionwp_unslash$_POST ) );
if ( 
is_wp_error$comment ) ) {
    
$data intval$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'] ) );

/**
 * Perform other actions when 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 boolean    $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;

// Add specific query arguments to display the awaiting moderation message.
if ( '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;