summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYury German <blueknight@gentoo.org>2019-05-22 01:01:36 -0400
committerYury German <blueknight@gentoo.org>2019-05-22 01:01:36 -0400
commit0914c92da22824025992c368c745546e41fbeb84 (patch)
tree965f6adf3b725e56d559fe4a93eff02281499dcc /plugins/jetpack/class.jetpack-bbpress-json-api-compat.php
parentDeleting plugins for update (diff)
downloadblogs-gentoo-0914c92da22824025992c368c745546e41fbeb84.tar.gz
blogs-gentoo-0914c92da22824025992c368c745546e41fbeb84.tar.bz2
blogs-gentoo-0914c92da22824025992c368c745546e41fbeb84.zip
Adding Plugins
Updating the following akismet.4.1.2, google-authenticator.0.52, jetpack.7.3.1 Signed-off-by: Yury German <blueknight@gentoo.org>
Diffstat (limited to 'plugins/jetpack/class.jetpack-bbpress-json-api-compat.php')
-rw-r--r--plugins/jetpack/class.jetpack-bbpress-json-api-compat.php98
1 files changed, 98 insertions, 0 deletions
diff --git a/plugins/jetpack/class.jetpack-bbpress-json-api-compat.php b/plugins/jetpack/class.jetpack-bbpress-json-api-compat.php
new file mode 100644
index 00000000..0038874b
--- /dev/null
+++ b/plugins/jetpack/class.jetpack-bbpress-json-api-compat.php
@@ -0,0 +1,98 @@
+<?php
+/**
+* bbPress & Jetpack REST API Compatibility
+* Enables bbPress to work with the Jetpack REST API
+*/
+class bbPress_Jetpack_REST_API {
+
+ private static $instance;
+
+ public static function instance() {
+ if ( isset( self::$instance ) )
+ return self::$instance;
+
+ self::$instance = new self;
+ }
+
+ 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' ) );
+ }
+
+ function allow_bbpress_post_types( $allowed_post_types ) {
+ $allowed_post_types[] = 'forum';
+ $allowed_post_types[] = 'topic';
+ $allowed_post_types[] = 'reply';
+ return $allowed_post_types;
+ }
+
+ 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;
+ }
+
+ function adjust_meta_caps( $caps, $cap, $user_id, $args ) {
+
+ // only run for REST API requests
+ if ( ! defined( 'REST_API_REQUEST' ) || ! REST_API_REQUEST )
+ return $caps;
+
+ // 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' ) ) || empty( $args[1] ) || false === strpos( $args[1], '_bbp_' ) )
+ 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;
+ }
+
+}
+
+bbPress_Jetpack_REST_API::instance();