2024-12-08 21:57:53 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Update handler file.
|
|
|
|
*
|
|
|
|
* @package Event_Bridge_For_ActivityPub
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Event_Bridge_For_ActivityPub\ActivityPub\Handler;
|
|
|
|
|
|
|
|
use Activitypub\Collection\Actors;
|
2025-01-04 12:17:58 +01:00
|
|
|
use Event_Bridge_For_ActivityPub\ActivityPub\Model\Event_Source;
|
2024-12-20 18:39:20 +01:00
|
|
|
use Event_Bridge_For_ActivityPub\Event_Sources;
|
2024-12-11 23:09:12 +01:00
|
|
|
use Event_Bridge_For_ActivityPub\Setup;
|
|
|
|
|
|
|
|
use function Activitypub\is_activity_public;
|
2024-12-08 21:57:53 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle Update requests.
|
|
|
|
*/
|
|
|
|
class Update {
|
|
|
|
/**
|
2024-12-16 17:36:23 +01:00
|
|
|
* Initialize the class, registering the handler for incoming `Update` activities to the ActivityPub plugin.
|
2024-12-08 21:57:53 +01:00
|
|
|
*/
|
|
|
|
public static function init() {
|
|
|
|
\add_action(
|
|
|
|
'activitypub_inbox_update',
|
2024-12-11 23:09:12 +01:00
|
|
|
array( self::class, 'handle_update' ),
|
|
|
|
15,
|
|
|
|
2
|
2024-12-08 21:57:53 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-12-16 17:36:23 +01:00
|
|
|
* Handle incoming "Update" activities..
|
2024-12-08 21:57:53 +01:00
|
|
|
*
|
2024-12-11 23:09:12 +01:00
|
|
|
* @param array $activity The activity-object.
|
|
|
|
* @param int $user_id The id of the local blog-user.
|
2024-12-08 21:57:53 +01:00
|
|
|
*/
|
2024-12-11 23:09:12 +01:00
|
|
|
public static function handle_update( $activity, $user_id ) {
|
2024-12-16 17:36:23 +01:00
|
|
|
// 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 ) {
|
2024-12-08 21:57:53 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-12-11 23:09:12 +01:00
|
|
|
// Check if Activity is public or not.
|
|
|
|
if ( ! is_activity_public( $activity ) ) {
|
|
|
|
return;
|
|
|
|
}
|
2024-12-08 21:57:53 +01:00
|
|
|
|
2024-12-25 22:54:43 +01:00
|
|
|
// Check if an object is set and it is an object of type `Event`.
|
2024-12-11 23:09:12 +01:00
|
|
|
if ( ! isset( $activity['object']['type'] ) || 'Event' !== $activity['object']['type'] ) {
|
2024-12-08 21:57:53 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2025-01-04 12:17:58 +01:00
|
|
|
// Check that we are actually following/or have a pending follow request this actor.
|
|
|
|
$event_source = Event_Source::get_by_id( $activity['actor'] );
|
|
|
|
if ( ! $event_source ) {
|
|
|
|
return;
|
2025-01-04 10:01:14 +01:00
|
|
|
}
|
|
|
|
|
2024-12-20 18:39:20 +01:00
|
|
|
if ( Event_Sources::is_time_passed( $activity['object']['startTime'] ) ) {
|
2024-12-16 17:36:23 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-12-15 22:25:28 +01:00
|
|
|
$transmogrifier = Setup::get_transmogrifier();
|
2024-12-11 23:09:12 +01:00
|
|
|
|
2024-12-15 22:25:28 +01:00
|
|
|
if ( ! $transmogrifier ) {
|
2024-12-08 21:57:53 +01:00
|
|
|
return;
|
|
|
|
}
|
2024-12-11 23:09:12 +01:00
|
|
|
|
2025-01-04 12:17:58 +01:00
|
|
|
$transmogrifier->save( $activity['object'], $event_source );
|
2024-12-08 21:57:53 +01:00
|
|
|
}
|
|
|
|
}
|