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
694      global $wpdb;
695      if ( current_user_can( 'manage_options' ) )
696           return; // don't throttle admins
697      $hour_ago = gmdate( 'Y-m-d H:i:s', time() - 3600 );
698      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 ) ) ) {
699           $time_lastcomment = mysql2date('U', $lasttime, false);
700           $time_newcomment  = mysql2date('U', $date, false);
701           $flood_die = apply_filters('comment_flood_filter', false, $time_lastcomment, $time_newcomment);
702           if ( $flood_die ) {
703                do_action('comment_flood_trigger', $time_lastcomment, $time_newcomment);
704
705                if ( defined('DOING_AJAX') )
706                     die( __('You are posting comments too quickly. Slow down.') );
707
708                wp_die( __('You are posting comments too quickly. Slow down.'), '', array('response' => 403) );
709           }
710      }
711 }
712