[PLUGIN][ActivityPub][Test] Activity: Create Page
Fixed a couple of bugs
This commit is contained in:
parent
6955872e05
commit
2f7fdf6ee4
|
@ -17,22 +17,31 @@
|
||||||
"@id": "gs:inConversation",
|
"@id": "gs:inConversation",
|
||||||
"@type": "@id"
|
"@type": "@id"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"@language": "en"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"id": "https://instance.gnusocial.test/activity/1338",
|
"id": "https://instance.gnusocial.test/activity/1338",
|
||||||
"published": "2022-03-01T18:19:51+00:00",
|
"published": "2022-03-17T23:30:26+00:00",
|
||||||
"actor": "https://instance.gnusocial.test/actor/42",
|
"actor": "https://instance.gnusocial.test/actor/42",
|
||||||
|
"to": [
|
||||||
|
"https://www.w3.org/ns/activitystreams#Public"
|
||||||
|
],
|
||||||
|
"cc": [
|
||||||
|
"https://instance.gnusocial.test/actor/21"
|
||||||
|
],
|
||||||
"object": {
|
"object": {
|
||||||
"type": "Page",
|
"type": "Page",
|
||||||
"id": "https://instance.gnusocial.test/object/note/1338",
|
"id": "https://instance.gnusocial.test/object/note/1338",
|
||||||
"published": "2022-03-01T22:44:29+00:00",
|
"published": "2022-03-17T23:30:26+00:00",
|
||||||
"attributedTo": "https://instance.gnusocial.test/actor/42",
|
"attributedTo": "https://instance.gnusocial.test/actor/42",
|
||||||
"name": "hello, world.",
|
"name": "hello, world.",
|
||||||
"content": "<p>This is an interesting page.</p>",
|
"content": "<p>This is an interesting page.</p>",
|
||||||
"mediaType": "text/html",
|
"mediaType": "text/html",
|
||||||
"source": {
|
"source": {
|
||||||
"content": "This is an interesting page.",
|
"content": "This is an interesting page.",
|
||||||
"mediaType": "text/plain"
|
"mediaType": "text/markdown"
|
||||||
},
|
},
|
||||||
"attachment": [],
|
"attachment": [],
|
||||||
"tag": [],
|
"tag": [],
|
||||||
|
@ -41,15 +50,7 @@
|
||||||
"https://www.w3.org/ns/activitystreams#Public"
|
"https://www.w3.org/ns/activitystreams#Public"
|
||||||
],
|
],
|
||||||
"cc": [
|
"cc": [
|
||||||
"https://instance.gnusocial.test/actor/42/subscribers",
|
|
||||||
"https://instance.gnusocial.test/actor/21"
|
"https://instance.gnusocial.test/actor/21"
|
||||||
]
|
]
|
||||||
},
|
}
|
||||||
"to": [
|
}
|
||||||
"https://www.w3.org/ns/activitystreams#Public"
|
|
||||||
],
|
|
||||||
"cc": [
|
|
||||||
"https://instance.gnusocial.test/actor/42/subscribers",
|
|
||||||
"https://instance.gnusocial.test/actor/21"
|
|
||||||
]
|
|
||||||
}
|
|
|
@ -17,6 +17,9 @@
|
||||||
"@id": "gs:inConversation",
|
"@id": "gs:inConversation",
|
||||||
"@type": "@id"
|
"@type": "@id"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"@language": "en"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"id": "https://instance.gnusocial.test/object/note/1337",
|
"id": "https://instance.gnusocial.test/object/note/1337",
|
||||||
|
|
|
@ -1,47 +1,50 @@
|
||||||
{
|
{
|
||||||
"type": "Note",
|
"type": "Note",
|
||||||
"@context": [
|
"@context": [
|
||||||
"https://www.w3.org/ns/activitystreams",
|
"https://www.w3.org/ns/activitystreams",
|
||||||
"https://w3id.org/security/v1",
|
"https://w3id.org/security/v1",
|
||||||
{
|
{
|
||||||
"gs": "https://www.gnu.org/software/social/ns#"
|
"gs": "https://www.gnu.org/software/social/ns#"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"litepub": "http://litepub.social/ns#"
|
"litepub": "http://litepub.social/ns#"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"chatMessage": "litepub:chatMessage"
|
"chatMessage": "litepub:chatMessage"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"inConversation": {
|
"inConversation": {
|
||||||
"@id": "gs:inConversation",
|
"@id": "gs:inConversation",
|
||||||
"@type": "@id"
|
"@type": "@id"
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
],
|
{
|
||||||
"id": "https://instance.gnusocial.test/object/note/1340",
|
"@language": "en"
|
||||||
"published": "2022-03-16T21:54:43+00:00",
|
}
|
||||||
"attributedTo": "https://instance.gnusocial.test/actor/42",
|
],
|
||||||
"content": "<p>This is a public root note with a mention to @<span class=\"h-card\"><a href=\"https://another_instance.gnusocial.test/actor/43\" class=\"h-card u-url p-nickname mention\">alice@another_instance.gnusocial.test</a></span>.</p>",
|
"id": "https://instance.gnusocial.test/object/note/1340",
|
||||||
"mediaType": "text/html",
|
"published": "2022-03-16T21:54:43+00:00",
|
||||||
"source": {
|
"attributedTo": "https://instance.gnusocial.test/actor/42",
|
||||||
"content": "This is a public root note with a mention to @alice@another_instance.gnusocial.test.",
|
"content": "<p>This is a public root note with a mention to @<span class=\"h-card\"><a href=\"https://another_instance.gnusocial.test/actor/43\" class=\"h-card u-url p-nickname mention\">alice@another_instance.gnusocial.test</a></span>.</p>",
|
||||||
"mediaType": "text/plain"
|
"mediaType": "text/html",
|
||||||
},
|
"source": {
|
||||||
"attachment": [],
|
"content": "This is a public root note with a mention to @alice@another_instance.gnusocial.test.",
|
||||||
"tag": [
|
"mediaType": "text/plain"
|
||||||
{
|
},
|
||||||
"type": "Mention",
|
"attachment": [],
|
||||||
"href": "https://another_instance.gnusocial.test/actor/43",
|
"tag": [
|
||||||
"name": "@alice@another_instance.gnusocial.test"
|
{
|
||||||
}
|
"type": "Mention",
|
||||||
],
|
"href": "https://another_instance.gnusocial.test/actor/43",
|
||||||
"inConversation": "https://instance.gnusocial.test/conversation/1340",
|
"name": "@alice@another_instance.gnusocial.test"
|
||||||
"to": [
|
}
|
||||||
"https://www.w3.org/ns/activitystreams#Public",
|
],
|
||||||
"https://testv3.gnusocial.rocks/actor/43"
|
"inConversation": "https://instance.gnusocial.test/conversation/1340",
|
||||||
],
|
"to": [
|
||||||
"cc": [
|
"https://www.w3.org/ns/activitystreams#Public",
|
||||||
"https://testv3.gnusocial.rocks/actor/43"
|
"https://testv3.gnusocial.rocks/actor/43"
|
||||||
]
|
],
|
||||||
|
"cc": [
|
||||||
|
"https://testv3.gnusocial.rocks/actor/43"
|
||||||
|
]
|
||||||
}
|
}
|
|
@ -17,26 +17,28 @@
|
||||||
"@id": "gs:inConversation",
|
"@id": "gs:inConversation",
|
||||||
"@type": "@id"
|
"@type": "@id"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"@language": "en"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"id": "https://instance.gnusocial.test/object/note/1338",
|
"id": "https://instance.gnusocial.test/object/note/1338",
|
||||||
"published": "2022-03-01T22:44:29+00:00",
|
"published": "2022-03-17T23:30:26+00:00",
|
||||||
"attributedTo": "https://instance.gnusocial.test/actor/42",
|
"attributedTo": "https://instance.gnusocial.test/actor/42",
|
||||||
"name": "hello, world.",
|
"name": "hello, world.",
|
||||||
"content": "<p>This is an interesting page.</p>",
|
"content": "<p>This is an interesting page.</p>",
|
||||||
"mediaType": "text/html",
|
"mediaType": "text/html",
|
||||||
"source": {
|
"source": {
|
||||||
"content": "This is an interesting page.",
|
"content": "This is an interesting page.",
|
||||||
"mediaType": "text/plain"
|
"mediaType": "text/markdown"
|
||||||
},
|
},
|
||||||
"attachment": [],
|
"attachment": [],
|
||||||
"tag": [],
|
"tag": [],
|
||||||
"inConversation": "https://instance.gnusocial.test/conversation/1338",
|
"inConversation": "https://instance.gnusocial.test/conversation/1338",
|
||||||
"to": [
|
"to": [
|
||||||
"https://www.w3.org/ns/activitystreams#Public"
|
"https://www.w3.org/ns/activitystreams#Public"
|
||||||
],
|
],
|
||||||
"cc": [
|
"cc": [
|
||||||
"https://instance.gnusocial.test/actor/42/subscribers",
|
"https://instance.gnusocial.test/actor/21"
|
||||||
"https://instance.gnusocial.test/actor/21"
|
]
|
||||||
]
|
|
||||||
}
|
}
|
|
@ -17,6 +17,9 @@
|
||||||
"@id": "gs:inConversation",
|
"@id": "gs:inConversation",
|
||||||
"@type": "@id"
|
"@type": "@id"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"@language": "en"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"id": "https://instance.gnusocial.test/object/note/1339",
|
"id": "https://instance.gnusocial.test/object/note/1339",
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types = 1);
|
||||||
|
|
||||||
|
// {{{ License
|
||||||
|
|
||||||
|
// This file is part of GNU social - https://www.gnu.org/software/social
|
||||||
|
//
|
||||||
|
// GNU social is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU Affero General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// GNU social is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU Affero General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Affero General Public License
|
||||||
|
// along with GNU social. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
// }}}
|
||||||
|
|
||||||
|
namespace Plugin\ActivityPub\Test\Objects;
|
||||||
|
|
||||||
|
use App\Util\GNUsocialTestCase;
|
||||||
|
use Plugin\ActivityPub\Entity\ActivitypubActivity;
|
||||||
|
use Plugin\ActivityPub\Util\Explorer;
|
||||||
|
|
||||||
|
class GSActivityCreatePageTest extends GNUsocialTestCase
|
||||||
|
{
|
||||||
|
public function testNoteFromJson()
|
||||||
|
{
|
||||||
|
self::bootKernel();
|
||||||
|
|
||||||
|
$activity_uri = 'https://instance.gnusocial.test/activity/1338';
|
||||||
|
$group_uri = 'https://instance.gnusocial.test/actor/21';
|
||||||
|
$ap_activity = ActivitypubActivity::getByPK(['activity_uri' => $activity_uri]);
|
||||||
|
|
||||||
|
$activity = $ap_activity->getActivity();
|
||||||
|
static::assertSame('create', $activity->getVerb());
|
||||||
|
static::assertSame('note', $activity->getObjectType());
|
||||||
|
static::assertSame('ActivityPub', $activity->getSource());
|
||||||
|
|
||||||
|
static::assertCount(1, $attT = $ap_activity->getAttentionTargets());
|
||||||
|
static::assertObjectEquals(Explorer::getOneFromUri($group_uri, try_online: false), $attT[0]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -50,7 +50,7 @@ class GSObjectNoteTest extends GNUsocialTestCase
|
||||||
static::assertFalse($note->getIsLocal());
|
static::assertFalse($note->getIsLocal());
|
||||||
static::assertSame(VisibilityScope::EVERYWHERE, $note->getScope());
|
static::assertSame(VisibilityScope::EVERYWHERE, $note->getScope());
|
||||||
static::assertSame($object_uri, $note->getUrl());
|
static::assertSame($object_uri, $note->getUrl());
|
||||||
static::assertNull($note->getLanguageId());
|
static::assertSame('en', $note->getLanguageLocale());
|
||||||
static::assertSame('note', $note->getType());
|
static::assertSame('note', $note->getType());
|
||||||
static::assertNull($note->getTitle());
|
static::assertNull($note->getTitle());
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ class GSObjectNoteTest extends GNUsocialTestCase
|
||||||
static::assertFalse($note->getIsLocal());
|
static::assertFalse($note->getIsLocal());
|
||||||
static::assertSame(VisibilityScope::EVERYWHERE, $note->getScope());
|
static::assertSame(VisibilityScope::EVERYWHERE, $note->getScope());
|
||||||
static::assertSame($object_uri, $note->getUrl());
|
static::assertSame($object_uri, $note->getUrl());
|
||||||
static::assertNull($note->getLanguageId());
|
static::assertSame('en', $note->getLanguageLocale());
|
||||||
static::assertSame('note', $note->getType());
|
static::assertSame('note', $note->getType());
|
||||||
static::assertNull($note->getTitle());
|
static::assertNull($note->getTitle());
|
||||||
|
|
||||||
|
|
|
@ -38,11 +38,12 @@ class GSObjectPageTest extends GNUsocialTestCase
|
||||||
|
|
||||||
$actor_uri = 'https://instance.gnusocial.test/actor/42';
|
$actor_uri = 'https://instance.gnusocial.test/actor/42';
|
||||||
$object_uri = 'https://instance.gnusocial.test/object/note/1338';
|
$object_uri = 'https://instance.gnusocial.test/object/note/1338';
|
||||||
|
$group_uri = 'https://instance.gnusocial.test/actor/21';
|
||||||
$page = ActivityPub::getObjectByUri($object_uri, try_online: false);
|
$page = ActivityPub::getObjectByUri($object_uri, try_online: false);
|
||||||
static::assertInstanceOf(Note::class, $page);
|
static::assertInstanceOf(Note::class, $page);
|
||||||
|
|
||||||
static::assertSame(Explorer::getOneFromUri($actor_uri)->getId(), $page->getActorId());
|
static::assertSame(Explorer::getOneFromUri($actor_uri)->getId(), $page->getActorId());
|
||||||
static::assertSame('text/plain', $page->getContentType());
|
static::assertSame('text/markdown', $page->getContentType());
|
||||||
static::assertSame('This is an interesting page.', $page->getContent());
|
static::assertSame('This is an interesting page.', $page->getContent());
|
||||||
static::assertSame('<p>This is an interesting page.</p>', $page->getRendered());
|
static::assertSame('<p>This is an interesting page.</p>', $page->getRendered());
|
||||||
static::assertSame('ActivityPub', $page->getSource());
|
static::assertSame('ActivityPub', $page->getSource());
|
||||||
|
@ -50,7 +51,7 @@ class GSObjectPageTest extends GNUsocialTestCase
|
||||||
static::assertFalse($page->getIsLocal());
|
static::assertFalse($page->getIsLocal());
|
||||||
static::assertSame(VisibilityScope::EVERYWHERE, $page->getScope());
|
static::assertSame(VisibilityScope::EVERYWHERE, $page->getScope());
|
||||||
static::assertSame($object_uri, $page->getUrl());
|
static::assertSame($object_uri, $page->getUrl());
|
||||||
static::assertNull($page->getLanguageId());
|
static::assertSame('en', $page->getLanguageLocale());
|
||||||
static::assertSame('page', $page->getType());
|
static::assertSame('page', $page->getType());
|
||||||
static::assertSame('hello, world.', $page->getTitle());
|
static::assertSame('hello, world.', $page->getTitle());
|
||||||
|
|
||||||
|
@ -59,6 +60,8 @@ class GSObjectPageTest extends GNUsocialTestCase
|
||||||
static::assertSame($object_uri, $ap_object->getObjectUri());
|
static::assertSame($object_uri, $ap_object->getObjectUri());
|
||||||
static::assertSame($page->getId(), $ap_object->getObjectId());
|
static::assertSame($page->getId(), $ap_object->getObjectId());
|
||||||
|
|
||||||
//dd($page->getAttentionTargets(), $page->getMentionTargets());
|
static::assertCount(1, $attT = $page->getAttentionTargets());
|
||||||
|
static::assertObjectEquals(Explorer::getOneFromUri($group_uri, try_online: false), $attT[0]);
|
||||||
|
static::assertSame([], $page->getMentionTargets());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -143,9 +143,9 @@ class Note extends Model
|
||||||
}
|
}
|
||||||
|
|
||||||
// Figure the locale of the note when possible
|
// Figure the locale of the note when possible
|
||||||
$locale = null;
|
$locale = array_column($type_note->get('@context'), '@language');
|
||||||
if (\array_key_exists('@language', $type_note->get('@context'))) {
|
if ($locale !== []) {
|
||||||
$locale = $type_note->get('@context')['@language'];
|
$locale = $locale[0];
|
||||||
if ($locale === 'und') {
|
if ($locale === 'und') {
|
||||||
$locale = null;
|
$locale = null;
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ class Note extends Model
|
||||||
'is_local' => false,
|
'is_local' => false,
|
||||||
'created' => new DateTime($type_note->get('published') ?? 'now'),
|
'created' => new DateTime($type_note->get('published') ?? 'now'),
|
||||||
'title' => $type_note->get('name') ?? null,
|
'title' => $type_note->get('name') ?? null,
|
||||||
'language_id' => $type_note->get('contentLang') ?? null,
|
'language_id' => \is_null($locale) ? null : Language::getByLocale($locale)->getId(),
|
||||||
'url' => $type_note->get('url') ?? $type_note->get('id'),
|
'url' => $type_note->get('url') ?? $type_note->get('id'),
|
||||||
'actor_id' => $actor_id,
|
'actor_id' => $actor_id,
|
||||||
'reply_to' => $reply_to = $handleInReplyTo($type_note),
|
'reply_to' => $reply_to = $handleInReplyTo($type_note),
|
||||||
|
@ -167,13 +167,6 @@ class Note extends Model
|
||||||
'source' => $source,
|
'source' => $source,
|
||||||
];
|
];
|
||||||
|
|
||||||
// Language
|
|
||||||
if (!\is_null($map['language_id'])) {
|
|
||||||
$map['language_id'] = Language::getByLocale($map['language_id'])->getId();
|
|
||||||
} else {
|
|
||||||
$map['language_id'] = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Scope
|
// Scope
|
||||||
if (\in_array('https://www.w3.org/ns/activitystreams#Public', $to)) {
|
if (\in_array('https://www.w3.org/ns/activitystreams#Public', $to)) {
|
||||||
// Public: Visible for all, shown in public feeds
|
// Public: Visible for all, shown in public feeds
|
||||||
|
|
Loading…
Reference in New Issue