forked from YokaiRick/akkoma
Output proper published data in ostatus.
This commit is contained in:
parent
869e5ccfe1
commit
94e980d6b4
3 changed files with 26 additions and 66 deletions
5
TODO.txt
5
TODO.txt
|
@ -5,5 +5,8 @@ Unliking:
|
||||||
WEBSUB:
|
WEBSUB:
|
||||||
|
|
||||||
- Add unsubscription
|
- Add unsubscription
|
||||||
- Add periodical renewal
|
|
||||||
|
OSTATUS:
|
||||||
|
|
||||||
|
- Save and output 'updated'
|
||||||
|
|
||||||
|
|
|
@ -28,10 +28,8 @@ def to_simple_form(activity, user, with_author \\ false)
|
||||||
def to_simple_form(%{data: %{"object" => %{"type" => "Note"}}} = activity, user, with_author) do
|
def to_simple_form(%{data: %{"object" => %{"type" => "Note"}}} = activity, user, with_author) do
|
||||||
h = fn(str) -> [to_charlist(str)] end
|
h = fn(str) -> [to_charlist(str)] end
|
||||||
|
|
||||||
updated_at = activity.updated_at
|
updated_at = activity.data["published"]
|
||||||
|> NaiveDateTime.to_iso8601
|
inserted_at = activity.data["published"]
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
attachments = Enum.map(activity.data["object"]["attachment"] || [], fn(attachment) ->
|
attachments = Enum.map(activity.data["object"]["attachment"] || [], fn(attachment) ->
|
||||||
url = hd(attachment["url"])
|
url = hd(attachment["url"])
|
||||||
|
@ -62,10 +60,8 @@ def to_simple_form(%{data: %{"object" => %{"type" => "Note"}}} = activity, user,
|
||||||
def to_simple_form(%{data: %{"type" => "Like"}} = activity, user, with_author) do
|
def to_simple_form(%{data: %{"type" => "Like"}} = activity, user, with_author) do
|
||||||
h = fn(str) -> [to_charlist(str)] end
|
h = fn(str) -> [to_charlist(str)] end
|
||||||
|
|
||||||
updated_at = activity.updated_at
|
updated_at = activity.data["published"]
|
||||||
|> NaiveDateTime.to_iso8601
|
inserted_at = activity.data["published"]
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
in_reply_to = get_in_reply_to(activity.data)
|
in_reply_to = get_in_reply_to(activity.data)
|
||||||
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
||||||
|
@ -92,10 +88,8 @@ def to_simple_form(%{data: %{"type" => "Like"}} = activity, user, with_author) d
|
||||||
def to_simple_form(%{data: %{"type" => "Announce"}} = activity, user, with_author) do
|
def to_simple_form(%{data: %{"type" => "Announce"}} = activity, user, with_author) do
|
||||||
h = fn(str) -> [to_charlist(str)] end
|
h = fn(str) -> [to_charlist(str)] end
|
||||||
|
|
||||||
updated_at = activity.updated_at
|
updated_at = activity.data["published"]
|
||||||
|> NaiveDateTime.to_iso8601
|
inserted_at = activity.data["published"]
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
in_reply_to = get_in_reply_to(activity.data)
|
in_reply_to = get_in_reply_to(activity.data)
|
||||||
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
||||||
|
@ -124,10 +118,8 @@ def to_simple_form(%{data: %{"type" => "Announce"}} = activity, user, with_autho
|
||||||
def to_simple_form(%{data: %{"type" => "Follow"}} = activity, user, with_author) do
|
def to_simple_form(%{data: %{"type" => "Follow"}} = activity, user, with_author) do
|
||||||
h = fn(str) -> [to_charlist(str)] end
|
h = fn(str) -> [to_charlist(str)] end
|
||||||
|
|
||||||
updated_at = activity.updated_at
|
updated_at = activity.data["published"]
|
||||||
|> NaiveDateTime.to_iso8601
|
inserted_at = activity.data["published"]
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
||||||
|
|
||||||
|
@ -153,10 +145,8 @@ def to_simple_form(%{data: %{"type" => "Follow"}} = activity, user, with_author)
|
||||||
def to_simple_form(%{data: %{"type" => "Undo"}} = activity, user, with_author) do
|
def to_simple_form(%{data: %{"type" => "Undo"}} = activity, user, with_author) do
|
||||||
h = fn(str) -> [to_charlist(str)] end
|
h = fn(str) -> [to_charlist(str)] end
|
||||||
|
|
||||||
updated_at = activity.updated_at
|
updated_at = activity.data["published"]
|
||||||
|> NaiveDateTime.to_iso8601
|
inserted_at = activity.data["published"]
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: []
|
||||||
follow_activity = Activity.get_by_ap_id(activity.data["object"])
|
follow_activity = Activity.get_by_ap_id(activity.data["object"])
|
||||||
|
|
|
@ -9,10 +9,6 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do
|
||||||
|
|
||||||
test "a note activity" do
|
test "a note activity" do
|
||||||
note_activity = insert(:note_activity)
|
note_activity = insert(:note_activity)
|
||||||
updated_at = note_activity.updated_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
inserted_at = note_activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
user = User.get_cached_by_ap_id(note_activity.data["actor"])
|
user = User.get_cached_by_ap_id(note_activity.data["actor"])
|
||||||
|
|
||||||
|
@ -22,8 +18,8 @@ test "a note activity" do
|
||||||
<id>#{note_activity.data["object"]["id"]}</id>
|
<id>#{note_activity.data["object"]["id"]}</id>
|
||||||
<title>New note by #{user.nickname}</title>
|
<title>New note by #{user.nickname}</title>
|
||||||
<content type="html">#{note_activity.data["object"]["content"]}</content>
|
<content type="html">#{note_activity.data["object"]["content"]}</content>
|
||||||
<published>#{inserted_at}</published>
|
<published>#{note_activity.data["published"]}</published>
|
||||||
<updated>#{updated_at}</updated>
|
<updated>#{note_activity.data["published"]}</updated>
|
||||||
<ostatus:conversation>#{note_activity.data["context"]}</ostatus:conversation>
|
<ostatus:conversation>#{note_activity.data["context"]}</ostatus:conversation>
|
||||||
<link href="#{note_activity.data["context"]}" rel="ostatus:conversation" />
|
<link href="#{note_activity.data["context"]}" rel="ostatus:conversation" />
|
||||||
<link type="application/atom+xml" href="#{note_activity.data["object"]["id"]}" rel="self" />
|
<link type="application/atom+xml" href="#{note_activity.data["object"]["id"]}" rel="self" />
|
||||||
|
@ -47,11 +43,6 @@ test "a reply note" do
|
||||||
data = %{answer.data | "object" => object}
|
data = %{answer.data | "object" => object}
|
||||||
answer = %{answer | data: data}
|
answer = %{answer | data: data}
|
||||||
|
|
||||||
updated_at = answer.updated_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
inserted_at = answer.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
user = User.get_cached_by_ap_id(answer.data["actor"])
|
user = User.get_cached_by_ap_id(answer.data["actor"])
|
||||||
|
|
||||||
expected = """
|
expected = """
|
||||||
|
@ -60,8 +51,8 @@ test "a reply note" do
|
||||||
<id>#{answer.data["object"]["id"]}</id>
|
<id>#{answer.data["object"]["id"]}</id>
|
||||||
<title>New note by #{user.nickname}</title>
|
<title>New note by #{user.nickname}</title>
|
||||||
<content type="html">#{answer.data["object"]["content"]}</content>
|
<content type="html">#{answer.data["object"]["content"]}</content>
|
||||||
<published>#{inserted_at}</published>
|
<published>#{answer.data["published"]}</published>
|
||||||
<updated>#{updated_at}</updated>
|
<updated>#{answer.data["published"]}</updated>
|
||||||
<ostatus:conversation>#{answer.data["context"]}</ostatus:conversation>
|
<ostatus:conversation>#{answer.data["context"]}</ostatus:conversation>
|
||||||
<link href="#{answer.data["context"]}" rel="ostatus:conversation" />
|
<link href="#{answer.data["context"]}" rel="ostatus:conversation" />
|
||||||
<link type="application/atom+xml" href="#{answer.data["object"]["id"]}" rel="self" />
|
<link type="application/atom+xml" href="#{answer.data["object"]["id"]}" rel="self" />
|
||||||
|
@ -92,19 +83,14 @@ test "an announce activity" do
|
||||||
|> :xmerl.export_simple_content(:xmerl_xml)
|
|> :xmerl.export_simple_content(:xmerl_xml)
|
||||||
|> to_string
|
|> to_string
|
||||||
|
|
||||||
updated_at = announce.updated_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
inserted_at = announce.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
expected = """
|
expected = """
|
||||||
<activity:object-type>http://activitystrea.ms/schema/1.0/activity</activity:object-type>
|
<activity:object-type>http://activitystrea.ms/schema/1.0/activity</activity:object-type>
|
||||||
<activity:verb>http://activitystrea.ms/schema/1.0/share</activity:verb>
|
<activity:verb>http://activitystrea.ms/schema/1.0/share</activity:verb>
|
||||||
<id>#{announce.data["id"]}</id>
|
<id>#{announce.data["id"]}</id>
|
||||||
<title>#{user.nickname} repeated a notice</title>
|
<title>#{user.nickname} repeated a notice</title>
|
||||||
<content type="html">RT #{note.data["object"]["content"]}</content>
|
<content type="html">RT #{note.data["object"]["content"]}</content>
|
||||||
<published>#{inserted_at}</published>
|
<published>#{announce.data["published"]}</published>
|
||||||
<updated>#{updated_at}</updated>
|
<updated>#{announce.data["published"]}</updated>
|
||||||
<ostatus:conversation>#{announce.data["context"]}</ostatus:conversation>
|
<ostatus:conversation>#{announce.data["context"]}</ostatus:conversation>
|
||||||
<link href="#{announce.data["context"]}" rel="ostatus:conversation" />
|
<link href="#{announce.data["context"]}" rel="ostatus:conversation" />
|
||||||
<link rel="self" type="application/atom+xml" href="#{announce.data["id"]}"/>
|
<link rel="self" type="application/atom+xml" href="#{announce.data["id"]}"/>
|
||||||
|
@ -126,12 +112,6 @@ test "a like activity" do
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
{:ok, like, _note} = ActivityPub.like(user, note)
|
{:ok, like, _note} = ActivityPub.like(user, note)
|
||||||
|
|
||||||
# TODO: Are these the correct dates?
|
|
||||||
updated_at = like.updated_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
inserted_at = like.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
tuple = ActivityRepresenter.to_simple_form(like, user)
|
tuple = ActivityRepresenter.to_simple_form(like, user)
|
||||||
refute is_nil(tuple)
|
refute is_nil(tuple)
|
||||||
|
|
||||||
|
@ -142,8 +122,8 @@ test "a like activity" do
|
||||||
<id>#{like.data["id"]}</id>
|
<id>#{like.data["id"]}</id>
|
||||||
<title>New favorite by #{user.nickname}</title>
|
<title>New favorite by #{user.nickname}</title>
|
||||||
<content type="html">#{user.nickname} favorited something</content>
|
<content type="html">#{user.nickname} favorited something</content>
|
||||||
<published>#{inserted_at}</published>
|
<published>#{like.data["published"]}</published>
|
||||||
<updated>#{updated_at}</updated>
|
<updated>#{like.data["published"]}</updated>
|
||||||
<activity:object>
|
<activity:object>
|
||||||
<activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type>
|
<activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type>
|
||||||
<id>#{note.data["id"]}</id>
|
<id>#{note.data["id"]}</id>
|
||||||
|
@ -168,13 +148,6 @@ test "a follow activity" do
|
||||||
"to" => [followed.ap_id]
|
"to" => [followed.ap_id]
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
# TODO: Are these the correct dates?
|
|
||||||
updated_at = activity.updated_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
tuple = ActivityRepresenter.to_simple_form(activity, follower)
|
tuple = ActivityRepresenter.to_simple_form(activity, follower)
|
||||||
|
|
||||||
refute is_nil(tuple)
|
refute is_nil(tuple)
|
||||||
|
@ -187,8 +160,8 @@ test "a follow activity" do
|
||||||
<id>#{activity.data["id"]}</id>
|
<id>#{activity.data["id"]}</id>
|
||||||
<title>#{follower.nickname} started following #{activity.data["object"]}</title>
|
<title>#{follower.nickname} started following #{activity.data["object"]}</title>
|
||||||
<content type="html"> #{follower.nickname} started following #{activity.data["object"]}</content>
|
<content type="html"> #{follower.nickname} started following #{activity.data["object"]}</content>
|
||||||
<published>#{inserted_at}</published>
|
<published>#{activity.data["published"]}</published>
|
||||||
<updated>#{updated_at}</updated>
|
<updated>#{activity.data["published"]}</updated>
|
||||||
<activity:object>
|
<activity:object>
|
||||||
<activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type>
|
<activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type>
|
||||||
<id>#{activity.data["object"]}</id>
|
<id>#{activity.data["object"]}</id>
|
||||||
|
@ -207,12 +180,6 @@ test "an unfollow activity" do
|
||||||
{:ok, _activity} = ActivityPub.follow(follower, followed)
|
{:ok, _activity} = ActivityPub.follow(follower, followed)
|
||||||
{:ok, activity} = ActivityPub.unfollow(follower, followed)
|
{:ok, activity} = ActivityPub.unfollow(follower, followed)
|
||||||
|
|
||||||
# TODO: Are these the correct dates?
|
|
||||||
updated_at = activity.updated_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
inserted_at = activity.inserted_at
|
|
||||||
|> NaiveDateTime.to_iso8601
|
|
||||||
|
|
||||||
tuple = ActivityRepresenter.to_simple_form(activity, follower)
|
tuple = ActivityRepresenter.to_simple_form(activity, follower)
|
||||||
|
|
||||||
refute is_nil(tuple)
|
refute is_nil(tuple)
|
||||||
|
@ -225,8 +192,8 @@ test "an unfollow activity" do
|
||||||
<id>#{activity.data["id"]}</id>
|
<id>#{activity.data["id"]}</id>
|
||||||
<title>#{follower.nickname} stopped following #{followed.ap_id}</title>
|
<title>#{follower.nickname} stopped following #{followed.ap_id}</title>
|
||||||
<content type="html"> #{follower.nickname} stopped following #{followed.ap_id}</content>
|
<content type="html"> #{follower.nickname} stopped following #{followed.ap_id}</content>
|
||||||
<published>#{inserted_at}</published>
|
<published>#{activity.data["published"]}</published>
|
||||||
<updated>#{updated_at}</updated>
|
<updated>#{activity.data["published"]}</updated>
|
||||||
<activity:object>
|
<activity:object>
|
||||||
<activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type>
|
<activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type>
|
||||||
<id>#{followed.ap_id}</id>
|
<id>#{followed.ap_id}</id>
|
||||||
|
|
Loading…
Reference in a new issue