ap_check_spam( integer $post_id )
Description #
Check post for spam, if spam then hold it for moderation.
Parameters #
- $post_idinteger (Required) Post id.
Source #
File: includes/akismet.php
function ap_check_spam( $post_id ) { // Return if akisment is not enabled. if ( ! class_exists( 'Akismet' ) || is_super_admin() ) { return; } $post = ap_get_post( $post_id ); // Set default arguments to pass. $defaults = array( 'blog' => home_url( '/' ), 'user_ip' => get_post_meta( $post->ID, 'create_ip', true ), 'user_agent' => ! empty( $_SERVER['HTTP_USER_AGENT'] ) ? sanitize_text_field( wp_unslash( $_SERVER['HTTP_USER_AGENT'] ) ) : '', 'referrer' => ! empty( $_SERVER['HTTP_REFERER'] ) ? sanitize_text_field( wp_unslash( $_SERVER['HTTP_REFERER'] ) ) : '', 'permalink' => get_permalink( $post->ID ), 'comment_type' => 'forum-post', 'comment_author' => get_the_author_meta( 'nicename', $post->post_author ), 'comment_author_email' => get_the_author_meta( 'user_email', $post->post_author ), 'comment_author_url' => get_the_author_meta( 'url', $post->post_author ), 'comment_content' => $post->post_content, ); $akismet_ua = sprintf( 'WordPress/%s | Akismet/%s', $GLOBALS['wp_version'], constant( 'AKISMET_VERSION' ) ); $akismet_ua = apply_filters( 'akismet_ua', $akismet_ua ); $api_key = Akismet::get_api_key(); $host = Akismet::API_HOST; if ( ! empty( $api_key ) ) { $host = $api_key . '.' . $host; } $http_host = $host; $http_args = array( 'body' => $defaults, 'headers' => array( 'Content-Type' => 'application/x-www-form-urlencoded; charset=' . get_option( 'blog_charset' ), 'Host' => $host, 'User-Agent' => $akismet_ua, ), 'httpversion' => '1.0', 'timeout' => 15, ); $http_akismet_url = "http://{$http_host}/1.1/comment-check"; $akismet_url = $http_akismet_url; /** * Try SSL first; if that fails, try without it and don't try it again for a while. */ $ssl_failed = false; $ssl = $ssl_failed; // Check if SSL requests were disabled fewer than X hours ago. $ssl_disabled = get_option( 'akismet_ssl_disabled' ); if ( $ssl_disabled && $ssl_disabled < ( time() - 60 * 60 * 24 ) ) { // 24 hours $ssl_disabled = false; delete_option( 'akismet_ssl_disabled' ); } elseif ( $ssl_disabled ) { do_action( 'akismet_ssl_disabled' ); } $ssl = function_exists( 'wp_http_supports' ) && wp_http_supports( array( 'ssl' ) ); if ( ! $ssl_disabled && $ssl ) { $akismet_url = set_url_scheme( $akismet_url, 'https' ); } $response = wp_remote_post( $akismet_url, $http_args ); Akismet::log( compact( 'akismet_url', 'http_args', 'response' ) ); if ( $ssl && is_wp_error( $response ) ) { // Intermittent connection problems may cause the first HTTPS // request to fail and subsequent HTTP requests to succeed randomly. // Retry the HTTPS request once before disabling SSL for a time. $response = wp_remote_post( $akismet_url, $http_args ); Akismet::log( compact( 'akismet_url', 'http_args', 'response' ) ); if ( is_wp_error( $response ) ) { $ssl_failed = true; // Try the request again without SSL. $response = wp_remote_post( $http_akismet_url, $http_args ); Akismet::log( compact( 'http_akismet_url', 'http_args', 'response' ) ); } } if ( is_wp_error( $response ) ) { return array( '', '' ); } if ( $ssl_failed ) { // The request failed when using SSL but succeeded without it. Disable SSL for future requests. update_option( 'akismet_ssl_disabled', time() ); do_action( 'akismet_https_disabled' ); } if ( $response['body'] ) { wp_update_post( array( 'ID' => $post_id, 'post_status' => 'moderate', ) ); } }
Expand full source code Collapse full source code View on GitHub: includes/akismet.php:19
Add your comment