Menu Adam R Brown

WP hooks navigation: Home/browseActions indexFilters index

Source View: akismet_spam_count_incr

To save our bandwidth, we show only a snippet of code around each occurence of the hook. View complete file in SVN (without highlighting).

Understanding Source Code

The best way to understand what a hook does is to look at where it occurs in the source code.

Remember, this hook may occur in more than one file. Moreover, the hook's context may change from version to version.

Source View

This hook occurs 2 times in this file.

Line Code
212                self::$last_comment_result = 'spam';
213
214                $discard = ( isset( $commentdata['akismet_pro_tip'] ) && $commentdata['akismet_pro_tip'] === 'discard' && self::allow_discard() );
215
216                do_action( 'akismet_spam_caught', $discard );
217
218                if ( $discard ) {
219                     // The spam is obvious, so we're bailing out early. 
220                     // akismet_result_spam() won't be called so bump the counter here
221                     if ( $incr = apply_filters( 'akismet_spam_count_incr', 1 ) ) {
222                          update_option( 'akismet_spam_count', get_option( 'akismet_spam_count' ) + $incr );
223                     }
224
225                     if ( self::$is_rest_api_call ) {
226                          return new WP_Error( 'akismet_rest_comment_discarded', __( 'Comment discarded.', 'akismet' ) );
227                     }
228                     else {
229                          // Redirect back to the previous page, or failing that, the post permalink, or failing that, the homepage of the blog.
230                          $redirect_to = isset( $_SERVER['HTTP_REFERER'] ) ? $_SERVER['HTTP_REFERER'] : ( $post ? get_permalink( $post ) : home_url() );
 
Line Code
991                // If the last comment we checked has had its approval set to 'trash',
992                // then it failed the comment blacklist check. Let that blacklist override
993                // the spam check, since users have the (valid) expectation that when
994                // they fill out their blacklists, comments that match it will always
995                // end up in the trash.
996                return $approved;
997           }
998
999           // bump the counter here instead of when the filter is added to reduce the possibility of overcounting
1000           if ( $incr = apply_filters('akismet_spam_count_incr', 1) )
1001                update_option( 'akismet_spam_count', get_option('akismet_spam_count') + $incr );
1002
1003           return self::$last_comment_result;
1004      }
1005      
1006      /**
1007       * If Akismet is temporarily unreachable, we don't want to "spam" the blogger with
1008       * moderation emails for comments that will be automatically cleared or spammed on
1009       * the next retry.