summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/jetpack/3rd-party/class-jetpack-bbpress-rest-api.php')
-rw-r--r--plugins/jetpack/3rd-party/class-jetpack-bbpress-rest-api.php161
1 files changed, 161 insertions, 0 deletions
diff --git a/plugins/jetpack/3rd-party/class-jetpack-bbpress-rest-api.php b/plugins/jetpack/3rd-party/class-jetpack-bbpress-rest-api.php
new file mode 100644
index 00000000..4943bcd5
--- /dev/null
+++ b/plugins/jetpack/3rd-party/class-jetpack-bbpress-rest-api.php
@@ -0,0 +1,161 @@
+<?php
+/**
+ * REST API Compatibility: bbPress & Jetpack
+ * Enables bbPress to work with the Jetpack REST API
+ *
+ * @package automattic/jetpack
+ */
+
+/**
+ * REST API Compatibility: bbPress.
+ */
+class Jetpack_BbPress_REST_API {
+
+ /**
+ * Singleton
+ *
+ * @var Jetpack_BbPress_REST_API.
+ */
+ private static $instance;
+
+ /**
+ * Returns or creates the singleton.
+ *
+ * @return Jetpack_BbPress_REST_API
+ */
+ public static function instance() {
+ if ( isset( self::$instance ) ) {
+ return self::$instance;
+ }
+
+ self::$instance = new self();
+ }
+
+ /**
+ * Jetpack_BbPress_REST_API constructor.
+ */
+ private function __construct() {
+ add_filter( 'rest_api_allowed_post_types', array( $this, 'allow_bbpress_post_types' ) );
+ add_filter( 'bbp_map_meta_caps', array( $this, 'adjust_meta_caps' ), 10, 4 );
+ add_filter( 'rest_api_allowed_public_metadata', array( $this, 'allow_bbpress_public_metadata' ) );
+ }
+
+ /**
+ * Adds the bbPress post types to the rest_api_allowed_post_types filter.
+ *
+ * @param array $allowed_post_types Allowed post types.
+ *
+ * @return array
+ */
+ public function allow_bbpress_post_types( $allowed_post_types ) {
+ $allowed_post_types[] = 'forum';
+ $allowed_post_types[] = 'topic';
+ $allowed_post_types[] = 'reply';
+ return $allowed_post_types;
+ }
+
+ /**
+ * Adds the bbpress meta keys to the rest_api_allowed_public_metadata filter.
+ *
+ * @param array $allowed_meta_keys Allowed meta keys.
+ *
+ * @return array
+ */
+ public function allow_bbpress_public_metadata( $allowed_meta_keys ) {
+ $allowed_meta_keys[] = '_bbp_forum_id';
+ $allowed_meta_keys[] = '_bbp_topic_id';
+ $allowed_meta_keys[] = '_bbp_status';
+ $allowed_meta_keys[] = '_bbp_forum_type';
+ $allowed_meta_keys[] = '_bbp_forum_subforum_count';
+ $allowed_meta_keys[] = '_bbp_reply_count';
+ $allowed_meta_keys[] = '_bbp_total_reply_count';
+ $allowed_meta_keys[] = '_bbp_topic_count';
+ $allowed_meta_keys[] = '_bbp_total_topic_count';
+ $allowed_meta_keys[] = '_bbp_topic_count_hidden';
+ $allowed_meta_keys[] = '_bbp_last_topic_id';
+ $allowed_meta_keys[] = '_bbp_last_reply_id';
+ $allowed_meta_keys[] = '_bbp_last_active_time';
+ $allowed_meta_keys[] = '_bbp_last_active_id';
+ $allowed_meta_keys[] = '_bbp_sticky_topics';
+ $allowed_meta_keys[] = '_bbp_voice_count';
+ $allowed_meta_keys[] = '_bbp_reply_count_hidden';
+ $allowed_meta_keys[] = '_bbp_anonymous_reply_count';
+
+ return $allowed_meta_keys;
+ }
+
+ /**
+ * Adds the needed caps to the bbp_map_meta_caps filter.
+ *
+ * @param array $caps Capabilities for meta capability.
+ * @param string $cap Capability name.
+ * @param int $user_id User id.
+ * @param array $args Arguments.
+ *
+ * @return array
+ */
+ public function adjust_meta_caps( $caps, $cap, $user_id, $args ) {
+
+ // Return early if not a REST request or if not meta bbPress caps.
+ if ( $this->should_adjust_meta_caps_return_early( $caps, $cap, $user_id, $args ) ) {
+ return $caps;
+ }
+
+ // $args[0] could be a post ID or a post_type string.
+ if ( is_int( $args[0] ) ) {
+ $_post = get_post( $args[0] );
+ if ( ! empty( $_post ) ) {
+ $post_type = get_post_type_object( $_post->post_type );
+ }
+ } elseif ( is_string( $args[0] ) ) {
+ $post_type = get_post_type_object( $args[0] );
+ }
+
+ // no post type found, bail.
+ if ( empty( $post_type ) ) {
+ return $caps;
+ }
+
+ // reset the needed caps.
+ $caps = array();
+
+ // Add 'do_not_allow' cap if user is spam or deleted.
+ if ( bbp_is_user_inactive( $user_id ) ) {
+ $caps[] = 'do_not_allow';
+
+ // Moderators can always edit meta.
+ } elseif ( user_can( $user_id, 'moderate' ) ) {
+ $caps[] = 'moderate';
+
+ // Unknown so map to edit_posts.
+ } else {
+ $caps[] = $post_type->cap->edit_posts;
+ }
+
+ return $caps;
+ }
+
+ /**
+ * Should adjust_meta_caps return early?
+ *
+ * @param array $caps Capabilities for meta capability.
+ * @param string $cap Capability name.
+ * @param int $user_id User id.
+ * @param array $args Arguments.
+ *
+ * @return bool
+ */
+ private function should_adjust_meta_caps_return_early( $caps, $cap, $user_id, $args ) {
+ // only run for REST API requests.
+ if ( ! defined( 'REST_API_REQUEST' ) || ! REST_API_REQUEST ) {
+ return true;
+ }
+
+ // only modify caps for meta caps and for bbPress meta keys.
+ if ( ! in_array( $cap, array( 'edit_post_meta', 'delete_post_meta', 'add_post_meta' ), true ) || empty( $args[1] ) || false === strpos( $args[1], '_bbp_' ) ) {
+ return true;
+ }
+
+ return false;
+ }
+}