wordpress-activitypub/includes/model/class-comment.php

270 lines
7.3 KiB
PHP
Raw Normal View History

2021-02-18 07:12:32 +01:00
<?php
namespace Activitypub\Model;
/**
* ActivityPub Comment Class
*
* @author Django Doucet
*/
class Comment {
private $comment;
2022-04-15 03:04:43 +02:00
private $updated;
private $deleted;
2021-02-18 07:12:32 +01:00
/**
* Initialize the class
*/
public function __construct( $comment = null ) {
$this->comment = $comment;
2022-04-15 03:04:43 +02:00
$this->id = $this->generate_comment_id();
2021-02-18 07:12:32 +01:00
$this->comment_author_url = \get_author_posts_url( $this->comment->user_id );
$this->safe_comment_id = $this->generate_comment_id();
$this->inReplyTo = $this->generate_parent_url();
$this->contentWarning = $this->generate_content_warning();
$this->permalink = $this->generate_permalink();
2022-04-15 03:04:43 +02:00
$this->context = $this->generate_context();
2021-02-18 07:12:32 +01:00
$this->cc_recipients = $this->generate_recipients();
$this->tags = $this->generate_tags();
2022-04-15 03:04:43 +02:00
$this->update = $this->generate_update();
$this->deleted = $this->generate_trash();
$this->replies = $this->generate_replies();
2021-02-18 07:12:32 +01:00
}
public function __call( $method, $params ) {
$var = \strtolower( \substr( $method, 4 ) );
if ( \strncasecmp( $method, 'get', 3 ) === 0 ) {
return $this->$var;
}
if ( \strncasecmp( $method, 'set', 3 ) === 0 ) {
$this->$var = $params[0];
}
}
public function to_array() {
$comment = $this->comment;
$array = array(
2022-04-15 03:04:43 +02:00
'id' => $this->safe_comment_id,
2021-02-18 07:12:32 +01:00
'type' => 'Note',
'published' => \date( 'Y-m-d\TH:i:s\Z', \strtotime( $comment->comment_date_gmt ) ),
'attributedTo' => $this->comment_author_url,
'summary' => $this->contentWarning,
'inReplyTo' => $this->inReplyTo,
'content' => $comment->comment_content,
'contentMap' => array(
\strstr( \get_locale(), '_', true ) => $comment->comment_content,
),
2022-04-15 03:04:43 +02:00
'context' => $this->context,
//'source' => \get_comment_link( $comment ), //non-conforming, see https://www.w3.org/TR/activitypub/#source-property
2022-04-15 09:17:00 +02:00
'url' => \get_comment_link( $comment ), //link for mastodon
'to' => array( 'https://www.w3.org/ns/activitystreams#Public' ), //audience logic
2021-02-18 07:12:32 +01:00
'cc' => $this->cc_recipients,
'tag' => $this->tags,
);
2022-04-15 03:04:43 +02:00
if ( $this->replies ) {
$array['replies'] = $this->replies;
}
if ( $this->update ) {
$array['updated'] = $this->update;
}
if ( $this->deleted ) {
$array['deleted'] = $this->deleted;
}
2021-02-18 07:12:32 +01:00
return \apply_filters( 'activitypub_comment', $array );
}
public function to_json() {
return \wp_json_encode( $this->to_array(), JSON_HEX_TAG | JSON_HEX_AMP | JSON_HEX_QUOT );
}
public function generate_comment_author_link() {
return \get_author_posts_url( $this->comment->comment_author );
}
2022-04-15 03:04:43 +02:00
public function generate_comment_id() {
return \Activitypub\set_ap_comment_id( $this->comment );
}
2021-02-18 07:12:32 +01:00
public function generate_permalink() {
$comment = $this->comment;
$permalink = \get_comment_link( $comment );
// replace 'trashed' for delete activity
return \str_replace( '__trashed', '', $permalink );
}
/**
* What is status is being replied to
* Comment ID or Post ID
*/
public function generate_parent_url() {
$comment = $this->comment;
$parent_comment = \get_comment( $comment->comment_parent );
2022-04-15 09:17:00 +02:00
if ( $comment->comment_parent ) {
2022-04-15 03:04:43 +02:00
//is parent remote?
2021-02-18 07:12:32 +01:00
$inReplyTo = \get_comment_meta( $comment->comment_parent, 'source_url', true );
2022-04-15 03:04:43 +02:00
if ( ! $inReplyTo ) {
2022-04-15 09:17:00 +02:00
$inReplyTo = add_query_arg(
array(
2022-04-15 03:04:43 +02:00
'p' => $comment->comment_post_ID,
'ap_comment_id' => $comment->comment_parent,
2022-04-15 09:17:00 +02:00
),
2022-04-15 03:04:43 +02:00
trailingslashit( site_url() )
);
}
2021-02-18 07:12:32 +01:00
} else {
2022-04-15 09:17:00 +02:00
$inReplyTo = add_query_arg(
array(
2022-04-15 03:04:43 +02:00
'p' => $comment->comment_post_ID,
2022-04-15 09:17:00 +02:00
),
2022-04-15 03:04:43 +02:00
trailingslashit( site_url() )
);
2021-02-18 07:12:32 +01:00
}
return $inReplyTo;
}
2022-04-15 03:04:43 +02:00
public function generate_context() {
$comment = $this->comment;
2022-04-15 09:17:00 +02:00
$inReplyTo = add_query_arg(
array(
2022-04-15 03:04:43 +02:00
'p' => $comment->comment_post_ID,
2022-04-15 09:17:00 +02:00
),
2022-04-15 03:04:43 +02:00
trailingslashit( site_url() )
);
return $inReplyTo;
}
2021-02-18 07:12:32 +01:00
/**
2022-04-15 09:17:00 +02:00
* Generate courtesy Content Warning
2021-02-18 07:12:32 +01:00
* If peer used CW let's just copy it
* TODO: Move to preprocess_comment / row_actions
* Add option for wrapping CW in Details/Summary markup
2022-04-15 09:17:00 +02:00
* Figure out some CW syntax: [shortcode-style], {brackets-style}?
2021-02-18 07:12:32 +01:00
* So it can be inserted into reply textbox, and removed or modified at will
*/
public function generate_content_warning() {
$comment = $this->comment;
$contentWarning = null;
2022-04-15 09:17:00 +02:00
2022-04-15 03:04:43 +02:00
// TODO Replace auto CW, with Title field or CW shortcode
2021-02-18 07:12:32 +01:00
$parent_comment = \get_comment( $comment->comment_parent );
if ( $parent_comment ) {
//get (received) comment
$ap_object = \unserialize( \get_comment_meta( $comment->comment_parent, 'ap_object', true ) );
if ( isset( $ap_object['object']['summary'] ) ) {
$contentWarning = $ap_object['object']['summary'];
}
}
2022-04-15 03:04:43 +02:00
/*summary = \get_comment_meta( $this->comment->comment_ID, 'summary', true ) ;
2021-02-18 07:12:32 +01:00
if ( !empty( $summary ) ) {
2022-04-15 03:04:43 +02:00
$contentWarning = \Activitypub\add_summary( $summary ); //TODO
2021-02-18 07:12:32 +01:00
} */
return $contentWarning;
}
/**
* Who is being replied to
*/
public function generate_recipients() {
//TODO Add audience logic get parent audience
2022-04-15 03:04:43 +02:00
//TODO shouldn't mentions go in 'to'?
2021-02-18 07:12:32 +01:00
$recipients = array( AS_PUBLIC );
2022-04-15 09:17:00 +02:00
$mentions = \get_comment_meta( $this->comment->comment_ID, 'mentions', true );
if ( ! empty( $mentions ) ) {
foreach ( $mentions as $mention ) {
2021-02-18 07:12:32 +01:00
$recipients[] = $mention['href'];
}
2022-04-15 09:17:00 +02:00
}
2021-02-18 07:12:32 +01:00
return $recipients;
}
/**
* Mention user being replied to
*/
public function generate_tags() {
2022-04-15 09:17:00 +02:00
$mentions = \get_comment_meta( $this->comment->comment_ID, 'mentions', true );
if ( ! empty( $mentions ) ) {
foreach ( $mentions as $mention ) {
2021-02-18 07:12:32 +01:00
$mention_tags[] = array(
'type' => 'Mention',
'href' => $mention['href'],
'name' => '@' . $mention['name'],
);
}
return $mention_tags;
}
}
/**
2022-04-15 03:04:43 +02:00
* Generate updated datetime
*/
public function generate_update() {
$comment = $this->comment;
$updated = null;
if ( \get_comment_meta( $comment->comment_ID, 'ap_last_modified', true ) ) {
$updated = \wp_date( 'Y-m-d\TH:i:s\Z', \get_comment_meta( $comment->comment_ID, 'ap_last_modified', true ) );
}
return $updated;
}
/**
* Generate deleted datetime
*/
public function generate_trash() {
$comment = $this->comment;
$deleted = null;
if ( 'trash' == $comment->status ) {
$deleted = \date( 'Y-m-d\TH:i:s\Z', \strtotime( $comment->comment_date_gmt ) );
}
return $deleted;
}
/**
* Generate replies collections
2021-02-18 07:12:32 +01:00
*/
2022-04-15 03:04:43 +02:00
public function generate_replies() {
$comment = $this->comment;
$args = array(
2022-04-15 09:17:00 +02:00
'post_id' => $comment->comment_post_ID,
'parent' => $comment->comment_ID,
'author__in' => $comment->user_id,
'status' => 'approve',
'hierarchical' => false,
2022-04-15 03:04:43 +02:00
);
$children = \get_comments( $args );
$replies = null;
if ( $children ) {
2022-04-15 09:17:00 +02:00
$items = array();
foreach ( $children as $child_comment ) {
2022-04-15 03:04:43 +02:00
$comment_url = \add_query_arg(
2022-04-15 09:17:00 +02:00
array(
2022-04-15 03:04:43 +02:00
'p' => $child_comment->comment_post_ID,
2022-04-15 09:17:00 +02:00
'ap_comment_id' => $child_comment->comment_ID,
),
2022-04-15 03:04:43 +02:00
trailingslashit( site_url() )
);
$items[] = $comment_url;
}
2022-04-15 09:17:00 +02:00
$replies = (object) array(
'type' => 'Collection',
'id' => \add_query_arg( array( 'replies' => '' ), $this->id ),
'first' => (object) array(
'type' => 'CollectionPage',
'partOf' => \add_query_arg( array( 'replies' => '' ), $this->id ),
'next' => \add_query_arg(
array(
'replies' => '',
'page' => 1,
),
$this->id
),
'items' => $items,
),
);
2022-04-15 03:04:43 +02:00
}
return $replies;
2021-02-18 07:12:32 +01:00
}
2022-04-15 09:17:00 +02:00
}