| @@ 316-344 (lines=29) @@ | ||
| 313 | * @param string $type Type of sync item to get the range for. |
|
| 314 | * @return array Array of min ID, max ID and total items in the range. |
|
| 315 | */ |
|
| 316 | public function get_range( $type ) { |
|
| 317 | global $wpdb; |
|
| 318 | if ( ! in_array( $type, array( 'comments', 'posts' ), true ) ) { |
|
| 319 | return array(); |
|
| 320 | } |
|
| 321 | ||
| 322 | switch ( $type ) { |
|
| 323 | case 'posts': |
|
| 324 | $table = $wpdb->posts; |
|
| 325 | $id = 'ID'; |
|
| 326 | $where_sql = Settings::get_blacklisted_post_types_sql(); |
|
| 327 | ||
| 328 | break; |
|
| 329 | case 'comments': |
|
| 330 | $table = $wpdb->comments; |
|
| 331 | $id = 'comment_ID'; |
|
| 332 | $where_sql = Settings::get_comments_filter_sql(); |
|
| 333 | break; |
|
| 334 | } |
|
| 335 | ||
| 336 | // TODO: Call $wpdb->prepare on the following query. |
|
| 337 | // phpcs:ignore WordPress.DB.PreparedSQL.InterpolatedNotPrepared |
|
| 338 | $results = $wpdb->get_results( "SELECT MAX({$id}) as max, MIN({$id}) as min, COUNT({$id}) as count FROM {$table} WHERE {$where_sql}" ); |
|
| 339 | if ( isset( $results[0] ) ) { |
|
| 340 | return $results[0]; |
|
| 341 | } |
|
| 342 | ||
| 343 | return array(); |
|
| 344 | } |
|
| 345 | ||
| 346 | /** |
|
| 347 | * Get the range for content (posts and comments) to sync. |
|
| @@ 289-317 (lines=29) @@ | ||
| 286 | * |
|
| 287 | * @return array Array of min ID, max ID and total items in the range. |
|
| 288 | */ |
|
| 289 | public function get_range( $type ) { |
|
| 290 | global $wpdb; |
|
| 291 | if ( ! in_array( $type, array( 'comments', 'posts' ), true ) ) { |
|
| 292 | return array(); |
|
| 293 | } |
|
| 294 | ||
| 295 | switch ( $type ) { |
|
| 296 | case 'posts': |
|
| 297 | $table = $wpdb->posts; |
|
| 298 | $id = 'ID'; |
|
| 299 | $where_sql = Settings::get_blacklisted_post_types_sql(); |
|
| 300 | ||
| 301 | break; |
|
| 302 | case 'comments': |
|
| 303 | $table = $wpdb->comments; |
|
| 304 | $id = 'comment_ID'; |
|
| 305 | $where_sql = Settings::get_comments_filter_sql(); |
|
| 306 | break; |
|
| 307 | } |
|
| 308 | ||
| 309 | // TODO: Call $wpdb->prepare on the following query. |
|
| 310 | // phpcs:ignore WordPress.DB.PreparedSQL.InterpolatedNotPrepared |
|
| 311 | $results = $wpdb->get_results( "SELECT MAX({$id}) as max, MIN({$id}) as min, COUNT({$id}) as count FROM {$table} WHERE {$where_sql}" ); |
|
| 312 | if ( isset( $results[0] ) ) { |
|
| 313 | return $results[0]; |
|
| 314 | } |
|
| 315 | ||
| 316 | return array(); |
|
| 317 | } |
|
| 318 | ||
| 319 | /** |
|
| 320 | * Continue sending instead of enqueueing. |
|