Menu Adam R Brown

WP hooks navigation: Home/browseActions indexFilters index

Source View: comment_flood_trigger

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

Line Code
676      global $wpdb;
677      if ( current_user_can( 'manage_options' ) )
678           return; // don't throttle admins
679      $hour_ago = gmdate( 'Y-m-d H:i:s', time() - 3600 );
680      if ( $lasttime = $wpdb->get_var( $wpdb->prepare( "SELECT `comment_date_gmt` FROM `$wpdb->comments` WHERE `comment_date_gmt` >= %s AND ( `comment_author_IP` = %s OR `comment_author_email` = %s ) ORDER BY `comment_date_gmt` DESC LIMIT 1", $hour_ago, $ip, $email ) ) ) {
681           $time_lastcomment = mysql2date('U', $lasttime, false);
682           $time_newcomment  = mysql2date('U', $date, false);
683           $flood_die = apply_filters('comment_flood_filter', false, $time_lastcomment, $time_newcomment);
684           if ( $flood_die ) {
685                do_action('comment_flood_trigger', $time_lastcomment, $time_newcomment);
686
687                if ( defined('DOING_AJAX') )
688                     die( __('You are posting comments too quickly.  Slow down.') );
689
690                wp_die( __('You are posting comments too quickly.  Slow down.'), '', array('response' => 403) );
691           }
692      }
693 }
694