forked from AkkomaGang/akkoma
ActivityPub: Handle incoming announces.
This commit is contained in:
parent
e3732ea3bc
commit
81ea359a7c
2 changed files with 21 additions and 0 deletions
|
@ -73,6 +73,16 @@ def handle_incoming(%{"type" => "Like", "object" => object_id, "actor" => actor,
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def handle_incoming(%{"type" => "Announce", "object" => object_id, "actor" => actor, "id" => id} = data) do
|
||||||
|
with %User{} = actor <- User.get_or_fetch_by_ap_id(actor),
|
||||||
|
{:ok, object} <- ActivityPub.fetch_object_from_id(object_id),
|
||||||
|
{:ok, activity, object} <- ActivityPub.announce(actor, object, id, false) do
|
||||||
|
{:ok, activity}
|
||||||
|
else
|
||||||
|
_e -> :error
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# TODO
|
# TODO
|
||||||
# Accept
|
# Accept
|
||||||
# Undo
|
# Undo
|
||||||
|
|
|
@ -62,6 +62,17 @@ test "it works for incoming likes" do
|
||||||
assert data["id"] == "http://mastodon.example.org/users/admin#likes/2"
|
assert data["id"] == "http://mastodon.example.org/users/admin#likes/2"
|
||||||
assert data["object"] == activity.data["object"]["id"]
|
assert data["object"] == activity.data["object"]["id"]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "it works for incoming announces" do
|
||||||
|
data = File.read!("test/fixtures/mastodon-announce.json") |> Poison.decode!
|
||||||
|
|
||||||
|
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
||||||
|
|
||||||
|
assert data["actor"] == "http://mastodon.example.org/users/admin"
|
||||||
|
assert data["type"] == "Announce"
|
||||||
|
assert data["id"] == "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
||||||
|
assert data["object"] == "http://mastodon.example.org/users/admin/statuses/99541947525187367"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "prepare outgoing" do
|
describe "prepare outgoing" do
|
||||||
|
|
Loading…
Reference in a new issue