WP hooks navigation: Home/browse • Actions index • Filters index
To save our bandwidth, we show only a snippet of code around each occurence of the hook. View complete file in SVN (without highlighting).
The best way to understand what a hook does is to look at where it occurs in the source code.
do_action( "hook_name" )apply_filters( "hook_name", "what_to_filter" ).Remember, this hook may occur in more than one file. Moreover, the hook's context may change from version to version.
| Line | Code |
|---|---|
| 604 | */ |
| 605 | function check_comment_flood_db( $ip, $email, $date ) { |
| 606 | global $wpdb; |
| 607 | if ( current_user_can( 'manage_options' ) ) |
| 608 | return; // don't throttle admins |
| 609 | $hour_ago = gmdate( 'Y-m-d H:i:s', time() - 3600 ); |
| 610 | 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 ) ) ) { |
| 611 | $time_lastcomment = mysql2date('U', $lasttime, false); |
| 612 | $time_newcomment = mysql2date('U', $date, false); |
| 613 | $flood_die = apply_filters('comment_flood_filter', false, $time_lastcomment, $time_newcomment); |
| 614 | if ( $flood_die ) { |
| 615 | do_action('comment_flood_trigger', $time_lastcomment, $time_newcomment); |
| 616 | |
| 617 | if ( defined('DOING_AJAX') ) |
| 618 | die( __('You are posting comments too quickly. Slow down.') ); |
| 619 | |
| 620 | wp_die( __('You are posting comments too quickly. Slow down.'), '', array('response' => 403) ); |
| 621 | } |
| 622 | } |