PluginProbe ʕ •ᴥ•ʔ
Jetpack – WP Security, Backup, Speed, & Growth / 15.9-a.7
Jetpack – WP Security, Backup, Speed, & Growth v15.9-a.7
15.9-a.7 15.9-a.5 15.9-a.3 15.9-a.1 15.8 15.8-beta 15.8-a.7 15.8-a.5 5.2.5 5.3.4 5.4.4 5.5.5 5.6.5 5.7.5 5.8.4 5.9.4 6.0.4 6.1 6.1.1 6.1.2 6.1.3 6.1.4 6.1.5 6.2 6.2.1 6.2.2 6.2.3 6.2.4 6.2.5 6.3 6.3.1 6.3.2 6.3.3 6.3.4 6.3.5 6.3.6 6.3.7 6.4 6.4.1 6.4.2 6.4.3 6.4.4 6.4.5 6.4.6 6.5 6.5.1 6.5.2 6.5.3 6.5.4 6.6 6.6.1 6.6.2 6.6.3 6.6.4 6.6.5 6.7 6.7.1 6.7.2 6.7.3 6.7.4 6.8 6.8.1 6.8.2 6.8.3 6.8.4 6.8.5 6.9 6.9.1 6.9.2 6.9.3 6.9.4 7.0 7.0.1 7.0.2 7.0.3 7.0.4 7.0.5 7.1 7.1.1 7.1.2 7.1.3 7.1.4 7.1.5 7.2 7.2.1 7.2.1.1 7.2.2 7.2.3 7.2.4 7.2.5 7.3 7.3.0.1 7.3.1 7.3.1.1 7.3.2 7.3.3 7.3.4 7.3.5 7.4 7.4.1 7.4.2 7.4.3 7.4.4 7.4.5 7.5 7.5.0.1 7.5.1 7.5.2 7.5.3 7.5.4 7.5.5 7.5.6 7.5.7 7.6 7.6.1 7.6.2 7.6.3 7.6.4 7.7 7.7.1 7.7.2 7.7.3 7.7.4 7.7.5 7.7.6 7.8 7.8.1 7.8.2 7.8.3 7.8.4 7.9 7.9.1 7.9.2 7.9.3 7.9.4 8.0 8.0.1 8.0.2 8.0.3 8.1 8.1.1 8.1.2 8.1.3 8.1.4 8.2 8.2.0.1 8.2.1 8.2.2 8.2.3 8.2.4 8.2.5 8.2.6 8.3 8.3.1 8.3.2 8.3.3 8.4 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 8.5 8.5.1 8.5.2 8.5.3 8.6 8.6.1 8.6.2 8.6.3 8.6.4 8.7 8.7.0.1 8.7.1 8.7.2 8.7.3 8.7.4 8.8 8.8.1 8.8.2 8.8.3 8.8.4 8.8.5 8.9 8.9.1 8.9.2 8.9.3 8.9.4 9.0 9.0.1 9.0.2 9.0.3 9.0.4 9.0.5 9.1 9.1.1 9.1.2 9.1.3 9.2 9.2.1 9.2.2 9.2.3 9.2.4 9.3 9.3.1 9.3.2 9.3.3 9.3.4 9.3.5 9.4 9.4.1 9.4.2 9.4.3 9.4.4 9.5 9.5.1 9.5.2 9.5.3 9.5.4 9.5.5 9.6 9.6.1 9.6.2 9.6.3 9.6.4 9.7 9.7.1 9.7.2 15.7-beta.2 9.7.3 15.7.1 9.8 15.8-a.1 9.8.1 15.8-a.3 9.8.2 2.0.9 9.8.3 2.1.7 9.9 2.2.10 9.9.1 2.3.10 9.9.2 2.4.7 9.9.3 2.5.5 2.6.6 2.7.5 2.8.5 2.9.6 3.0.6 3.1.5 3.2.5 3.3.6 3.4.6 3.5.6 3.6.4 3.7.5 3.8.5 3.9.10 4.0.7 4.1.4 4.2.5 4.3.5 4.4.5 4.5.3 4.6.3 4.7.4 4.8.5 4.9.3 5.0.3 5.1.4 trunk 10.0 10.0.1 10.0.2 10.1 10.1.1 10.1.2 10.2 10.2.1 10.2.2 10.2.3 10.3 10.3.1 10.3.2 10.4 10.4.1 10.4.2 10.5 10.5.1 10.5.2 10.5.3 10.6 10.6.1 10.6.2 10.7 10.7.1 10.7.2 10.8 10.8.1 10.8.2 10.9 10.9.1 10.9.2 10.9.3 11.0 11.0.1 11.0.2 11.1 11.1.1 11.1.2 11.1.3 11.1.4 11.2 11.2.1 11.2.2 11.3 11.3.1 11.3.2 11.3.3 11.3.4 11.4 11.4.1 11.4.2 11.5 11.5.1 11.5.2 11.5.3 11.6 11.6.1 11.6.2 11.7 11.7.1 11.7.2 11.7.3 11.8 11.8.3 11.8.4 11.8.5 11.8.6 11.9 11.9.1 11.9.2 11.9.3 12.0 12.0.1 12.0.2 12.1 12.1.1 12.1.2 12.2 12.2.1 12.2.2 12.3 12.3.1 12.4 12.4.1 12.5 12.5.1 12.6 12.6.1 12.6.2 12.6.3 12.7 12.7.1 12.7.2 12.8 12.8.1 12.8.2 12.9 12.9.1 12.9.2 12.9.3 12.9.4 13.0 13.0.1 13.1 13.1.1 13.1.2 13.1.3 13.1.4 13.2 13.2.1 13.2.2 13.2.3 13.3 13.3.1 13.3.2 13.4 13.4.1 13.4.2 13.4.3 13.4.4 13.5 13.5.1 13.6 13.6.1 13.7 13.7.1 13.8 13.8.1 13.8.2 13.9 13.9.1 14.0 14.1 14.2 14.2.1 14.3 14.4 14.4.1 14.5 14.6 14.7 14.8 14.9 14.9.1 15.0 15.0.1 15.0.2 15.1 15.1.1 15.2 15.3 15.3.1 15.4 15.5 15.6 15.7 15.7-a.1 15.7-a.3 15.7-a.5 15.7-a.7 15.7-beta
jetpack / json-endpoints / class.wpcom-json-api-get-comments-tree-endpoint.php
jetpack / json-endpoints Last commit date
jetpack 1 week ago class.wpcom-json-api-add-widget-endpoint.php 6 months ago class.wpcom-json-api-autosave-post-v1-1-endpoint.php 6 months ago class.wpcom-json-api-bulk-delete-post-endpoint.php 6 months ago class.wpcom-json-api-bulk-restore-post-endpoint.php 6 months ago class.wpcom-json-api-bulk-update-comments-endpoint.php 1 week ago class.wpcom-json-api-comment-endpoint.php 6 months ago class.wpcom-json-api-delete-media-endpoint.php 6 months ago class.wpcom-json-api-delete-media-v1-1-endpoint.php 6 months ago class.wpcom-json-api-edit-media-v1-2-endpoint.php 1 week ago class.wpcom-json-api-get-autosave-v1-1-endpoint.php 6 months ago class.wpcom-json-api-get-comment-counts-endpoint.php 6 months ago class.wpcom-json-api-get-comment-endpoint.php 6 months ago class.wpcom-json-api-get-comment-history-endpoint.php 6 months ago class.wpcom-json-api-get-comments-tree-endpoint.php 6 months ago class.wpcom-json-api-get-comments-tree-v1-1-endpoint.php 6 months ago class.wpcom-json-api-get-comments-tree-v1-2-endpoint.php 6 months ago class.wpcom-json-api-get-customcss.php 6 months ago class.wpcom-json-api-get-media-endpoint.php 6 months ago class.wpcom-json-api-get-media-v1-1-endpoint.php 6 months ago class.wpcom-json-api-get-media-v1-2-endpoint.php 6 months ago class.wpcom-json-api-get-post-counts-v1-1-endpoint.php 6 months ago class.wpcom-json-api-get-post-endpoint.php 6 months ago class.wpcom-json-api-get-post-v1-1-endpoint.php 6 months ago class.wpcom-json-api-get-site-endpoint.php 4 weeks ago class.wpcom-json-api-get-site-v1-2-endpoint.php 3 months ago class.wpcom-json-api-get-taxonomies-endpoint.php 1 month ago class.wpcom-json-api-get-taxonomy-endpoint.php 6 months ago class.wpcom-json-api-get-term-endpoint.php 6 months ago class.wpcom-json-api-list-comments-endpoint.php 1 week ago class.wpcom-json-api-list-dropdown-pages-endpoint.php 6 months ago class.wpcom-json-api-list-embeds-endpoint.php 6 months ago class.wpcom-json-api-list-media-endpoint.php 6 months ago class.wpcom-json-api-list-media-v1-1-endpoint.php 1 week ago class.wpcom-json-api-list-media-v1-2-endpoint.php 6 months ago class.wpcom-json-api-list-post-type-taxonomies-endpoint.php 6 months ago class.wpcom-json-api-list-post-types-endpoint.php 6 months ago class.wpcom-json-api-list-posts-endpoint.php 1 week ago class.wpcom-json-api-list-posts-v1-1-endpoint.php 1 week ago class.wpcom-json-api-list-posts-v1-2-endpoint.php 1 week ago class.wpcom-json-api-list-roles-endpoint.php 6 months ago class.wpcom-json-api-list-shortcodes-endpoint.php 6 months ago class.wpcom-json-api-list-terms-endpoint.php 6 months ago class.wpcom-json-api-list-users-endpoint.php 6 months ago class.wpcom-json-api-menus-v1-1-endpoint.php 1 week ago class.wpcom-json-api-post-endpoint.php 6 months ago class.wpcom-json-api-post-v1-1-endpoint.php 1 month ago class.wpcom-json-api-render-embed-endpoint.php 6 months ago class.wpcom-json-api-render-embed-reversal-endpoint.php 6 months ago class.wpcom-json-api-render-endpoint.php 2 weeks ago class.wpcom-json-api-render-shortcode-endpoint.php 6 months ago class.wpcom-json-api-sharing-buttons-endpoint.php 1 week ago class.wpcom-json-api-site-settings-endpoint.php 2 months ago class.wpcom-json-api-site-settings-v1-2-endpoint.php 6 months ago class.wpcom-json-api-site-settings-v1-3-endpoint.php 6 months ago class.wpcom-json-api-site-settings-v1-4-endpoint.php 2 months ago class.wpcom-json-api-site-user-endpoint.php 6 months ago class.wpcom-json-api-taxonomy-endpoint.php 6 months ago class.wpcom-json-api-update-comment-endpoint.php 4 months ago class.wpcom-json-api-update-customcss.php 6 months ago class.wpcom-json-api-update-media-endpoint.php 6 months ago class.wpcom-json-api-update-media-v1-1-endpoint.php 1 week ago class.wpcom-json-api-update-post-endpoint.php 1 week ago class.wpcom-json-api-update-post-v1-1-endpoint.php 1 week ago class.wpcom-json-api-update-post-v1-2-endpoint.php 1 week ago class.wpcom-json-api-update-site-homepage-endpoint.php 6 months ago class.wpcom-json-api-update-site-logo-endpoint.php 6 months ago class.wpcom-json-api-update-taxonomy-endpoint.php 5 months ago class.wpcom-json-api-update-term-endpoint.php 6 months ago class.wpcom-json-api-update-user-endpoint.php 6 months ago class.wpcom-json-api-upload-media-endpoint.php 6 months ago class.wpcom-json-api-upload-media-v1-1-endpoint.php 6 months ago
class.wpcom-json-api-get-comments-tree-endpoint.php
202 lines
1 <?php // phpcs:ignore WordPress.Files.FileName.InvalidClassFileName
2
3 if ( ! defined( 'ABSPATH' ) ) {
4 exit( 0 );
5 }
6
7 new WPCOM_JSON_API_Get_Comments_Tree_Endpoint(
8 array(
9 'description' => 'Get a comments tree for site.',
10 'max_version' => '1',
11 'new_version' => '1.1',
12 'group' => 'comments-tree',
13 'stat' => 'comments-tree:1',
14
15 'method' => 'GET',
16 'path' => '/sites/%s/comments-tree',
17 'path_labels' => array(
18 '$site' => '(int|string) Site ID or domain',
19 ),
20 'query_parameters' => array(
21 'status' => '(string) Filter returned comments based on this value (allowed values: all, approved, unapproved, pending, trash, spam).',
22 ),
23 'response_format' => array(
24 'comments_count' => '(int) Total number of comments on the site',
25 'comments_tree' => '(array) Array of arrays representing the comments tree for given site (max 50000)',
26 'trackbacks_count' => '(int) Total number of trackbacks on the site',
27 'trackbacks_tree' => '(array) Array of arrays representing the trackbacks tree for given site (max 50000)',
28 'pingbacks_count' => '(int) Total number of pingbacks on the site',
29 'pingbacks_tree' => '(array) Array of arrays representing the pingbacks tree for given site (max 50000)',
30 ),
31
32 'example_request' => 'https://public-api.wordpress.com/rest/v1/sites/en.blog.wordpress.com/comments-tree?status=approved',
33 )
34 );
35 /**
36 * GET comments tree endpoint class.
37 *
38 * @phan-constructor-used-for-side-effects
39 */
40 class WPCOM_JSON_API_Get_Comments_Tree_Endpoint extends WPCOM_JSON_API_Endpoint {
41 /**
42 * Retrieves a list of comment data for a given site.
43 *
44 * @param string $status Filter by status: all, approved, pending, spam or trash.
45 * @param int $start_at first comment to search from going back in time.
46 *
47 * @return array
48 */
49 public function get_site_tree( $status, $start_at = PHP_INT_MAX ) {
50 global $wpdb;
51 $max_comment_count = 50000;
52 $db_status = $this->get_comment_db_status( $status );
53
54 $db_comment_rows = $wpdb->get_results(
55 $wpdb->prepare(
56 'SELECT comment_ID, comment_post_ID, comment_parent, comment_type ' .
57 "FROM $wpdb->comments AS comments " .
58 "INNER JOIN $wpdb->posts AS posts ON comments.comment_post_ID = posts.ID " .
59 "WHERE comment_ID <= %d AND ( %s = 'all' OR comment_approved = %s ) " .
60 'ORDER BY comment_ID DESC ' .
61 'LIMIT %d',
62 (int) $start_at,
63 $db_status,
64 $db_status,
65 $max_comment_count
66 ),
67 ARRAY_N
68 );
69
70 $comments = array();
71 $trackbacks = array();
72 $pingbacks = array();
73 foreach ( $db_comment_rows as $row ) {
74 list( $comment_id, $comment_post_id, $comment_parent, $comment_type ) = $row;
75 switch ( $comment_type ) {
76 case 'trackback':
77 $trackbacks[] = array( $comment_id, $comment_post_id, $comment_parent );
78 break;
79 case 'pingback':
80 $pingbacks[] = array( $comment_id, $comment_post_id, $comment_parent );
81 break;
82 default:
83 $comments[] = array( $comment_id, $comment_post_id, $comment_parent );
84 }
85 }
86
87 return array(
88 'comments_count' => $this->get_site_tree_total_count( $status, 'comment' ),
89 'comments_tree' => array_map( array( $this, 'array_map_all_as_ints' ), $comments ),
90 'trackbacks_count' => $this->get_site_tree_total_count( $status, 'trackback' ),
91 'trackbacks_tree' => array_map( array( $this, 'array_map_all_as_ints' ), $trackbacks ),
92 'pingbacks_count' => $this->get_site_tree_total_count( $status, 'pingback' ),
93 'pingbacks_tree' => array_map( array( $this, 'array_map_all_as_ints' ), $pingbacks ),
94 );
95 }
96
97 /**
98 * Ensure all values are integers.
99 *
100 * @param array $comments Collection of comments.
101 *
102 * @return array Comments with values as integers.
103 */
104 public function array_map_all_as_ints( $comments ) {
105 return array_map( 'intval', $comments );
106 }
107
108 /**
109 * Retrieves a total count of comments by type for the given site.
110 *
111 * @param string $status Filter by status: all, approved, pending, spam or trash.
112 * @param string $type Comment type: 'trackback', 'pingback', or 'comment'.
113 *
114 * @return int Total count of comments for a site.
115 */
116 public function get_site_tree_total_count( $status, $type ) {
117 global $wpdb;
118
119 $db_status = $this->get_comment_db_status( $status );
120 $type = $this->get_sanitized_comment_type( $type );
121
122 $result = $wpdb->get_var(
123 $wpdb->prepare(
124 'SELECT COUNT(1) ' .
125 "FROM $wpdb->comments AS comments " .
126 "INNER JOIN $wpdb->posts AS posts ON comments.comment_post_ID = posts.ID " .
127 "WHERE comment_type = %s AND ( %s = 'all' OR comment_approved = %s )",
128 $type,
129 $db_status,
130 $db_status
131 )
132 );
133 return (int) $result;
134 }
135
136 /**
137 * Ensure a valid status is converted to a database-supported value if necessary.
138 *
139 * @param string $status Should be one of: all, approved, pending, spam or trash.
140 *
141 * @return string Corresponding value that exists in database.
142 */
143 public function get_comment_db_status( $status ) {
144 if ( 'approved' === $status ) {
145 return '1';
146 }
147 if ( 'pending' === $status || 'unapproved' === $status ) {
148 return '0';
149 }
150 return $status;
151 }
152
153 /**
154 * Determine if the passed comment status is valid or not.
155 *
156 * @param string $status - comment status.
157 *
158 * @return boolean
159 */
160 public function validate_status_param( $status ) {
161 return in_array( $status, array( 'all', 'approved', 'unapproved', 'pending', 'spam', 'trash' ), true );
162 }
163
164 /**
165 * Sanitize a given comment type.
166 *
167 * @param string $type Comment type: can be 'trackback', 'pingback', or 'comment'.
168 *
169 * @return string Sanitized comment type.
170 */
171 public function get_sanitized_comment_type( $type = 'comment' ) {
172 if ( in_array( $type, array( 'trackback', 'pingback', 'comment' ), true ) ) {
173 return $type;
174 }
175 return 'comment';
176 }
177
178 /**
179 * Endpoint callback for /sites/%s/comments-tree
180 *
181 * @param string $path - the api path.
182 * @param int $blog_id - the blog id.
183 *
184 * @return array Site tree results by status.
185 */
186 public function callback( $path = '', $blog_id = 0 ) {
187 $blog_id = $this->api->switch_to_blog_and_validate_user( $this->api->get_blog_id( $blog_id ) );
188 if ( is_wp_error( $blog_id ) ) {
189 return $blog_id;
190 }
191
192 $args = $this->query_args();
193 $comment_status = empty( $args['status'] ) ? 'all' : $args['status'];
194
195 if ( ! $this->validate_status_param( $comment_status ) ) {
196 return new WP_Error( 'invalid_status', "Invalid comment status value provided: '$comment_status'.", 400 );
197 }
198
199 return $this->get_site_tree( $comment_status );
200 }
201 }
202