2024-02-08 12:31:25 +00:00
|
|
|
<?php
|
2024-10-09 12:44:17 +00:00
|
|
|
/**
|
|
|
|
* Base Transformer Class file.
|
|
|
|
*
|
|
|
|
* @package Activitypub
|
|
|
|
*/
|
|
|
|
|
2024-02-08 12:31:25 +00:00
|
|
|
namespace Activitypub\Transformer;
|
|
|
|
|
|
|
|
use WP_Post;
|
|
|
|
use WP_Comment;
|
|
|
|
|
|
|
|
use Activitypub\Activity\Activity;
|
|
|
|
use Activitypub\Activity\Base_Object;
|
2024-10-09 12:44:17 +00:00
|
|
|
use Activitypub\Collection\Replies;
|
2024-02-08 12:31:25 +00:00
|
|
|
|
|
|
|
/**
|
2024-10-09 12:44:17 +00:00
|
|
|
* WordPress Base Transformer.
|
2024-02-08 12:31:25 +00:00
|
|
|
*
|
|
|
|
* Transformers are responsible for transforming a WordPress objects into different ActivityPub
|
|
|
|
* Object-Types or Activities.
|
|
|
|
*/
|
|
|
|
abstract class Base {
|
|
|
|
/**
|
|
|
|
* The WP_Post or WP_Comment object.
|
|
|
|
*
|
|
|
|
* This is the source object of the transformer.
|
|
|
|
*
|
|
|
|
* @var WP_Post|WP_Comment
|
|
|
|
*/
|
|
|
|
protected $wp_object;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Static function to Transform a WordPress Object.
|
|
|
|
*
|
|
|
|
* This helps to chain the output of the Transformer.
|
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @param WP_Post|WP_Comment $wp_object The WordPress object.
|
2024-02-08 12:31:25 +00:00
|
|
|
*
|
2024-06-27 12:10:38 +00:00
|
|
|
* @return Base
|
2024-02-08 12:31:25 +00:00
|
|
|
*/
|
2024-10-09 12:44:17 +00:00
|
|
|
public static function transform( $wp_object ) {
|
|
|
|
return new static( $wp_object );
|
2024-02-08 12:31:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base constructor.
|
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @param WP_Post|WP_Comment $wp_object The WordPress object.
|
2024-02-08 12:31:25 +00:00
|
|
|
*/
|
|
|
|
public function __construct( $wp_object ) {
|
|
|
|
$this->wp_object = $wp_object;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-03-28 09:39:50 +00:00
|
|
|
* Transform all properties with available get(ter) functions.
|
2024-02-08 12:31:25 +00:00
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @param Base_Object|object $activitypub_object The ActivityPub Object.
|
2024-03-28 09:39:50 +00:00
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @return Base_Object|object
|
2024-02-08 12:31:25 +00:00
|
|
|
*/
|
2024-03-28 09:39:50 +00:00
|
|
|
protected function transform_object_properties( $activitypub_object ) {
|
2024-02-08 12:31:25 +00:00
|
|
|
$vars = $activitypub_object->get_object_var_keys();
|
|
|
|
|
|
|
|
foreach ( $vars as $var ) {
|
|
|
|
$getter = 'get_' . $var;
|
|
|
|
|
|
|
|
if ( method_exists( $this, $getter ) ) {
|
|
|
|
$value = call_user_func( array( $this, $getter ) );
|
|
|
|
|
|
|
|
if ( isset( $value ) ) {
|
|
|
|
$setter = 'set_' . $var;
|
|
|
|
|
|
|
|
call_user_func( array( $activitypub_object, $setter ), $value );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-03-28 09:39:50 +00:00
|
|
|
return $activitypub_object;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transform the WordPress Object into an ActivityPub Object.
|
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @return Base_Object|object The ActivityPub Object.
|
2024-03-28 09:39:50 +00:00
|
|
|
*/
|
|
|
|
public function to_object() {
|
|
|
|
$activitypub_object = new Base_Object();
|
2024-02-08 12:31:25 +00:00
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
return $this->transform_object_properties( $activitypub_object );
|
2024-02-08 12:31:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transforms the ActivityPub Object to an Activity
|
|
|
|
*
|
|
|
|
* @param string $type The Activity-Type.
|
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @return Activity The Activity.
|
2024-02-08 12:31:25 +00:00
|
|
|
*/
|
|
|
|
public function to_activity( $type ) {
|
|
|
|
$object = $this->to_object();
|
|
|
|
|
|
|
|
$activity = new Activity();
|
|
|
|
$activity->set_type( $type );
|
2024-03-28 09:39:50 +00:00
|
|
|
|
|
|
|
// Pre-fill the Activity with data (for example cc and to).
|
2024-02-08 12:31:25 +00:00
|
|
|
$activity->set_object( $object );
|
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
// Use simple Object (only ID-URI) for Like and Announce.
|
2024-02-08 12:31:25 +00:00
|
|
|
if ( in_array( $type, array( 'Like', 'Announce' ), true ) ) {
|
|
|
|
$activity->set_object( $object->get_id() );
|
|
|
|
}
|
|
|
|
|
|
|
|
return $activity;
|
|
|
|
}
|
|
|
|
|
2024-10-09 12:44:17 +00:00
|
|
|
/**
|
|
|
|
* Get the ID of the WordPress Object.
|
|
|
|
*/
|
|
|
|
abstract protected function get_id();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the replies Collection.
|
|
|
|
*/
|
|
|
|
public function get_replies() {
|
|
|
|
return Replies::get_collection( $this->wp_object );
|
|
|
|
}
|
|
|
|
|
2024-02-08 12:31:25 +00:00
|
|
|
/**
|
|
|
|
* Returns the ID of the WordPress Object.
|
|
|
|
*/
|
|
|
|
abstract public function get_wp_user_id();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Change the User-ID of the WordPress Post.
|
|
|
|
*
|
2024-10-09 12:44:17 +00:00
|
|
|
* @param int $user_id The new user ID.
|
2024-02-08 12:31:25 +00:00
|
|
|
*/
|
|
|
|
abstract public function change_wp_user_id( $user_id );
|
|
|
|
}
|