2024-06-27 12:10:38 +00:00
|
|
|
<?php
|
2024-10-09 12:44:17 +00:00
|
|
|
/**
|
|
|
|
* Announce handler file.
|
|
|
|
*
|
|
|
|
* @package Activitypub
|
|
|
|
*/
|
|
|
|
|
2024-06-27 12:10:38 +00:00
|
|
|
namespace Activitypub\Handler;
|
|
|
|
|
|
|
|
use Activitypub\Http;
|
2024-10-09 12:44:17 +00:00
|
|
|
use Activitypub\Comment;
|
|
|
|
use Activitypub\Collection\Interactions;
|
2024-06-27 12:10:38 +00:00
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
use function Activitypub\object_to_uri;
|
2024-06-27 12:10:38 +00:00
|
|
|
use function Activitypub\is_activity_public;
|
|
|
|
|
|
|
|
/**
|
2024-10-09 12:44:17 +00:00
|
|
|
* Handle Create requests.
|
2024-06-27 12:10:38 +00:00
|
|
|
*/
|
|
|
|
class Announce {
|
|
|
|
/**
|
2024-10-09 12:44:17 +00:00
|
|
|
* Initialize the class, registering WordPress hooks.
|
2024-06-27 12:10:38 +00:00
|
|
|
*/
|
|
|
|
public static function init() {
|
|
|
|
\add_action(
|
|
|
|
'activitypub_inbox_announce',
|
|
|
|
array( self::class, 'handle_announce' ),
|
|
|
|
10,
|
|
|
|
3
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-10-09 12:44:17 +00:00
|
|
|
* Handles "Announce" requests.
|
2024-06-27 12:10:38 +00:00
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @param array $announcement The activity-object.
|
|
|
|
* @param int $user_id The id of the local blog-user.
|
|
|
|
* @param \Activitypub\Activity\Activity $activity The activity object.
|
2024-06-27 12:10:38 +00:00
|
|
|
*/
|
2024-10-09 12:44:17 +00:00
|
|
|
public static function handle_announce( $announcement, $user_id, $activity = null ) {
|
|
|
|
// Check if Activity is public or not.
|
|
|
|
if ( ! is_activity_public( $announcement ) ) {
|
2024-06-27 12:10:38 +00:00
|
|
|
// @todo maybe send email
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
if ( ! ACTIVITYPUB_DISABLE_REACTIONS ) {
|
|
|
|
self::maybe_save_announce( $announcement, $user_id );
|
|
|
|
}
|
2024-06-27 12:10:38 +00:00
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
if ( is_string( $announcement['object'] ) ) {
|
|
|
|
$object = Http::get_remote_object( $announcement['object'] );
|
2024-06-27 12:10:38 +00:00
|
|
|
} else {
|
2024-10-09 12:44:17 +00:00
|
|
|
$object = $announcement['object'];
|
2024-06-27 12:10:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! $object || is_wp_error( $object ) ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! isset( $object['type'] ) ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$type = \strtolower( $object['type'] );
|
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
/**
|
|
|
|
* Fires after an Announce has been received.
|
|
|
|
*
|
|
|
|
* @param array $object The object.
|
|
|
|
* @param int $user_id The id of the local blog-user.
|
|
|
|
* @param array $activity The activity object.
|
|
|
|
*/
|
2024-06-27 12:10:38 +00:00
|
|
|
\do_action( 'activitypub_inbox', $object, $user_id, $type, $activity );
|
2024-10-09 12:44:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fires after an Announce of a specific type has been received.
|
|
|
|
*
|
|
|
|
* @param array $object The object.
|
|
|
|
* @param int $user_id The id of the local blog-user.
|
|
|
|
* @param array $activity The activity object.
|
|
|
|
*/
|
2024-06-27 12:10:38 +00:00
|
|
|
\do_action( "activitypub_inbox_{$type}", $object, $user_id, $activity );
|
|
|
|
}
|
2024-10-09 12:44:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Try to save the Announce.
|
|
|
|
*
|
|
|
|
* @param array $activity The activity-object.
|
|
|
|
* @param int $user_id The id of the local blog-user.
|
|
|
|
*/
|
|
|
|
public static function maybe_save_announce( $activity, $user_id ) {
|
|
|
|
$url = object_to_uri( $activity['object'] );
|
|
|
|
|
|
|
|
if ( empty( $url ) ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$exists = Comment::object_id_to_comment( esc_url_raw( $url ) );
|
|
|
|
if ( $exists ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$state = Interactions::add_reaction( $activity );
|
|
|
|
$reaction = null;
|
|
|
|
|
|
|
|
if ( $state && ! is_wp_error( $state ) ) {
|
|
|
|
$reaction = get_comment( $state );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fires after an Announce has been saved.
|
|
|
|
*
|
|
|
|
* @param array $activity The activity-object.
|
|
|
|
* @param int $user_id The id of the local blog-user.
|
|
|
|
* @param mixed $state The state of the reaction.
|
|
|
|
* @param mixed $reaction The reaction.
|
|
|
|
*/
|
|
|
|
do_action( 'activitypub_handled_announce', $activity, $user_id, $state, $reaction );
|
|
|
|
}
|
2024-06-27 12:10:38 +00:00
|
|
|
}
|