summaryrefslogtreecommitdiff
blob: 6770b2cc33dff6014d97bdb8c640bb322a049277 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php

class WPCOM_JSON_API_GET_Post_Counts_V1_1_Endpoint extends WPCOM_JSON_API_Endpoint {

	private $whitelist = array( 'publish' );

	/**
 	 * Build SQL query
 	 *
 	 * @param {String} type - post type
 	 * @param {Number} [author]
 	 * @return {String} SQL query
 	 */
	private function buildCountsQuery( $post_type = 'post', $user_id = null ) {
		global $wpdb;

		$query = "SELECT post_status as status, count(*) as count ";
		$query .= "FROM {$wpdb->posts} ";
		$query .= "WHERE post_type = %s ";
		if ( isset( $user_id ) ) {
			$query .= "AND post_author = %d ";
		}

		$query .= "GROUP BY status";

		return $wpdb->prepare( $query, $post_type, $user_id );
	}

	/**
 	 * Retrive counts using wp_cache
 	 *
 	 * @param {String} $post_type
 	 * @param {Number} [$id]
 	 */
	private function retrieveCounts( $post_type, $id = null) {
		if ( ! isset( $id ) ) {
			$counts = array();
			foreach( (array) wp_count_posts( $post_type ) as $status => $count ) {
				if ( in_array( $status, $this->whitelist ) && $count > 0 ) {
					$counts[ $status ] = (int) $count;
				}
			};

			return $counts;
		}

		global $wpdb;
		$key = 'rest-api-' . $id . '-' . _count_posts_cache_key( $post_type );
		$counts = wp_cache_get( $key, 'counts' );

		if ( false === $counts ) {
			$results = $wpdb->get_results( $this->buildCountsQuery( $post_type, $id ) );
			$counts = $this->filterStatusesByWhiteslist( $results );
			wp_cache_set( $key, $counts, 'counts' );
		}

		return $counts;
	}

	private function filterStatusesByWhiteslist( $in ) {
		$return = array();
		foreach( $in as $result) {
			if ( in_array( $result->status, $this->whitelist ) ) {
				$return[ $result->status ] = (int) $result->count;
			}
		};
		return $return;
	}

	public function callback( $path = '', $blog_id = 0, $post_type = 'post' ) {
		if ( ! get_current_user_id() ) {
			return new WP_Error( 'authorization_required', __( 'An active access token must be used to retrieve post counts.', 'jetpack' ), 403 );
		}

		$blog_id = $this->api->switch_to_blog_and_validate_user( $this->api->get_blog_id( $blog_id ), false );

		if ( is_wp_error( $blog_id ) ) {
			return $blog_id;
		}

		if ( ! post_type_exists( $post_type ) ) {
			return new WP_Error( 'unknown_post_type', __( 'Unknown post type requested.', 'jetpack' ), 404 );
		}

		$args = $this->query_args();
		$mine_ID = get_current_user_id();

		if ( current_user_can( 'edit_posts' ) ) {
			array_push( $this->whitelist, 'draft', 'future', 'pending', 'private', 'trash' );
		}

		$return = array(
			'counts' => (array) array(
				'all' => (object) $this->retrieveCounts( $post_type ),
				'mine' => (object) $this->retrieveCounts( $post_type, $mine_ID ),
			)
		);

		// AUTHOR
		if ( isset( $args['author'] ) ) {
			$author_ID = $args['author'];
			$return['counts']['author'] = (object) $this->retrieveCounts( $post_type, $author_ID );
		}

		return (object) $return;
	}
}