post_author = Users::BLOG_USER_ID; if ( is_single_user() ) { self::send_activity( $wp_post, $type ); } else { self::send_announce( $wp_post, $type ); } } /** * Send Activities to followers and mentioned users. * * @param WP_Post $wp_post The ActivityPub Post. * @param string $type The Activity-Type. * * @return void */ public static function send_activity( WP_Post $wp_post, $type ) { if ( is_user_disabled( $wp_post->post_author ) ) { return; } $transformer = \Activitypub\Transformers_Manager::instance()->get_transformer( $wp_post ); $transformer->set_wp_post( $wp_post ); $transformer->to_object(); $activity = new Activity(); $activity->set_type( $type ); $activity->set_object( $object ); $follower_inboxes = Followers::get_inboxes( $wp_post->post_author ); $mentioned_inboxes = Mention::get_inboxes( $activity->get_cc() ); $inboxes = array_merge( $follower_inboxes, $mentioned_inboxes ); $inboxes = array_unique( $inboxes ); $json = $activity->to_json(); foreach ( $inboxes as $inbox ) { safe_remote_post( $inbox, $json, $wp_post->post_author ); } } /** * Send Announces to followers and mentioned users. * * @param WP_Post $wp_post The ActivityPub Post. * @param string $type The Activity-Type. * * @return void */ public static function send_announce( WP_Post $wp_post, $type ) { if ( ! in_array( $type, array( 'Create', 'Update' ), true ) ) { return; } if ( is_user_disabled( Users::BLOG_USER_ID ) ) { return; } $transformer = \Activitypub\Transformers_Manager::instance()->get_transformer( $wp_post ); $transformer->set_wp_post( $wp_post ); $transformer->to_object(); $activity = new Activity(); $activity->set_type( 'Announce' ); // to pre-fill attributes like "published" and "id" $activity->set_object( $object ); // send only the id $activity->set_object( $object->get_id() ); $follower_inboxes = Followers::get_inboxes( $wp_post->post_author ); $mentioned_inboxes = Mention::get_inboxes( $activity->get_cc() ); $inboxes = array_merge( $follower_inboxes, $mentioned_inboxes ); $inboxes = array_unique( $inboxes ); $json = $activity->to_json(); foreach ( $inboxes as $inbox ) { safe_remote_post( $inbox, $json, $wp_post->post_author ); } } }