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
726      global $wpdb;
727      if ( current_user_can( 'manage_options' ) )
728           return; // don't throttle admins
729      $hour_ago = gmdate( 'Y-m-d H:i:s', time() - HOUR_IN_SECONDS );
730      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 ) ) ) {
731           $time_lastcomment = mysql2date('U', $lasttime, false);
732           $time_newcomment  = mysql2date('U', $date, false);
733           $flood_die = apply_filters('comment_flood_filter', false, $time_lastcomment, $time_newcomment);
734           if ( $flood_die ) {
735                do_action('comment_flood_trigger', $time_lastcomment, $time_newcomment);
736
737                if ( defined('DOING_AJAX') )
738                     die( __('You are posting comments too quickly. Slow down.') );
739
740                wp_die( __('You are posting comments too quickly. Slow down.'), '', array('response' => 403) );
741           }
742      }
743 }
744