Menu Adam R Brown

WP hooks navigation: Home/browseActions indexFilters index

Source View: comment_flood_filter

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
662  */
663 function check_comment_flood_db( $ip, $email, $date ) {
664      global $wpdb;
665      if ( current_user_can( 'manage_options' ) )
666           return; // don't throttle admins
667      $hour_ago = gmdate( 'Y-m-d H:i:s', time() - 3600 );
668      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 ) ) ) {
669           $time_lastcomment = mysql2date('U', $lasttime, false);
670           $time_newcomment  = mysql2date('U', $date, false);
671           $flood_die = apply_filters('comment_flood_filter', false, $time_lastcomment, $time_newcomment);
672           if ( $flood_die ) {
673                do_action('comment_flood_trigger', $time_lastcomment, $time_newcomment);
674
675                if ( defined('DOING_AJAX') )
676                     die( __('You are posting comments too quickly.  Slow down.') );
677
678                wp_die( __('You are posting comments too quickly.  Slow down.'), '', array('response' => 403) );
679           }
680      }