ID, '_activitypub_activity_type', true ) ) { return; } $actor_post = Remote_Actors::get_by_uri( object_to_uri( $accept['object']['object'] ) ); if ( \is_wp_error( $actor_post ) ) { return; } $user_id = is_array( $user_ids ) ? reset( $user_ids ) : $user_ids; $result = Following::accept( $actor_post, $user_id ); $success = ! \is_wp_error( $result ); /** * Fires after an ActivityPub Accept activity has been handled. * * @param array $accept The ActivityPub activity data. * @param int[] $user_ids The local user IDs. * @param bool $success True on success, false otherwise. * @param \WP_Post|\WP_Error $result The remote actor post or error. */ \do_action( 'activitypub_handled_accept', $accept, (array) $user_ids, $success, $result ); } /** * Validate the object. * * @param bool $valid The validation state. * @param string $param The object parameter. * @param \WP_REST_Request $request The request object. * * @return bool The validation state: true if valid, false if not. */ public static function validate_object( $valid, $param, $request ) { $activity = $request->get_json_params(); if ( empty( $activity['type'] ) ) { return false; } if ( 'Accept' !== $activity['type'] ) { return $valid; } if ( ! isset( $activity['actor'], $activity['object'] ) ) { return false; } if ( ! \is_array( $activity['object'] ) ) { return false; } if ( ! isset( $activity['object']['id'], $activity['object']['type'], $activity['object']['actor'], $activity['object']['object'] ) ) { return false; } return $valid; } }