Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a post_status check for performance #169

Open
wants to merge 12 commits into
base: main
Choose a base branch
from
61 changes: 46 additions & 15 deletions msm-sitemap.php
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ public static function setup() {
add_action( 'init', array( __CLASS__, 'create_post_type' ) );
add_filter( 'posts_pre_query', array( __CLASS__, 'disable_main_query_for_sitemap_xml' ), 10, 2 );
add_filter( 'template_include', array( __CLASS__, 'load_sitemap_template' ) );

// Disable WordPress 5.5-era sitemaps.
add_filter( 'wp_sitemaps_enabled', '__return_false' );

Expand Down Expand Up @@ -330,7 +330,9 @@ public static function disable_canonical_redirects_for_sitemap_xml( $redirect_ur
public static function get_post_year_range() {
global $wpdb;

$oldest_post_date_year = $wpdb->get_var( "SELECT DISTINCT YEAR(post_date) as year FROM $wpdb->posts WHERE post_status = 'publish' ORDER BY year ASC LIMIT 1" );
$post_statuses_in = self::get_supported_post_statuses_in();

$oldest_post_date_year = $wpdb->get_var( "SELECT DISTINCT YEAR(post_date) as year FROM $wpdb->posts WHERE post_status IN ( {$post_statuses_in} ) ORDER BY year ASC LIMIT 1" );

if ( null !== $oldest_post_date_year ) {
$current_year = date( 'Y' );
Expand Down Expand Up @@ -382,8 +384,10 @@ public static function date_range_has_posts( $start_date, $end_date ) {
$start_date .= ' 00:00:00';
$end_date .= ' 23:59:59';

$post_types_in = self::get_supported_post_types_in();
return $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->posts WHERE post_status = 'publish' AND post_date >= %s AND post_date <= %s AND post_type IN ( {$post_types_in} ) LIMIT 1", $start_date, $end_date ) );
$post_types_in = self::get_supported_post_types_in();
$post_statuses_in = self::get_supported_post_statuses_in();

return $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->posts WHERE post_status IN ( {$post_statuses_in} ) AND post_date >= %s AND post_date <= %s AND post_type IN ( {$post_types_in} ) LIMIT 1", $start_date, $end_date ) );
}

/**
Expand All @@ -397,10 +401,12 @@ public static function get_post_ids_for_date( $sitemap_date, $limit = 500 ) {
global $wpdb;

$start_date = $sitemap_date . ' 00:00:00';
$end_date = $sitemap_date . ' 23:59:59';
$post_types_in = self::get_supported_post_types_in();
$end_dat = $sitemap_date . ' 23:59:59';
srtfisher marked this conversation as resolved.
Show resolved Hide resolved

$posts = $wpdb->get_results( $wpdb->prepare( "SELECT ID, post_date FROM $wpdb->posts WHERE post_status = 'publish' AND post_date >= %s AND post_date <= %s AND post_type IN ( {$post_types_in} ) LIMIT %d", $start_date, $end_date, $limit ) );
$post_types_in = self::get_supported_post_types_in();
$post_statuses_in = self::get_supported_post_statuses_in();

$posts = $wpdb->get_results( $wpdb->prepare( "SELECT ID, post_date FROM $wpdb->posts WHERE post_status IN ( {$post_statuses_in} ) AND post_date >= %s AND post_date <= %s AND post_type IN ( {$post_types_in} ) LIMIT %d", $start_date, $end_date, $limit ) );

usort( $posts, array( __CLASS__ , 'order_by_post_date' ) );

Expand Down Expand Up @@ -587,9 +593,12 @@ public static function get_last_modified_posts() {
$date = date( 'Y-m-d H:i:s', $sitemap_last_run );
}

$post_types_in = self::get_supported_post_types_in();
$post_types_in = self::get_supported_post_types_in();
$post_statuses_in = self::get_supported_post_statuses_in();

$modified_posts = $wpdb->get_results( $wpdb->prepare( "SELECT ID, post_date FROM $wpdb->posts WHERE post_type IN ( {$post_types_in} ) AND post_modified_gmt >= %s LIMIT 1000", $date ) );
$modified_posts = $wpdb->get_results(
$wpdb->prepare( "SELECT ID, post_date FROM $wpdb->posts WHERE post_type IN ( {$post_types_in} ) AND post_status IN ( {$post_statuses_in} ) AND post_modified_gmt >= %s LIMIT 1000", $date )
);
return $modified_posts;
}

Expand Down Expand Up @@ -800,17 +809,39 @@ public static function get_supported_post_types() {
return apply_filters( 'msm_sitemap_entry_post_type', array( 'post' ) );
}

private static function get_supported_post_types_in() {
/**
* Retrieve supported post statuses for inclusion in sitemap.
*
* @return string[] Array of post statuses.
*/
public static function get_supported_post_statuses() {
return (array) apply_filters( 'msm_sitemap_entry_post_status', array_values( get_post_stati( array( 'public' => true ) ) ) );
}

/**
* Convert an array to a string of comma-separated values to be used in a query.
*
* @param string[] $values Array of values to be converted.
* @return string Comma-separated prepared values.
*/
private static function prepare_where_in( $values ) {
global $wpdb;

$post_types = self::get_supported_post_types();
$post_types_prepared = array();
$prepared = array();

foreach ( $post_types as $post_type ) {
$post_types_prepared[] = $wpdb->prepare( '%s', $post_type );
foreach ( $values as $value ) {
$prepared[] = $wpdb->prepare( '%s', $value );
}

return implode( ', ', $post_types_prepared );
return implode( ', ', $prepared );
}

private static function get_supported_post_types_in() {
return self::prepare_where_in( self::get_supported_post_types() );
}

private static function get_supported_post_statuses_in() {
return self::prepare_where_in( self::get_supported_post_statuses() );
}

/**
Expand Down