PluginProbe ʕ •ᴥ•ʔ
Jetpack – WP Security, Backup, Speed, & Growth / 11.1.1
Jetpack – WP Security, Backup, Speed, & Growth v11.1.1
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 3 years ago class.wpcom-json-api-add-widget-endpoint.php 4 years ago class.wpcom-json-api-autosave-post-v1-1-endpoint.php 5 years ago class.wpcom-json-api-bulk-delete-post-endpoint.php 4 years ago class.wpcom-json-api-bulk-restore-post-endpoint.php 4 years ago class.wpcom-json-api-bulk-update-comments-endpoint.php 4 years ago class.wpcom-json-api-comment-endpoint.php 4 years ago class.wpcom-json-api-delete-media-endpoint.php 4 years ago class.wpcom-json-api-delete-media-v1-1-endpoint.php 4 years ago class.wpcom-json-api-edit-media-v1-2-endpoint.php 4 years ago class.wpcom-json-api-get-autosave-v1-1-endpoint.php 5 years ago class.wpcom-json-api-get-comment-counts-endpoint.php 4 years ago class.wpcom-json-api-get-comment-endpoint.php 4 years ago class.wpcom-json-api-get-comment-history-endpoint.php 4 years ago class.wpcom-json-api-get-comments-tree-endpoint.php 4 years ago class.wpcom-json-api-get-comments-tree-v1-1-endpoint.php 4 years ago class.wpcom-json-api-get-comments-tree-v1-2-endpoint.php 4 years ago class.wpcom-json-api-get-customcss.php 4 years ago class.wpcom-json-api-get-media-endpoint.php 4 years ago class.wpcom-json-api-get-media-v1-1-endpoint.php 4 years ago class.wpcom-json-api-get-media-v1-2-endpoint.php 4 years ago class.wpcom-json-api-get-post-counts-v1-1-endpoint.php 4 years ago class.wpcom-json-api-get-post-endpoint.php 4 years ago class.wpcom-json-api-get-post-v1-1-endpoint.php 4 years ago class.wpcom-json-api-get-site-endpoint.php 4 years ago class.wpcom-json-api-get-site-v1-2-endpoint.php 4 years ago class.wpcom-json-api-get-taxonomies-endpoint.php 4 years ago class.wpcom-json-api-get-taxonomy-endpoint.php 4 years ago class.wpcom-json-api-get-term-endpoint.php 4 years ago class.wpcom-json-api-list-comments-endpoint.php 4 years ago class.wpcom-json-api-list-embeds-endpoint.php 4 years ago class.wpcom-json-api-list-media-endpoint.php 4 years ago class.wpcom-json-api-list-media-v1-1-endpoint.php 4 years ago class.wpcom-json-api-list-media-v1-2-endpoint.php 4 years ago class.wpcom-json-api-list-post-type-taxonomies-endpoint.php 4 years ago class.wpcom-json-api-list-post-types-endpoint.php 4 years ago class.wpcom-json-api-list-posts-endpoint.php 4 years ago class.wpcom-json-api-list-posts-v1-1-endpoint.php 4 years ago class.wpcom-json-api-list-posts-v1-2-endpoint.php 4 years ago class.wpcom-json-api-list-roles-endpoint.php 4 years ago class.wpcom-json-api-list-shortcodes-endpoint.php 4 years ago class.wpcom-json-api-list-terms-endpoint.php 4 years ago class.wpcom-json-api-list-users-endpoint.php 4 years ago class.wpcom-json-api-menus-v1-1-endpoint.php 4 years ago class.wpcom-json-api-post-endpoint.php 3 years ago class.wpcom-json-api-post-v1-1-endpoint.php 3 years ago class.wpcom-json-api-render-embed-endpoint.php 4 years ago class.wpcom-json-api-render-embed-reversal-endpoint.php 4 years ago class.wpcom-json-api-render-endpoint.php 4 years ago class.wpcom-json-api-render-shortcode-endpoint.php 4 years ago class.wpcom-json-api-sharing-buttons-endpoint.php 4 years ago class.wpcom-json-api-site-settings-endpoint.php 3 years ago class.wpcom-json-api-site-settings-v1-2-endpoint.php 4 years ago class.wpcom-json-api-site-settings-v1-3-endpoint.php 4 years ago class.wpcom-json-api-site-settings-v1-4-endpoint.php 4 years ago class.wpcom-json-api-site-user-endpoint.php 4 years ago class.wpcom-json-api-taxonomy-endpoint.php 4 years ago class.wpcom-json-api-update-comment-endpoint.php 4 years ago class.wpcom-json-api-update-customcss.php 4 years ago class.wpcom-json-api-update-media-endpoint.php 4 years ago class.wpcom-json-api-update-media-v1-1-endpoint.php 4 years ago class.wpcom-json-api-update-post-endpoint.php 4 years ago class.wpcom-json-api-update-post-v1-1-endpoint.php 4 years ago class.wpcom-json-api-update-post-v1-2-endpoint.php 4 years ago class.wpcom-json-api-update-site-homepage-endpoint.php 4 years ago class.wpcom-json-api-update-site-logo-endpoint.php 4 years ago class.wpcom-json-api-update-taxonomy-endpoint.php 4 years ago class.wpcom-json-api-update-term-endpoint.php 4 years ago class.wpcom-json-api-update-user-endpoint.php 4 years ago class.wpcom-json-api-upload-media-endpoint.php 4 years ago class.wpcom-json-api-upload-media-v1-1-endpoint.php 4 years ago
class.wpcom-json-api-get-comments-tree-endpoint.php
196 lines
1 <?php // phpcs:ignore WordPress.Files.FileName.InvalidClassFileName
2
3 new WPCOM_JSON_API_Get_Comments_Tree_Endpoint(
4 array(
5 'description' => 'Get a comments tree for site.',
6 'max_version' => '1',
7 'new_version' => '1.1',
8 'group' => 'comments-tree',
9 'stat' => 'comments-tree:1',
10
11 'method' => 'GET',
12 'path' => '/sites/%s/comments-tree',
13 'path_labels' => array(
14 '$site' => '(int|string) Site ID or domain',
15 ),
16 'query_parameters' => array(
17 'status' => '(string) Filter returned comments based on this value (allowed values: all, approved, unapproved, pending, trash, spam).',
18 ),
19 'response_format' => array(
20 'comments_count' => '(int) Total number of comments on the site',
21 'comments_tree' => '(array) Array of arrays representing the comments tree for given site (max 50000)',
22 'trackbacks_count' => '(int) Total number of trackbacks on the site',
23 'trackbacks_tree' => '(array) Array of arrays representing the trackbacks tree for given site (max 50000)',
24 'pingbacks_count' => '(int) Total number of pingbacks on the site',
25 'pingbacks_tree' => '(array) Array of arrays representing the pingbacks tree for given site (max 50000)',
26 ),
27
28 'example_request' => 'https://public-api.wordpress.com/rest/v1/sites/en.blog.wordpress.com/comments-tree?status=approved',
29 )
30 );
31 /**
32 * GET comments tree endpoint class.
33 */
34 class WPCOM_JSON_API_Get_Comments_Tree_Endpoint extends WPCOM_JSON_API_Endpoint {
35 /**
36 * Retrieves a list of comment data for a given site.
37 *
38 * @param string $status Filter by status: all, approved, pending, spam or trash.
39 * @param int $start_at first comment to search from going back in time.
40 *
41 * @return array
42 */
43 public function get_site_tree( $status, $start_at = PHP_INT_MAX ) {
44 global $wpdb;
45 $max_comment_count = 50000;
46 $db_status = $this->get_comment_db_status( $status );
47
48 $db_comment_rows = $wpdb->get_results(
49 $wpdb->prepare(
50 'SELECT comment_ID, comment_post_ID, comment_parent, comment_type ' .
51 "FROM $wpdb->comments AS comments " .
52 "INNER JOIN $wpdb->posts AS posts ON comments.comment_post_ID = posts.ID " .
53 "WHERE comment_ID <= %d AND ( %s = 'all' OR comment_approved = %s ) " .
54 'ORDER BY comment_ID DESC ' .
55 'LIMIT %d',
56 (int) $start_at,
57 $db_status,
58 $db_status,
59 $max_comment_count
60 ),
61 ARRAY_N
62 );
63
64 $comments = array();
65 $trackbacks = array();
66 $pingbacks = array();
67 foreach ( $db_comment_rows as $row ) {
68 list( $comment_id, $comment_post_id, $comment_parent, $comment_type ) = $row;
69 switch ( $comment_type ) {
70 case 'trackback':
71 $trackbacks[] = array( $comment_id, $comment_post_id, $comment_parent );
72 break;
73 case 'pingback':
74 $pingbacks[] = array( $comment_id, $comment_post_id, $comment_parent );
75 break;
76 default:
77 $comments[] = array( $comment_id, $comment_post_id, $comment_parent );
78 }
79 }
80
81 return array(
82 'comments_count' => $this->get_site_tree_total_count( $status, 'comment' ),
83 'comments_tree' => array_map( array( $this, 'array_map_all_as_ints' ), $comments ),
84 'trackbacks_count' => $this->get_site_tree_total_count( $status, 'trackback' ),
85 'trackbacks_tree' => array_map( array( $this, 'array_map_all_as_ints' ), $trackbacks ),
86 'pingbacks_count' => $this->get_site_tree_total_count( $status, 'pingback' ),
87 'pingbacks_tree' => array_map( array( $this, 'array_map_all_as_ints' ), $pingbacks ),
88 );
89 }
90
91 /**
92 * Ensure all values are integers.
93 *
94 * @param array $comments Collection of comments.
95 *
96 * @return array Comments with values as integers.
97 */
98 public function array_map_all_as_ints( $comments ) {
99 return array_map( 'intval', $comments );
100 }
101
102 /**
103 * Retrieves a total count of comments by type for the given site.
104 *
105 * @param string $status Filter by status: all, approved, pending, spam or trash.
106 * @param string $type Comment type: 'trackback', 'pingback', or 'comment'.
107 *
108 * @return int Total count of comments for a site.
109 */
110 public function get_site_tree_total_count( $status, $type ) {
111 global $wpdb;
112
113 $db_status = $this->get_comment_db_status( $status );
114 $type = $this->get_sanitized_comment_type( $type );
115
116 $result = $wpdb->get_var(
117 $wpdb->prepare(
118 'SELECT COUNT(1) ' .
119 "FROM $wpdb->comments AS comments " .
120 "INNER JOIN $wpdb->posts AS posts ON comments.comment_post_ID = posts.ID " .
121 "WHERE comment_type = %s AND ( %s = 'all' OR comment_approved = %s )",
122 $type,
123 $db_status,
124 $db_status
125 )
126 );
127 return (int) $result;
128 }
129
130 /**
131 * Ensure a valid status is converted to a database-supported value if necessary.
132 *
133 * @param string $status Should be one of: all, approved, pending, spam or trash.
134 *
135 * @return string Corresponding value that exists in database.
136 */
137 public function get_comment_db_status( $status ) {
138 if ( 'approved' === $status ) {
139 return '1';
140 }
141 if ( 'pending' === $status || 'unapproved' === $status ) {
142 return '0';
143 }
144 return $status;
145 }
146
147 /**
148 * Determine if the passed comment status is valid or not.
149 *
150 * @param string $status - comment status.
151 *
152 * @return boolean
153 */
154 public function validate_status_param( $status ) {
155 return in_array( $status, array( 'all', 'approved', 'unapproved', 'pending', 'spam', 'trash' ), true );
156 }
157
158 /**
159 * Sanitize a given comment type.
160 *
161 * @param string $type Comment type: can be 'trackback', 'pingback', or 'comment'.
162 *
163 * @return string Sanitized comment type.
164 */
165 public function get_sanitized_comment_type( $type = 'comment' ) {
166 if ( in_array( $type, array( 'trackback', 'pingback', 'comment' ), true ) ) {
167 return $type;
168 }
169 return 'comment';
170 }
171
172 /**
173 * Endpoint callback for /sites/%s/comments-tree
174 *
175 * @param string $path - the api path.
176 * @param int $blog_id - the blog id.
177 *
178 * @return array Site tree results by status.
179 */
180 public function callback( $path = '', $blog_id = 0 ) {
181 $blog_id = $this->api->switch_to_blog_and_validate_user( $this->api->get_blog_id( $blog_id ) );
182 if ( is_wp_error( $blog_id ) ) {
183 return $blog_id;
184 }
185
186 $args = $this->query_args();
187 $comment_status = empty( $args['status'] ) ? 'all' : $args['status'];
188
189 if ( ! $this->validate_status_param( $comment_status ) ) {
190 return new WP_Error( 'invalid_status', "Invalid comment status value provided: '$comment_status'.", 400 );
191 }
192
193 return $this->get_site_tree( $comment_status );
194 }
195 }
196