Undo formatting in user.ex
This commit is contained in:
parent
d8c842a771
commit
e6dc15b96c
|
@ -241,24 +241,6 @@ def handle_incoming(
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def handle_incoming(
|
|
||||||
%{
|
|
||||||
"type" => "Undo",
|
|
||||||
"object" => %{"type" => "Follow", "object" => followed},
|
|
||||||
"actor" => follower,
|
|
||||||
"id" => id
|
|
||||||
} = data
|
|
||||||
) do
|
|
||||||
with %User{local: true} = followed = User.get_cached_by_ap_id(followed),
|
|
||||||
%User{} = follower = User.get_or_fetch_by_ap_id(follower),
|
|
||||||
{:ok, activity} <- ActivityPub.unfollow(follower, followed, false) do
|
|
||||||
User.unfollow(follower, followed)
|
|
||||||
{:ok, activity}
|
|
||||||
else
|
|
||||||
e -> :error
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# TODO
|
# TODO
|
||||||
# Accept
|
# Accept
|
||||||
# Undo for non-Announce
|
# Undo for non-Announce
|
||||||
|
|
33
test/fixtures/mastodon-unfollow-activity.json
vendored
33
test/fixtures/mastodon-unfollow-activity.json
vendored
|
@ -1,33 +0,0 @@
|
||||||
{
|
|
||||||
"@context": [
|
|
||||||
"https://www.w3.org/ns/activitystreams",
|
|
||||||
"https://w3id.org/security/v1",
|
|
||||||
{
|
|
||||||
"toot": "http://joinmastodon.org/ns#",
|
|
||||||
"sensitive": "as:sensitive",
|
|
||||||
"ostatus": "http://ostatus.org#",
|
|
||||||
"movedTo": "as:movedTo",
|
|
||||||
"manuallyApprovesFollowers": "as:manuallyApprovesFollowers",
|
|
||||||
"inReplyToAtomUri": "ostatus:inReplyToAtomUri",
|
|
||||||
"conversation": "ostatus:conversation",
|
|
||||||
"atomUri": "ostatus:atomUri",
|
|
||||||
"Hashtag": "as:Hashtag",
|
|
||||||
"Emoji": "toot:Emoji"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"signature": {
|
|
||||||
"type": "RsaSignature2017",
|
|
||||||
"signatureValue": "Kn1/UkAQGJVaXBfWLAHcnwHg8YMAUqlEaBuYLazAG+pz5hqivsyrBmPV186Xzr+B4ZLExA9+SnOoNx/GOz4hBm0kAmukNSILAsUd84tcJ2yT9zc1RKtembK4WiwOw7li0+maeDN0HaB6t+6eTqsCWmtiZpprhXD8V1GGT8yG7X24fQ9oFGn+ng7lasbcCC0988Y1eGqNe7KryxcPuQz57YkDapvtONzk8gyLTkZMV4De93MyRHq6GVjQVIgtiYabQAxrX6Q8C+4P/jQoqdWJHEe+MY5JKyNaT/hMPt2Md1ok9fZQBGHlErk22/zy8bSN19GdG09HmIysBUHRYpBLig==",
|
|
||||||
"creator": "http://mastodon.example.org/users/admin#main-key",
|
|
||||||
"created": "2018-02-17T13:29:31Z"
|
|
||||||
},
|
|
||||||
"type": "Undo",
|
|
||||||
"object": {
|
|
||||||
"type": "Follow",
|
|
||||||
"object": "http://localtesting.pleroma.lol/users/lain",
|
|
||||||
"nickname": "lain",
|
|
||||||
"id": "http://mastodon.example.org/users/admin#follows/2",
|
|
||||||
"actor": "http://mastodon.example.org/users/admin"
|
|
||||||
},
|
|
||||||
"actor": "http://mastodon.example.org/users/admin"
|
|
||||||
}
|
|
|
@ -260,30 +260,6 @@ test "it works for incoming unannounces with an existing notice" do
|
||||||
assert data["object"]["id"] ==
|
assert data["object"]["id"] ==
|
||||||
"http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
"http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it works for incomming unfollows" do
|
|
||||||
user = insert(:user)
|
|
||||||
|
|
||||||
follow_data =
|
|
||||||
File.read!("test/fixtures/mastodon-follow-activity.json")
|
|
||||||
|> Poison.decode!()
|
|
||||||
|> Map.put("object", user.ap_id)
|
|
||||||
|
|
||||||
{:ok, %Activity{data: _, local: false}} = Transmogrifier.handle_incoming(follow_data)
|
|
||||||
|
|
||||||
data =
|
|
||||||
File.read!("test/fixtures/mastodon-unfollow-activity.json")
|
|
||||||
|> Poison.decode!()
|
|
||||||
|> Map.put("object", follow_data)
|
|
||||||
|
|
||||||
{:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data)
|
|
||||||
|
|
||||||
assert data["type"] == "Undo"
|
|
||||||
assert data["object"]["type"] == "Follow"
|
|
||||||
assert data["actor"] == "http://mastodon.example.org/users/admin"
|
|
||||||
|
|
||||||
refute User.following?(User.get_by_ap_id(data["actor"]), user)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "prepare outgoing" do
|
describe "prepare outgoing" do
|
||||||
|
|
Loading…
Reference in a new issue