Merge branch 'scrobbles' into fork
This commit is contained in:
commit
a82c081ee0
7 changed files with 48 additions and 12 deletions
1
changelog.d/scrobbles.change
Normal file
1
changelog.d/scrobbles.change
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Change scrobble external link param name to use snake case
|
|
@ -779,6 +779,7 @@ The status posting endpoint takes an additional parameter, `in_reply_to_conversa
|
||||||
"artist": "Some Artist",
|
"artist": "Some Artist",
|
||||||
"album": "Some Album",
|
"album": "Some Album",
|
||||||
"length": 180000,
|
"length": 180000,
|
||||||
|
"external_link": "https://www.last.fm/music/Some+Artist/_/Some+Title",
|
||||||
"created_at": "2019-09-28T12:40:45.000Z"
|
"created_at": "2019-09-28T12:40:45.000Z"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -57,11 +57,15 @@ defp create_request do
|
||||||
album: %Schema{type: :string, description: "The album of the media playing"},
|
album: %Schema{type: :string, description: "The album of the media playing"},
|
||||||
artist: %Schema{type: :string, description: "The artist of the media playing"},
|
artist: %Schema{type: :string, description: "The artist of the media playing"},
|
||||||
length: %Schema{type: :integer, description: "The length of the media playing"},
|
length: %Schema{type: :integer, description: "The length of the media playing"},
|
||||||
externalLink: %Schema{type: :string, description: "A URL referencing the media playing"},
|
external_link: %Schema{type: :string, description: "A URL referencing the media playing"},
|
||||||
visibility: %Schema{
|
visibility: %Schema{
|
||||||
allOf: [VisibilityScope],
|
allOf: [VisibilityScope],
|
||||||
default: "public",
|
default: "public",
|
||||||
description: "Scrobble visibility"
|
description: "Scrobble visibility"
|
||||||
|
},
|
||||||
|
externalLink: %Schema{
|
||||||
|
type: :string,
|
||||||
|
description: "Deprecated, use `external_link` instead"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
example: %{
|
example: %{
|
||||||
|
@ -69,7 +73,7 @@ defp create_request do
|
||||||
"artist" => "Some Artist",
|
"artist" => "Some Artist",
|
||||||
"album" => "Some Album",
|
"album" => "Some Album",
|
||||||
"length" => 180_000,
|
"length" => 180_000,
|
||||||
"externalLink" => "https://www.last.fm/music/Some+Artist/_/Some+Title"
|
"external_link" => "https://www.last.fm/music/Some+Artist/_/Some+Title"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
@ -83,7 +87,7 @@ defp scrobble do
|
||||||
title: %Schema{type: :string, description: "The title of the media playing"},
|
title: %Schema{type: :string, description: "The title of the media playing"},
|
||||||
album: %Schema{type: :string, description: "The album of the media playing"},
|
album: %Schema{type: :string, description: "The album of the media playing"},
|
||||||
artist: %Schema{type: :string, description: "The artist of the media playing"},
|
artist: %Schema{type: :string, description: "The artist of the media playing"},
|
||||||
externalLink: %Schema{type: :string, description: "A URL referencing the media playing"},
|
external_link: %Schema{type: :string, description: "A URL referencing the media playing"},
|
||||||
length: %Schema{
|
length: %Schema{
|
||||||
type: :integer,
|
type: :integer,
|
||||||
description: "The length of the media playing",
|
description: "The length of the media playing",
|
||||||
|
@ -98,7 +102,7 @@ defp scrobble do
|
||||||
"artist" => "Some Artist",
|
"artist" => "Some Artist",
|
||||||
"album" => "Some Album",
|
"album" => "Some Album",
|
||||||
"length" => 180_000,
|
"length" => 180_000,
|
||||||
"externalLink" => "https://www.last.fm/music/Some+Artist/_/Some+Title",
|
"external_link" => "https://www.last.fm/music/Some+Artist/_/Some+Title",
|
||||||
"created_at" => "2019-09-28T12:40:45.000Z"
|
"created_at" => "2019-09-28T12:40:45.000Z"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,7 +97,8 @@ def listen(user, params) do
|
||||||
defp listen_object(draft) do
|
defp listen_object(draft) do
|
||||||
object =
|
object =
|
||||||
draft.params
|
draft.params
|
||||||
|> Map.take([:album, :artist, :title, :length, :externalLink])
|
|> Map.take([:album, :artist, :title, :length])
|
||||||
|
|> Map.put(:externalLink, Map.get(draft.params, :external_link))
|
||||||
|> Map.new(fn {key, value} -> {to_string(key), value} end)
|
|> Map.new(fn {key, value} -> {to_string(key), value} end)
|
||||||
|> Map.put("type", "Audio")
|
|> Map.put("type", "Audio")
|
||||||
|> Map.put("to", draft.to)
|
|> Map.put("to", draft.to)
|
||||||
|
|
|
@ -24,6 +24,10 @@ defmodule Pleroma.Web.PleromaAPI.ScrobbleController do
|
||||||
defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.PleromaScrobbleOperation
|
defdelegate open_api_operation(action), to: Pleroma.Web.ApiSpec.PleromaScrobbleOperation
|
||||||
|
|
||||||
def create(%{assigns: %{user: user}, body_params: params} = conn, _) do
|
def create(%{assigns: %{user: user}, body_params: params} = conn, _) do
|
||||||
|
params =
|
||||||
|
params
|
||||||
|
|> Map.put_new(:external_link, Map.get(params, :externalLink))
|
||||||
|
|
||||||
with {:ok, activity} <- CommonAPI.listen(user, params) do
|
with {:ok, activity} <- CommonAPI.listen(user, params) do
|
||||||
render(conn, "show.json", activity: activity, for: user)
|
render(conn, "show.json", activity: activity, for: user)
|
||||||
else
|
else
|
||||||
|
|
|
@ -27,8 +27,10 @@ def render("show.json", %{activity: %Activity{data: %{"type" => "Listen"}} = act
|
||||||
title: object.data["title"] |> HTML.strip_tags(),
|
title: object.data["title"] |> HTML.strip_tags(),
|
||||||
artist: object.data["artist"] |> HTML.strip_tags(),
|
artist: object.data["artist"] |> HTML.strip_tags(),
|
||||||
album: object.data["album"] |> HTML.strip_tags(),
|
album: object.data["album"] |> HTML.strip_tags(),
|
||||||
externalLink: object.data["externalLink"],
|
external_link: object.data["externalLink"],
|
||||||
length: object.data["length"]
|
length: object.data["length"],
|
||||||
|
# DEPRECATED
|
||||||
|
externalLink: object.data["externalLink"]
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -19,10 +19,33 @@ test "works correctly" do
|
||||||
"artist" => "lain",
|
"artist" => "lain",
|
||||||
"album" => "lain radio",
|
"album" => "lain radio",
|
||||||
"length" => "180000",
|
"length" => "180000",
|
||||||
"externalLink" => "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+1"
|
"external_link" => "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+1"
|
||||||
})
|
})
|
||||||
|
|
||||||
assert %{"title" => "lain radio episode 1"} = json_response_and_validate_schema(conn, 200)
|
assert %{
|
||||||
|
"title" => "lain radio episode 1",
|
||||||
|
"external_link" => "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+1"
|
||||||
|
} = json_response_and_validate_schema(conn, 200)
|
||||||
|
end
|
||||||
|
|
||||||
|
test "external_link fallback" do
|
||||||
|
%{conn: conn} = oauth_access(["write"])
|
||||||
|
|
||||||
|
conn =
|
||||||
|
conn
|
||||||
|
|> put_req_header("content-type", "application/json")
|
||||||
|
|> post("/api/v1/pleroma/scrobble", %{
|
||||||
|
"title" => "lain radio episode 2",
|
||||||
|
"artist" => "lain",
|
||||||
|
"album" => "lain radio",
|
||||||
|
"length" => "180000",
|
||||||
|
"externalLink" => "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+2"
|
||||||
|
})
|
||||||
|
|
||||||
|
assert %{
|
||||||
|
"title" => "lain radio episode 2",
|
||||||
|
"external_link" => "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+2"
|
||||||
|
} = json_response_and_validate_schema(conn, 200)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -35,7 +58,7 @@ test "works correctly" do
|
||||||
title: "lain radio episode 1",
|
title: "lain radio episode 1",
|
||||||
artist: "lain",
|
artist: "lain",
|
||||||
album: "lain radio",
|
album: "lain radio",
|
||||||
externalLink: "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+1"
|
external_link: "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+1"
|
||||||
})
|
})
|
||||||
|
|
||||||
{:ok, _activity} =
|
{:ok, _activity} =
|
||||||
|
@ -43,7 +66,7 @@ test "works correctly" do
|
||||||
title: "lain radio episode 2",
|
title: "lain radio episode 2",
|
||||||
artist: "lain",
|
artist: "lain",
|
||||||
album: "lain radio",
|
album: "lain radio",
|
||||||
externalLink: "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+2"
|
external_link: "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+2"
|
||||||
})
|
})
|
||||||
|
|
||||||
{:ok, _activity} =
|
{:ok, _activity} =
|
||||||
|
@ -51,7 +74,7 @@ test "works correctly" do
|
||||||
title: "lain radio episode 3",
|
title: "lain radio episode 3",
|
||||||
artist: "lain",
|
artist: "lain",
|
||||||
album: "lain radio",
|
album: "lain radio",
|
||||||
externalLink: "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+3"
|
external_link: "https://www.last.fm/music/lain/lain+radio/lain+radio+episode+3"
|
||||||
})
|
})
|
||||||
|
|
||||||
conn = get(conn, "/api/v1/pleroma/accounts/#{user.id}/scrobbles")
|
conn = get(conn, "/api/v1/pleroma/accounts/#{user.id}/scrobbles")
|
||||||
|
|
Loading…
Reference in a new issue