Accept status_map and spoiler_text_map in POST statuses
Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
parent
0d96c04019
commit
72a2b3329e
3 changed files with 105 additions and 11 deletions
|
@ -168,18 +168,17 @@ defp summary(%{params: params} = draft) do
|
||||||
%__MODULE__{draft | summary: Map.get(params, :spoiler_text, "")}
|
%__MODULE__{draft | summary: Map.get(params, :spoiler_text, "")}
|
||||||
end
|
end
|
||||||
|
|
||||||
defp full_payload(%{status_map: status_map, summary_map: summary_map} = draft) do
|
defp full_payload(%{status: status, status_map: nil} = draft) do
|
||||||
status = status_map |> Enum.reduce("", fn {_lang, content}, acc -> acc <> content end)
|
full_payload(%__MODULE__{draft | status_map: %{"und" => status}})
|
||||||
summary = summary_map |> Enum.reduce("", fn {_lang, content}, acc -> acc <> content end)
|
|
||||||
full_payload = String.trim(status <> summary)
|
|
||||||
|
|
||||||
case Utils.validate_character_limit(full_payload, draft.attachments) do
|
|
||||||
:ok -> %__MODULE__{draft | full_payload: full_payload}
|
|
||||||
{:error, message} -> add_error(draft, message)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
defp full_payload(%{status: status, summary: summary} = draft) do
|
defp full_payload(%{summary: summary, summary_map: nil} = draft) do
|
||||||
|
full_payload(%__MODULE__{draft | summary_map: %{"und" => summary}})
|
||||||
|
end
|
||||||
|
|
||||||
|
defp full_payload(%{status_map: %{} = status_map, summary_map: %{} = summary_map} = draft) do
|
||||||
|
status = status_map |> Enum.reduce("", fn {_lang, content}, acc -> acc <> content end)
|
||||||
|
summary = summary_map |> Enum.reduce("", fn {_lang, content}, acc -> acc <> content end)
|
||||||
full_payload = String.trim(status <> summary)
|
full_payload = String.trim(status <> summary)
|
||||||
|
|
||||||
case Utils.validate_character_limit(full_payload, draft.attachments) do
|
case Utils.validate_character_limit(full_payload, draft.attachments) do
|
||||||
|
@ -497,7 +496,7 @@ defp validate(%{errors: [message | _]}), do: {:error, message}
|
||||||
defp differentiate_string_map(%{} = map), do: {nil, map}
|
defp differentiate_string_map(%{} = map), do: {nil, map}
|
||||||
defp differentiate_string_map(str) when is_binary(str), do: {str, nil}
|
defp differentiate_string_map(str) when is_binary(str), do: {str, nil}
|
||||||
|
|
||||||
defp get_source_map(%{status_map: status_map} = _draft) do
|
defp get_source_map(%{status_map: %{} = status_map} = _draft) do
|
||||||
%{
|
%{
|
||||||
"content" => Pleroma.MultiLanguage.map_to_str(status_map, mutiline: true),
|
"content" => Pleroma.MultiLanguage.map_to_str(status_map, mutiline: true),
|
||||||
"contentMap" => status_map
|
"contentMap" => status_map
|
||||||
|
|
|
@ -232,6 +232,26 @@ defp do_create(
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def create(
|
||||||
|
%{
|
||||||
|
assigns: %{user: _user},
|
||||||
|
private: %{open_api_spex: %{body_params: %{status_map: _}}} = params
|
||||||
|
} = conn,
|
||||||
|
_
|
||||||
|
) do
|
||||||
|
create(conn |> put_in([:private, :open_api_spex, :body_params, :status], ""), %{})
|
||||||
|
end
|
||||||
|
|
||||||
|
def create(
|
||||||
|
%{
|
||||||
|
assigns: %{user: _user},
|
||||||
|
private: %{open_api_spex: %{body_params: %{media_ids: _}}} = params
|
||||||
|
} = conn,
|
||||||
|
_
|
||||||
|
) do
|
||||||
|
create(conn |> put_in([:private, :open_api_spex, :body_params, :status], ""), %{})
|
||||||
|
end
|
||||||
|
|
||||||
@doc "GET /api/v1/statuses/:id/history"
|
@doc "GET /api/v1/statuses/:id/history"
|
||||||
def show_history(
|
def show_history(
|
||||||
%{assigns: assigns, private: %{open_api_spex: %{params: %{id: id} = params}}} = conn,
|
%{assigns: assigns, private: %{open_api_spex: %{params: %{id: id} = params}}} = conn,
|
||||||
|
|
|
@ -139,6 +139,81 @@ test "posting a status", %{conn: conn} do
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "posting a multilang status", %{conn: conn} do
|
||||||
|
idempotency_key = "Pikachu rocks!"
|
||||||
|
|
||||||
|
conn_one =
|
||||||
|
conn
|
||||||
|
|> put_req_header("content-type", "application/json")
|
||||||
|
|> put_req_header("idempotency-key", idempotency_key)
|
||||||
|
|> post("/api/v1/statuses", %{
|
||||||
|
"status_map" => %{"a" => "mew mew", "b" => "lol lol"},
|
||||||
|
"spoiler_text_map" => %{"a" => "mew", "b" => "lol"},
|
||||||
|
"sensitive" => "0"
|
||||||
|
})
|
||||||
|
|
||||||
|
assert %{
|
||||||
|
"content" => _content,
|
||||||
|
"content_map" => %{"a" => "mew mew", "b" => "lol lol"},
|
||||||
|
"id" => id,
|
||||||
|
"spoiler_text" => _spoiler_text,
|
||||||
|
"spoiler_text_map" => %{"a" => "mew", "b" => "lol"},
|
||||||
|
"sensitive" => false
|
||||||
|
} = json_response_and_validate_schema(conn_one, 200)
|
||||||
|
|
||||||
|
assert Activity.get_by_id(id)
|
||||||
|
end
|
||||||
|
|
||||||
|
test "posting a multilang status with singlelang summary", %{conn: conn} do
|
||||||
|
idempotency_key = "Pikachu rocks!"
|
||||||
|
|
||||||
|
conn_one =
|
||||||
|
conn
|
||||||
|
|> put_req_header("content-type", "application/json")
|
||||||
|
|> put_req_header("idempotency-key", idempotency_key)
|
||||||
|
|> post("/api/v1/statuses", %{
|
||||||
|
"status_map" => %{"a" => "mew mew", "b" => "lol lol"},
|
||||||
|
"spoiler_text" => "mewlol",
|
||||||
|
"sensitive" => "0"
|
||||||
|
})
|
||||||
|
|
||||||
|
assert %{
|
||||||
|
"content" => _content,
|
||||||
|
"content_map" => %{"a" => "mew mew", "b" => "lol lol"},
|
||||||
|
"id" => id,
|
||||||
|
"spoiler_text" => "mewlol",
|
||||||
|
"spoiler_text_map" => %{},
|
||||||
|
"sensitive" => false
|
||||||
|
} = json_response_and_validate_schema(conn_one, 200)
|
||||||
|
|
||||||
|
assert Activity.get_by_id(id)
|
||||||
|
end
|
||||||
|
|
||||||
|
test "posting a multilang summary with singlelang status", %{conn: conn} do
|
||||||
|
idempotency_key = "Pikachu rocks!"
|
||||||
|
|
||||||
|
conn_one =
|
||||||
|
conn
|
||||||
|
|> put_req_header("content-type", "application/json")
|
||||||
|
|> put_req_header("idempotency-key", idempotency_key)
|
||||||
|
|> post("/api/v1/statuses", %{
|
||||||
|
"spoiler_text_map" => %{"a" => "mew mew", "b" => "lol lol"},
|
||||||
|
"status" => "mewlol",
|
||||||
|
"sensitive" => "0"
|
||||||
|
})
|
||||||
|
|
||||||
|
assert %{
|
||||||
|
"content" => "mewlol",
|
||||||
|
"content_map" => %{},
|
||||||
|
"id" => id,
|
||||||
|
"spoiler_text" => _,
|
||||||
|
"spoiler_text_map" => %{"a" => "mew mew", "b" => "lol lol"},
|
||||||
|
"sensitive" => false
|
||||||
|
} = json_response_and_validate_schema(conn_one, 200)
|
||||||
|
|
||||||
|
assert Activity.get_by_id(id)
|
||||||
|
end
|
||||||
|
|
||||||
test "posting a quote post", %{conn: conn} do
|
test "posting a quote post", %{conn: conn} do
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue