wordpress-event-bridge-for-.../includes/activitypub/handler/class-delete.php

60 lines
1.3 KiB
PHP
Raw Normal View History

<?php
/**
* Delete handler file.
*
* @package Event_Bridge_For_ActivityPub
*/
namespace Event_Bridge_For_ActivityPub\ActivityPub\Handler;
use Activitypub\Collection\Actors;
use Event_Bridge_For_ActivityPub\Event_Sources;
2024-12-14 14:46:00 +01:00
use Event_Bridge_For_ActivityPub\Setup;
2024-12-25 14:21:25 +01:00
use function Activitypub\object_to_uri;
/**
* Handle Delete requests.
*/
class Delete {
/**
* Initialize the class, registering the handler for incoming `Delete` activities to the ActivityPub plugin.
*/
public static function init() {
\add_action(
'activitypub_inbox_delete',
2024-12-14 14:46:00 +01:00
array( self::class, 'handle_delete' ),
15,
2
);
}
/**
* Handle "Follow" requests.
*
2024-12-14 14:46:00 +01:00
* @param array $activity The activity-object.
* @param int $user_id The id of the local blog-user.
*/
2024-12-14 14:46:00 +01:00
public static function handle_delete( $activity, $user_id ) {
// We only process activities that are target to the application user.
2024-12-15 13:42:57 +01:00
if ( Actors::BLOG_USER_ID !== $user_id ) {
return;
}
2024-12-25 14:21:25 +01:00
// Check that we are actually following this actor.
if ( ! Event_Sources::actor_is_event_source( $activity['actor'] ) ) {
2024-12-25 14:21:25 +01:00
return false;
2024-12-14 14:46:00 +01:00
}
2024-12-25 14:21:25 +01:00
$id = object_to_uri( $activity['object'] );
$transmogrifier = Setup::get_transmogrifier();
2024-12-14 14:46:00 +01:00
if ( ! $transmogrifier ) {
return;
}
2024-12-14 14:46:00 +01:00
2024-12-25 14:21:25 +01:00
$transmogrifier->delete( $id );
}
}