diff --git a/includes/activitypub/class-handler.php b/includes/activitypub/class-handler.php index b9961d2..0199486 100644 --- a/includes/activitypub/class-handler.php +++ b/includes/activitypub/class-handler.php @@ -26,7 +26,6 @@ class Handler { * Register all ActivityPub handlers. */ public static function register_handlers() { - Accept::init(); Announce::init(); Update::init(); diff --git a/includes/activitypub/collection/class-event-sources.php b/includes/activitypub/collection/class-event-sources.php index 314bb73..b641f53 100644 --- a/includes/activitypub/collection/class-event-sources.php +++ b/includes/activitypub/collection/class-event-sources.php @@ -25,6 +25,15 @@ class Event_Sources { */ const POST_TYPE = 'ebap_event_source'; + /** + * Init. + */ + public static function init() { + self::register_post_type(); + \add_action( 'event_bridge_for_activitypub_follow', array( self::class, 'activitypub_follow_actor' ), 10, 2 ); + \add_action( 'event_bridge_for_activitypub_unfollow', array( self::class, 'activitypub_unfollow_actor' ), 10, 2 ); + } + /** * Register the post type used to store the external event sources (i.e., followed ActivityPub actors). */ @@ -146,6 +155,8 @@ class Event_Sources { return $post_id; } + self::queue_follow_actor( $actor ); + return $event_source; } diff --git a/includes/activitypub/handler/class-create.php b/includes/activitypub/handler/class-create.php index 854a084..411bbb3 100644 --- a/includes/activitypub/handler/class-create.php +++ b/includes/activitypub/handler/class-create.php @@ -7,8 +7,10 @@ namespace Event_Bridge_For_ActivityPub\ActivityPub\Handler; -use Activitypub\Notification; use Activitypub\Collection\Actors; +use Event_Bridge_For_ActivityPub\Setup; + +use function Activitypub\is_activity_public; /** * Handle Create requests. @@ -27,23 +29,32 @@ class Create { /** * Handle "Create" requests. * - * @param array $activity The activity object. + * @param array $activity The activity-object. + * @param int $user_id The id of the local blog-user. */ - public static function handle_create( $activity ) { - if ( ! isset( $activity['object'] ) ) { + public static function handle_create( $activity, $user_id ) { + // We only process activities that are target the application user. + if ( Actors::APPLICATION_USER_ID !== $user_id ) { return; } - $object = Actors::get_by_resource( $activity['object'] ); - - if ( ! $object || is_wp_error( $object ) ) { - // If we can not find a actor, we handle the `create` activity. + // Check if Activity is public or not. + if ( ! is_activity_public( $activity ) ) { return; } - // We only expect `create` activities being answers to follow requests by the application actor. - if ( Actors::APPLICATION_USER_ID !== $object->get__id() ) { + // Check if an object is set. + if ( ! isset( $activity['object']['type'] ) || 'Event' !== isset( $activity['object']['type'] ) ) { return; } + + $transmogrifier_class = Setup::get_transmogrifier(); + + if ( ! $transmogrifier_class ) { + return; + } + + $transmogrifier = new $transmogrifier_class( $activity['object'] ); + $transmogrifier->create(); } } diff --git a/includes/activitypub/handler/class-update.php b/includes/activitypub/handler/class-update.php index 16b7559..12e3c96 100644 --- a/includes/activitypub/handler/class-update.php +++ b/includes/activitypub/handler/class-update.php @@ -9,6 +9,7 @@ namespace Event_Bridge_For_ActivityPub\ActivityPub\Handler; use Activitypub\Notification; use Activitypub\Collection\Actors; +use Activitypub\Http; /** * Handle Update requests. diff --git a/includes/activitypub/transmogrify/class-gatherpress.php b/includes/activitypub/transmogrifier/class-gatherpress.php similarity index 61% rename from includes/activitypub/transmogrify/class-gatherpress.php rename to includes/activitypub/transmogrifier/class-gatherpress.php index b94efb5..7db80d8 100644 --- a/includes/activitypub/transmogrify/class-gatherpress.php +++ b/includes/activitypub/transmogrifier/class-gatherpress.php @@ -9,7 +9,7 @@ * @license AGPL-3.0-or-later */ -namespace Event_Bridge_For_ActivityPub\Activitypub\Transmogrify; +namespace Event_Bridge_For_ActivityPub\Activitypub\Transmogrifier; use Activitypub\Activity\Extended_Object\Event; use Activitypub\Activity\Extended_Object\Place; @@ -20,7 +20,7 @@ defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore use GatherPress\Core\Event as GatherPress_Event; /** - * ActivityPub Transmogrify for the GatherPress event plugin. + * ActivityPub Transmogrifier for the GatherPress event plugin. * * Handles converting incoming external ActivityPub events to GatherPress Events. * @@ -56,6 +56,27 @@ class GatherPress { * Save the ActivityPub event object as GatherPress Event. */ public function save() { - // Insert GatherPress Event here. + // Insert new GatherPress Event post. + $post_id = wp_insert_post( + array( + 'post_title' => $this->activitypub_event->get_name(), + 'post_type' => 'gatherpress_event', + 'post_content' => $this->activitypub_event->get_content(), + 'post_excerpt' => $this->activitypub_event->get_summary(), + 'post_status' => 'publish', + ) + ); + + if ( ! $post_id || is_wp_error( $post_id ) ) { + return; + } + + $event = new \GatherPress\Core\Event( $post_id ); + $params = array( + 'datetime_start' => $this->activitypub_event->get_start_time(), + 'datetime_end' => $this->activitypub_event->get_end_time(), + 'timezone' => $this->activitypub_event->get_timezone(), + ); + $event->save_datetimes( $params ); } } diff --git a/includes/admin/class-settings-page.php b/includes/admin/class-settings-page.php index 2ad8999..ac68816 100644 --- a/includes/admin/class-settings-page.php +++ b/includes/admin/class-settings-page.php @@ -173,14 +173,6 @@ class Settings_Page { $event_terms = array_merge( $event_terms, self::get_event_terms( $event_plugin ) ); } - $args = array( - 'slug' => self::SETTINGS_SLUG, - 'event_terms' => $event_terms, - ); - - \load_template( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . 'templates/settings.php', true, $args ); - break; - case 'event-sources': $supports_event_sources = array(); foreach ( $event_plugins as $event_plugin ) { @@ -188,13 +180,19 @@ class Settings_Page { $supports_event_sources[ $event_plugin::class ] = $event_plugin->get_plugin_name(); } } + $args = array( + 'slug' => self::SETTINGS_SLUG, + 'event_terms' => $event_terms, 'supports_event_sources' => $supports_event_sources, ); + \load_template( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . 'templates/settings.php', true, $args ); + break; + case 'event-sources': wp_enqueue_script( 'thickbox' ); wp_enqueue_style( 'thickbox' ); - \load_template( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . 'templates/event-sources.php', true, $args ); + \load_template( EVENT_BRIDGE_FOR_ACTIVITYPUB_PLUGIN_DIR . 'templates/event-sources.php', true ); break; case 'welcome': default: diff --git a/includes/class-settings.php b/includes/class-settings.php index 30d3cf4..02769ae 100644 --- a/includes/class-settings.php +++ b/includes/class-settings.php @@ -95,7 +95,7 @@ class Settings { ); \register_setting( - 'event-bridge-for-activitypub-event-sources', + 'event-bridge-for-activitypub', 'event_bridge_for_activitypub_event_sources_active', array( 'type' => 'boolean', @@ -106,7 +106,7 @@ class Settings { ); \register_setting( - 'event-bridge-for-activitypub-event-sources', + 'event-bridge-for-activitypub', 'event_bridge_for_activitypub_plugin_used_for_event_source_feature', array( 'type' => 'array', @@ -115,6 +115,17 @@ class Settings { 'sanitize_callback' => array( self::class, 'sanitize_plugin_used_for_event_sources' ), ) ); + + \register_setting( + 'event-bridge-for-activitypub-event-sources', + 'event_bridge_for_activitypub_event_sources', + array( + 'type' => 'array', + 'description' => \__( 'Dummy setting', 'event-bridge-for-activitypub' ), + 'default' => array(), + 'sanitize_callback' => 'is_array', + ) + ); } /** diff --git a/includes/class-setup.php b/includes/class-setup.php index b381905..87bdb59 100644 --- a/includes/class-setup.php +++ b/includes/class-setup.php @@ -204,13 +204,17 @@ class Setup { } add_action( 'init', array( Health_Check::class, 'init' ) ); - add_action( 'init', array( Event_Sources_Collection::class, 'register_post_type' ) ); // Check if the minimum required version of the ActivityPub plugin is installed. if ( ! version_compare( $this->activitypub_plugin_version, EVENT_BRIDGE_FOR_ACTIVITYPUB_ACTIVITYPUB_PLUGIN_MIN_VERSION ) ) { return; } + if ( get_option( 'event_bridge_for_activitypub_event_sources_active' ) ) { + add_action( 'init', array( Event_Sources_Collection::class, 'init' ) ); + add_action( 'init', array( Handler::class, 'register_handlers' ) ); + } + add_filter( 'activitypub_transformer', array( $this, 'register_activitypub_event_transformer' ), 10, 3 ); } @@ -348,4 +352,22 @@ class Setup { self::activate_activitypub_support_for_active_event_plugins(); } + + /** + * Get the transmogrifier. + */ + public static function get_transmogrifier() { + $setup = self::get_instance(); + + $event_sources_active = get_option( 'event_bridge_for_activitypub_event_sources_active', false ); + $event_plugin = get_option( 'event_bridge_for_activitypub_plugin_used_for_event_source_feature', '' ); + + if ( ! $event_sources_active || ! $event_plugin ) { + return; + } + $active_event_plugins = $setup->get_active_event_plugins(); + if ( array_key_exists( $event_plugin, $active_event_plugins ) ) { + return $active_event_plugins[ $event_plugin ]->get_transmogrifier_class(); + } + } } diff --git a/includes/integrations/class-event-plugin.php b/includes/integrations/class-event-plugin.php index 756926f..6c25b1a 100644 --- a/includes/integrations/class-event-plugin.php +++ b/includes/integrations/class-event-plugin.php @@ -95,4 +95,14 @@ abstract class Event_Plugin { public static function get_activitypub_event_transformer_class(): string { return str_replace( 'Integrations', 'Activitypub\Transformer', static::class ); } + + /** + * Returns the class used for transmogrifying an Event (ActivityStreams to Event plugin transformation). + */ + public static function get_transmogrifier_class(): ?string { + if ( ! self::supports_event_sources() ) { + return null; + } + return str_replace( 'Integrations', 'Activitypub\Transmogrifier', static::class ); + } } diff --git a/templates/event-sources.php b/templates/event-sources.php index 8a03ffb..4f541a5 100644 --- a/templates/event-sources.php +++ b/templates/event-sources.php @@ -17,105 +17,8 @@ defined( 'ABSPATH' ) || exit; // @codeCoverageIgnore 'event-sources' => 'active', ) ); - -if ( ! isset( $args ) || ! array_key_exists( 'supports_event_sources', $args ) ) { - return; -} - -if ( ! current_user_can( 'manage_options' ) ) { - return; -} - -$event_plugins_supporting_event_sources = $args['supports_event_sources']; - -$selected_plugin = \get_option( 'event_bridge_for_activitypub_plugin_used_for_event_source_feature', '' ); -$event_sources_active = \get_option( 'event_bridge_for_activitypub_event_sources_active', false ); ?> -
-+ + | ++ + > + + | +
---|---|
+ + | ++ + + | +