Process waiting pings a half hour after the last ping to avoid spamming ping sites. Don't make a ping wait if the last ping was more than half an hour ago. Props VoxPelli. fixes #6698 for trunk

git-svn-id: https://develop.svn.wordpress.org/trunk@11732 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Ryan Boren 2009-07-21 19:44:21 +00:00
parent 8db7e5a07c
commit 0f8ce0e0df
2 changed files with 11 additions and 3 deletions

View File

@ -1435,6 +1435,8 @@ function generic_ping($post_id = 0) {
weblog_ping($service);
}
set_transient('generic_ping_last', time(), 1800);
return $post_id;
}

View File

@ -3274,9 +3274,15 @@ function _transition_post_status($new_status, $old_status, $post) {
if ( '' == get_the_guid($post->ID) )
$wpdb->update( $wpdb->posts, array( 'guid' => get_permalink( $post->ID ) ), array( 'ID' => $post->ID ) );
do_action('private_to_published', $post->ID); // Deprecated, use private_to_publish
// do generic pings once per hour at most
if ( !wp_next_scheduled('do_generic_ping') )
wp_schedule_single_event(time() + 3600, 'do_generic_ping');
// do generic pings once per half hour at most
if ( !wp_next_scheduled('do_generic_ping') ) {
$schedule = time();
$last_ping = get_transient('generic_ping_last');
if ($last_ping) {
$schedule = max($schedule, $last_ping + 1800);
}
wp_schedule_single_event($schedule, 'do_generic_ping');
}
}
// Always clears the hook in case the post status bounced from future to draft.