added Pleroma.Web.PleromaAPI.EmojiFileController
This commit is contained in:
parent
3d5d8c05c9
commit
7794d7c694
@ -0,0 +1,133 @@
|
|||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Web.ApiSpec.PleromaEmojiFileOperation do
|
||||||
|
alias OpenApiSpex.Operation
|
||||||
|
alias OpenApiSpex.Schema
|
||||||
|
alias Pleroma.Web.ApiSpec.Schemas.ApiError
|
||||||
|
|
||||||
|
import Pleroma.Web.ApiSpec.Helpers
|
||||||
|
|
||||||
|
def open_api_operation(action) do
|
||||||
|
operation = String.to_existing_atom("#{action}_operation")
|
||||||
|
apply(__MODULE__, operation, [])
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_operation do
|
||||||
|
%Operation{
|
||||||
|
tags: ["Emoji Packs"],
|
||||||
|
summary: "Add new file to the pack",
|
||||||
|
operationId: "PleromaAPI.EmojiPackController.add_file",
|
||||||
|
security: [%{"oAuth" => ["write"]}],
|
||||||
|
requestBody: request_body("Parameters", create_request(), required: true),
|
||||||
|
parameters: [name_param()],
|
||||||
|
responses: %{
|
||||||
|
200 => Operation.response("Files Object", "application/json", files_object()),
|
||||||
|
400 => Operation.response("Bad Request", "application/json", ApiError),
|
||||||
|
409 => Operation.response("Conflict", "application/json", ApiError)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
defp create_request do
|
||||||
|
%Schema{
|
||||||
|
type: :object,
|
||||||
|
required: [:file],
|
||||||
|
properties: %{
|
||||||
|
file: %Schema{
|
||||||
|
description:
|
||||||
|
"File needs to be uploaded with the multipart request or link to remote file",
|
||||||
|
anyOf: [
|
||||||
|
%Schema{type: :string, format: :binary},
|
||||||
|
%Schema{type: :string, format: :uri}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
shortcode: %Schema{
|
||||||
|
type: :string,
|
||||||
|
description:
|
||||||
|
"Shortcode for new emoji, must be unique for all emoji. If not sended, shortcode will be taken from original filename."
|
||||||
|
},
|
||||||
|
filename: %Schema{
|
||||||
|
type: :string,
|
||||||
|
description:
|
||||||
|
"New emoji file name. If not specified will be taken from original filename."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def update_operation do
|
||||||
|
%Operation{
|
||||||
|
tags: ["Emoji Packs"],
|
||||||
|
summary: "Add new file to the pack",
|
||||||
|
operationId: "PleromaAPI.EmojiPackController.update_file",
|
||||||
|
security: [%{"oAuth" => ["write"]}],
|
||||||
|
requestBody: request_body("Parameters", update_request(), required: true),
|
||||||
|
parameters: [name_param()],
|
||||||
|
responses: %{
|
||||||
|
200 => Operation.response("Files Object", "application/json", files_object()),
|
||||||
|
400 => Operation.response("Bad Request", "application/json", ApiError),
|
||||||
|
409 => Operation.response("Conflict", "application/json", ApiError)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
defp update_request do
|
||||||
|
%Schema{
|
||||||
|
type: :object,
|
||||||
|
required: [:shortcode, :new_shortcode, :new_filename],
|
||||||
|
properties: %{
|
||||||
|
shortcode: %Schema{
|
||||||
|
type: :string,
|
||||||
|
description: "Emoji file shortcode"
|
||||||
|
},
|
||||||
|
new_shortcode: %Schema{
|
||||||
|
type: :string,
|
||||||
|
description: "New emoji file shortcode"
|
||||||
|
},
|
||||||
|
new_filename: %Schema{
|
||||||
|
type: :string,
|
||||||
|
description: "New filename for emoji file"
|
||||||
|
},
|
||||||
|
force: %Schema{
|
||||||
|
type: :boolean,
|
||||||
|
description: "With true value to overwrite existing emoji with new shortcode",
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete_operation do
|
||||||
|
%Operation{
|
||||||
|
tags: ["Emoji Packs"],
|
||||||
|
summary: "Delete emoji file from pack",
|
||||||
|
operationId: "PleromaAPI.EmojiPackController.delete_file",
|
||||||
|
security: [%{"oAuth" => ["write"]}],
|
||||||
|
parameters: [
|
||||||
|
name_param(),
|
||||||
|
Operation.parameter(:shortcode, :query, :string, "File shortcode",
|
||||||
|
example: "cofe",
|
||||||
|
required: true
|
||||||
|
)
|
||||||
|
],
|
||||||
|
responses: %{
|
||||||
|
200 => Operation.response("Files Object", "application/json", files_object()),
|
||||||
|
400 => Operation.response("Bad Request", "application/json", ApiError)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
defp name_param do
|
||||||
|
Operation.parameter(:name, :path, :string, "Pack Name", example: "cofe", required: true)
|
||||||
|
end
|
||||||
|
|
||||||
|
defp files_object do
|
||||||
|
%Schema{
|
||||||
|
type: :object,
|
||||||
|
additionalProperties: %Schema{type: :string},
|
||||||
|
description: "Object with emoji names as keys and filenames as values"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
@ -175,111 +175,6 @@ defmodule Pleroma.Web.ApiSpec.PleromaEmojiPackOperation do
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def add_file_operation do
|
|
||||||
%Operation{
|
|
||||||
tags: ["Emoji Packs"],
|
|
||||||
summary: "Add new file to the pack",
|
|
||||||
operationId: "PleromaAPI.EmojiPackController.add_file",
|
|
||||||
security: [%{"oAuth" => ["write"]}],
|
|
||||||
requestBody: request_body("Parameters", add_file_request(), required: true),
|
|
||||||
parameters: [name_param()],
|
|
||||||
responses: %{
|
|
||||||
200 => Operation.response("Files Object", "application/json", files_object()),
|
|
||||||
400 => Operation.response("Bad Request", "application/json", ApiError),
|
|
||||||
409 => Operation.response("Conflict", "application/json", ApiError)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
defp add_file_request do
|
|
||||||
%Schema{
|
|
||||||
type: :object,
|
|
||||||
required: [:file],
|
|
||||||
properties: %{
|
|
||||||
file: %Schema{
|
|
||||||
description:
|
|
||||||
"File needs to be uploaded with the multipart request or link to remote file",
|
|
||||||
anyOf: [
|
|
||||||
%Schema{type: :string, format: :binary},
|
|
||||||
%Schema{type: :string, format: :uri}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
shortcode: %Schema{
|
|
||||||
type: :string,
|
|
||||||
description:
|
|
||||||
"Shortcode for new emoji, must be unique for all emoji. If not sended, shortcode will be taken from original filename."
|
|
||||||
},
|
|
||||||
filename: %Schema{
|
|
||||||
type: :string,
|
|
||||||
description:
|
|
||||||
"New emoji file name. If not specified will be taken from original filename."
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
def update_file_operation do
|
|
||||||
%Operation{
|
|
||||||
tags: ["Emoji Packs"],
|
|
||||||
summary: "Add new file to the pack",
|
|
||||||
operationId: "PleromaAPI.EmojiPackController.update_file",
|
|
||||||
security: [%{"oAuth" => ["write"]}],
|
|
||||||
requestBody: request_body("Parameters", update_file_request(), required: true),
|
|
||||||
parameters: [name_param()],
|
|
||||||
responses: %{
|
|
||||||
200 => Operation.response("Files Object", "application/json", files_object()),
|
|
||||||
400 => Operation.response("Bad Request", "application/json", ApiError),
|
|
||||||
409 => Operation.response("Conflict", "application/json", ApiError)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
defp update_file_request do
|
|
||||||
%Schema{
|
|
||||||
type: :object,
|
|
||||||
required: [:shortcode, :new_shortcode, :new_filename],
|
|
||||||
properties: %{
|
|
||||||
shortcode: %Schema{
|
|
||||||
type: :string,
|
|
||||||
description: "Emoji file shortcode"
|
|
||||||
},
|
|
||||||
new_shortcode: %Schema{
|
|
||||||
type: :string,
|
|
||||||
description: "New emoji file shortcode"
|
|
||||||
},
|
|
||||||
new_filename: %Schema{
|
|
||||||
type: :string,
|
|
||||||
description: "New filename for emoji file"
|
|
||||||
},
|
|
||||||
force: %Schema{
|
|
||||||
type: :boolean,
|
|
||||||
description: "With true value to overwrite existing emoji with new shortcode",
|
|
||||||
default: false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
def delete_file_operation do
|
|
||||||
%Operation{
|
|
||||||
tags: ["Emoji Packs"],
|
|
||||||
summary: "Delete emoji file from pack",
|
|
||||||
operationId: "PleromaAPI.EmojiPackController.delete_file",
|
|
||||||
security: [%{"oAuth" => ["write"]}],
|
|
||||||
parameters: [
|
|
||||||
name_param(),
|
|
||||||
Operation.parameter(:shortcode, :query, :string, "File shortcode",
|
|
||||||
example: "cofe",
|
|
||||||
required: true
|
|
||||||
)
|
|
||||||
],
|
|
||||||
responses: %{
|
|
||||||
200 => Operation.response("Files Object", "application/json", files_object()),
|
|
||||||
400 => Operation.response("Bad Request", "application/json", ApiError)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
def import_from_filesystem_operation do
|
def import_from_filesystem_operation do
|
||||||
%Operation{
|
%Operation{
|
||||||
tags: ["Emoji Packs"],
|
tags: ["Emoji Packs"],
|
||||||
|
122
lib/pleroma/web/pleroma_api/controllers/emoji_file_controller.ex
Normal file
122
lib/pleroma/web/pleroma_api/controllers/emoji_file_controller.ex
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
defmodule Pleroma.Web.PleromaAPI.EmojiFileController do
|
||||||
|
use Pleroma.Web, :controller
|
||||||
|
|
||||||
|
alias Pleroma.Emoji.Pack
|
||||||
|
alias Pleroma.Web.ApiSpec
|
||||||
|
|
||||||
|
plug(Pleroma.Web.ApiSpec.CastAndValidate)
|
||||||
|
|
||||||
|
plug(
|
||||||
|
Pleroma.Plugs.OAuthScopesPlug,
|
||||||
|
%{scopes: ["write"], admin: true}
|
||||||
|
when action in [
|
||||||
|
:create,
|
||||||
|
:update,
|
||||||
|
:delete
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
defdelegate open_api_operation(action), to: ApiSpec.PleromaEmojiFileOperation
|
||||||
|
|
||||||
|
def create(%{body_params: params} = conn, %{name: pack_name}) do
|
||||||
|
filename = params[:filename] || get_filename(params[:file])
|
||||||
|
shortcode = params[:shortcode] || Path.basename(filename, Path.extname(filename))
|
||||||
|
|
||||||
|
with {:ok, pack} <- Pack.add_file(pack_name, shortcode, filename, params[:file]) do
|
||||||
|
json(conn, pack.files)
|
||||||
|
else
|
||||||
|
{:error, :already_exists} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:conflict)
|
||||||
|
|> json(%{error: "An emoji with the \"#{shortcode}\" shortcode already exists"})
|
||||||
|
|
||||||
|
{:error, :not_found} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "pack \"#{pack_name}\" is not found"})
|
||||||
|
|
||||||
|
{:error, :empty_values} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "pack name, shortcode or filename cannot be empty"})
|
||||||
|
|
||||||
|
{:error, _} ->
|
||||||
|
render_error(
|
||||||
|
conn,
|
||||||
|
:internal_server_error,
|
||||||
|
"Unexpected error occurred while adding file to pack."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def update(%{body_params: %{shortcode: shortcode} = params} = conn, %{name: pack_name}) do
|
||||||
|
new_shortcode = params[:new_shortcode]
|
||||||
|
new_filename = params[:new_filename]
|
||||||
|
force = params[:force]
|
||||||
|
|
||||||
|
with {:ok, pack} <- Pack.update_file(pack_name, shortcode, new_shortcode, new_filename, force) do
|
||||||
|
json(conn, pack.files)
|
||||||
|
else
|
||||||
|
{:error, :doesnt_exist} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "Emoji \"#{shortcode}\" does not exist"})
|
||||||
|
|
||||||
|
{:error, :already_exists} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:conflict)
|
||||||
|
|> json(%{
|
||||||
|
error:
|
||||||
|
"New shortcode \"#{new_shortcode}\" is already used. If you want to override emoji use 'force' option"
|
||||||
|
})
|
||||||
|
|
||||||
|
{:error, :not_found} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "pack \"#{pack_name}\" is not found"})
|
||||||
|
|
||||||
|
{:error, :empty_values} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "new_shortcode or new_filename cannot be empty"})
|
||||||
|
|
||||||
|
{:error, _} ->
|
||||||
|
render_error(
|
||||||
|
conn,
|
||||||
|
:internal_server_error,
|
||||||
|
"Unexpected error occurred while updating file in pack."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def delete(conn, %{name: pack_name, shortcode: shortcode}) do
|
||||||
|
with {:ok, pack} <- Pack.delete_file(pack_name, shortcode) do
|
||||||
|
json(conn, pack.files)
|
||||||
|
else
|
||||||
|
{:error, :doesnt_exist} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "Emoji \"#{shortcode}\" does not exist"})
|
||||||
|
|
||||||
|
{:error, :not_found} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "pack \"#{pack_name}\" is not found"})
|
||||||
|
|
||||||
|
{:error, :empty_values} ->
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> json(%{error: "pack name or shortcode cannot be empty"})
|
||||||
|
|
||||||
|
{:error, _} ->
|
||||||
|
render_error(
|
||||||
|
conn,
|
||||||
|
:internal_server_error,
|
||||||
|
"Unexpected error occurred while removing file from pack."
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
defp get_filename(%Plug.Upload{filename: filename}), do: filename
|
||||||
|
defp get_filename(url) when is_binary(url), do: Path.basename(url)
|
||||||
|
end
|
@ -14,10 +14,7 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackController do
|
|||||||
:download,
|
:download,
|
||||||
:create,
|
:create,
|
||||||
:update,
|
:update,
|
||||||
:delete,
|
:delete
|
||||||
:add_file,
|
|
||||||
:update_file,
|
|
||||||
:delete_file
|
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -184,105 +181,6 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackController do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def add_file(%{body_params: params} = conn, %{name: name}) do
|
|
||||||
filename = params[:filename] || get_filename(params[:file])
|
|
||||||
shortcode = params[:shortcode] || Path.basename(filename, Path.extname(filename))
|
|
||||||
|
|
||||||
with {:ok, pack} <- Pack.add_file(name, shortcode, filename, params[:file]) do
|
|
||||||
json(conn, pack.files)
|
|
||||||
else
|
|
||||||
{:error, :already_exists} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:conflict)
|
|
||||||
|> json(%{error: "An emoji with the \"#{shortcode}\" shortcode already exists"})
|
|
||||||
|
|
||||||
{:error, :not_found} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "pack \"#{name}\" is not found"})
|
|
||||||
|
|
||||||
{:error, :empty_values} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "pack name, shortcode or filename cannot be empty"})
|
|
||||||
|
|
||||||
{:error, _} ->
|
|
||||||
render_error(
|
|
||||||
conn,
|
|
||||||
:internal_server_error,
|
|
||||||
"Unexpected error occurred while adding file to pack."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def update_file(%{body_params: %{shortcode: shortcode} = params} = conn, %{name: name}) do
|
|
||||||
new_shortcode = params[:new_shortcode]
|
|
||||||
new_filename = params[:new_filename]
|
|
||||||
force = params[:force]
|
|
||||||
|
|
||||||
with {:ok, pack} <- Pack.update_file(name, shortcode, new_shortcode, new_filename, force) do
|
|
||||||
json(conn, pack.files)
|
|
||||||
else
|
|
||||||
{:error, :doesnt_exist} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "Emoji \"#{shortcode}\" does not exist"})
|
|
||||||
|
|
||||||
{:error, :already_exists} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:conflict)
|
|
||||||
|> json(%{
|
|
||||||
error:
|
|
||||||
"New shortcode \"#{new_shortcode}\" is already used. If you want to override emoji use 'force' option"
|
|
||||||
})
|
|
||||||
|
|
||||||
{:error, :not_found} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "pack \"#{name}\" is not found"})
|
|
||||||
|
|
||||||
{:error, :empty_values} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "new_shortcode or new_filename cannot be empty"})
|
|
||||||
|
|
||||||
{:error, _} ->
|
|
||||||
render_error(
|
|
||||||
conn,
|
|
||||||
:internal_server_error,
|
|
||||||
"Unexpected error occurred while updating file in pack."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def delete_file(conn, %{name: name, shortcode: shortcode}) do
|
|
||||||
with {:ok, pack} <- Pack.delete_file(name, shortcode) do
|
|
||||||
json(conn, pack.files)
|
|
||||||
else
|
|
||||||
{:error, :doesnt_exist} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "Emoji \"#{shortcode}\" does not exist"})
|
|
||||||
|
|
||||||
{:error, :not_found} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "pack \"#{name}\" is not found"})
|
|
||||||
|
|
||||||
{:error, :empty_values} ->
|
|
||||||
conn
|
|
||||||
|> put_status(:bad_request)
|
|
||||||
|> json(%{error: "pack name or shortcode cannot be empty"})
|
|
||||||
|
|
||||||
{:error, _} ->
|
|
||||||
render_error(
|
|
||||||
conn,
|
|
||||||
:internal_server_error,
|
|
||||||
"Unexpected error occurred while removing file from pack."
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def import_from_filesystem(conn, _params) do
|
def import_from_filesystem(conn, _params) do
|
||||||
with {:ok, names} <- Pack.import_from_filesystem() do
|
with {:ok, names} <- Pack.import_from_filesystem() do
|
||||||
json(conn, names)
|
json(conn, names)
|
||||||
@ -298,7 +196,4 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackController do
|
|||||||
|> json(%{error: "Error accessing emoji pack directory"})
|
|> json(%{error: "Error accessing emoji pack directory"})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
defp get_filename(%Plug.Upload{filename: filename}), do: filename
|
|
||||||
defp get_filename(url) when is_binary(url), do: Path.basename(url)
|
|
||||||
end
|
end
|
||||||
|
@ -229,9 +229,9 @@ defmodule Pleroma.Web.Router do
|
|||||||
patch("/:name", EmojiPackController, :update)
|
patch("/:name", EmojiPackController, :update)
|
||||||
delete("/:name", EmojiPackController, :delete)
|
delete("/:name", EmojiPackController, :delete)
|
||||||
|
|
||||||
post("/:name/files", EmojiPackController, :add_file)
|
post("/:name/files", EmojiFileController, :create)
|
||||||
patch("/:name/files", EmojiPackController, :update_file)
|
patch("/:name/files", EmojiFileController, :update)
|
||||||
delete("/:name/files", EmojiPackController, :delete_file)
|
delete("/:name/files", EmojiFileController, :delete)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Pack info / downloading
|
# Pack info / downloading
|
||||||
|
318
test/web/pleroma_api/controllers/emoji_file_controller_test.exs
Normal file
318
test/web/pleroma_api/controllers/emoji_file_controller_test.exs
Normal file
@ -0,0 +1,318 @@
|
|||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Web.PleromaAPI.EmojiFileControllerTest do
|
||||||
|
use Pleroma.Web.ConnCase
|
||||||
|
|
||||||
|
import Tesla.Mock
|
||||||
|
import Pleroma.Factory
|
||||||
|
|
||||||
|
@emoji_path Path.join(
|
||||||
|
Pleroma.Config.get!([:instance, :static_dir]),
|
||||||
|
"emoji"
|
||||||
|
)
|
||||||
|
setup do: clear_config([:auth, :enforce_oauth_admin_scope_usage], false)
|
||||||
|
|
||||||
|
setup do: clear_config([:instance, :public], true)
|
||||||
|
|
||||||
|
setup do
|
||||||
|
admin = insert(:user, is_admin: true)
|
||||||
|
token = insert(:oauth_admin_token, user: admin)
|
||||||
|
|
||||||
|
admin_conn =
|
||||||
|
build_conn()
|
||||||
|
|> assign(:user, admin)
|
||||||
|
|> assign(:token, token)
|
||||||
|
|
||||||
|
Pleroma.Emoji.reload()
|
||||||
|
{:ok, %{admin_conn: admin_conn}}
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "POST/PATCH/DELETE /api/pleroma/emoji/packs/:name/files" do
|
||||||
|
setup do
|
||||||
|
pack_file = "#{@emoji_path}/test_pack/pack.json"
|
||||||
|
original_content = File.read!(pack_file)
|
||||||
|
|
||||||
|
on_exit(fn ->
|
||||||
|
File.write!(pack_file, original_content)
|
||||||
|
end)
|
||||||
|
|
||||||
|
:ok
|
||||||
|
end
|
||||||
|
|
||||||
|
test "create shortcode exists", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank",
|
||||||
|
filename: "dir/blank.png",
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "blank.png",
|
||||||
|
path: "#{@emoji_path}/test_pack/blank.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:conflict) == %{
|
||||||
|
"error" => "An emoji with the \"blank\" shortcode already exists"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "don't rewrite old emoji", %{admin_conn: admin_conn} do
|
||||||
|
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir/") end)
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank3",
|
||||||
|
filename: "dir/blank.png",
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "blank.png",
|
||||||
|
path: "#{@emoji_path}/test_pack/blank.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png",
|
||||||
|
"blank3" => "dir/blank.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png")
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank",
|
||||||
|
new_shortcode: "blank2",
|
||||||
|
new_filename: "dir_2/blank_3.png"
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:conflict) == %{
|
||||||
|
"error" =>
|
||||||
|
"New shortcode \"blank2\" is already used. If you want to override emoji use 'force' option"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "rewrite old emoji with force option", %{admin_conn: admin_conn} do
|
||||||
|
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir_2/") end)
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank3",
|
||||||
|
filename: "dir/blank.png",
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "blank.png",
|
||||||
|
path: "#{@emoji_path}/test_pack/blank.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png",
|
||||||
|
"blank3" => "dir/blank.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png")
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank3",
|
||||||
|
new_shortcode: "blank4",
|
||||||
|
new_filename: "dir_2/blank_3.png",
|
||||||
|
force: true
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png",
|
||||||
|
"blank4" => "dir_2/blank_3.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png")
|
||||||
|
end
|
||||||
|
|
||||||
|
test "with empty filename", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank2",
|
||||||
|
filename: "",
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "blank.png",
|
||||||
|
path: "#{@emoji_path}/test_pack/blank.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "pack name, shortcode or filename cannot be empty"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "add file with not loaded pack", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/not_loaded/files", %{
|
||||||
|
shortcode: "blank3",
|
||||||
|
filename: "dir/blank.png",
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "blank.png",
|
||||||
|
path: "#{@emoji_path}/test_pack/blank.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "pack \"not_loaded\" is not found"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "remove file with not loaded pack", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=blank3")
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "pack \"not_loaded\" is not found"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "remove file with empty shortcode", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=")
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "pack name or shortcode cannot be empty"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "update file with not loaded pack", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> patch("/api/pleroma/emoji/packs/not_loaded/files", %{
|
||||||
|
shortcode: "blank4",
|
||||||
|
new_shortcode: "blank3",
|
||||||
|
new_filename: "dir_2/blank_3.png"
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "pack \"not_loaded\" is not found"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "new with shortcode as file with update", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank4",
|
||||||
|
filename: "dir/blank.png",
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "blank.png",
|
||||||
|
path: "#{@emoji_path}/test_pack/blank.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank4" => "dir/blank.png",
|
||||||
|
"blank2" => "blank2.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png")
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank4",
|
||||||
|
new_shortcode: "blank3",
|
||||||
|
new_filename: "dir_2/blank_3.png"
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank3" => "dir_2/blank_3.png",
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
refute File.exists?("#{@emoji_path}/test_pack/dir/")
|
||||||
|
assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png")
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3")
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
refute File.exists?("#{@emoji_path}/test_pack/dir_2/")
|
||||||
|
|
||||||
|
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir") end)
|
||||||
|
end
|
||||||
|
|
||||||
|
test "new with shortcode from url", %{admin_conn: admin_conn} do
|
||||||
|
mock(fn
|
||||||
|
%{
|
||||||
|
method: :get,
|
||||||
|
url: "https://test-blank/blank_url.png"
|
||||||
|
} ->
|
||||||
|
text(File.read!("#{@emoji_path}/test_pack/blank.png"))
|
||||||
|
end)
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank_url",
|
||||||
|
file: "https://test-blank/blank_url.png"
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"blank_url" => "blank_url.png",
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
assert File.exists?("#{@emoji_path}/test_pack/blank_url.png")
|
||||||
|
|
||||||
|
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/blank_url.png") end)
|
||||||
|
end
|
||||||
|
|
||||||
|
test "new without shortcode", %{admin_conn: admin_conn} do
|
||||||
|
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/shortcode.png") end)
|
||||||
|
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
file: %Plug.Upload{
|
||||||
|
filename: "shortcode.png",
|
||||||
|
path: "#{Pleroma.Config.get([:instance, :static_dir])}/add/shortcode.png"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(200) == %{
|
||||||
|
"shortcode" => "shortcode.png",
|
||||||
|
"blank" => "blank.png",
|
||||||
|
"blank2" => "blank2.png"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "remove non existing shortcode in pack.json", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3")
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "Emoji \"blank3\" does not exist"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "update non existing emoji", %{admin_conn: admin_conn} do
|
||||||
|
assert admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank3",
|
||||||
|
new_shortcode: "blank4",
|
||||||
|
new_filename: "dir_2/blank_3.png"
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:bad_request) == %{
|
||||||
|
"error" => "Emoji \"blank3\" does not exist"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "update with empty shortcode", %{admin_conn: admin_conn} do
|
||||||
|
assert %{
|
||||||
|
"error" => "Missing field: new_shortcode."
|
||||||
|
} =
|
||||||
|
admin_conn
|
||||||
|
|> put_req_header("content-type", "multipart/form-data")
|
||||||
|
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
||||||
|
shortcode: "blank",
|
||||||
|
new_filename: "dir_2/blank_3.png"
|
||||||
|
})
|
||||||
|
|> json_response_and_validate_schema(:bad_request)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
@ -411,293 +411,6 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "POST/PATCH/DELETE /api/pleroma/emoji/packs/:name/files" do
|
|
||||||
setup do
|
|
||||||
pack_file = "#{@emoji_path}/test_pack/pack.json"
|
|
||||||
original_content = File.read!(pack_file)
|
|
||||||
|
|
||||||
on_exit(fn ->
|
|
||||||
File.write!(pack_file, original_content)
|
|
||||||
end)
|
|
||||||
|
|
||||||
:ok
|
|
||||||
end
|
|
||||||
|
|
||||||
test "create shortcode exists", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank",
|
|
||||||
filename: "dir/blank.png",
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "blank.png",
|
|
||||||
path: "#{@emoji_path}/test_pack/blank.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:conflict) == %{
|
|
||||||
"error" => "An emoji with the \"blank\" shortcode already exists"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "don't rewrite old emoji", %{admin_conn: admin_conn} do
|
|
||||||
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir/") end)
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank3",
|
|
||||||
filename: "dir/blank.png",
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "blank.png",
|
|
||||||
path: "#{@emoji_path}/test_pack/blank.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png",
|
|
||||||
"blank3" => "dir/blank.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png")
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank",
|
|
||||||
new_shortcode: "blank2",
|
|
||||||
new_filename: "dir_2/blank_3.png"
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:conflict) == %{
|
|
||||||
"error" =>
|
|
||||||
"New shortcode \"blank2\" is already used. If you want to override emoji use 'force' option"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "rewrite old emoji with force option", %{admin_conn: admin_conn} do
|
|
||||||
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir_2/") end)
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank3",
|
|
||||||
filename: "dir/blank.png",
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "blank.png",
|
|
||||||
path: "#{@emoji_path}/test_pack/blank.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png",
|
|
||||||
"blank3" => "dir/blank.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png")
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank3",
|
|
||||||
new_shortcode: "blank4",
|
|
||||||
new_filename: "dir_2/blank_3.png",
|
|
||||||
force: true
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png",
|
|
||||||
"blank4" => "dir_2/blank_3.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png")
|
|
||||||
end
|
|
||||||
|
|
||||||
test "with empty filename", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank2",
|
|
||||||
filename: "",
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "blank.png",
|
|
||||||
path: "#{@emoji_path}/test_pack/blank.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "pack name, shortcode or filename cannot be empty"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "add file with not loaded pack", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/not_loaded/files", %{
|
|
||||||
shortcode: "blank3",
|
|
||||||
filename: "dir/blank.png",
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "blank.png",
|
|
||||||
path: "#{@emoji_path}/test_pack/blank.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "pack \"not_loaded\" is not found"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "remove file with not loaded pack", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=blank3")
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "pack \"not_loaded\" is not found"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "remove file with empty shortcode", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=")
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "pack name or shortcode cannot be empty"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "update file with not loaded pack", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> patch("/api/pleroma/emoji/packs/not_loaded/files", %{
|
|
||||||
shortcode: "blank4",
|
|
||||||
new_shortcode: "blank3",
|
|
||||||
new_filename: "dir_2/blank_3.png"
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "pack \"not_loaded\" is not found"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "new with shortcode as file with update", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank4",
|
|
||||||
filename: "dir/blank.png",
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "blank.png",
|
|
||||||
path: "#{@emoji_path}/test_pack/blank.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank4" => "dir/blank.png",
|
|
||||||
"blank2" => "blank2.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png")
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank4",
|
|
||||||
new_shortcode: "blank3",
|
|
||||||
new_filename: "dir_2/blank_3.png"
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank3" => "dir_2/blank_3.png",
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
refute File.exists?("#{@emoji_path}/test_pack/dir/")
|
|
||||||
assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png")
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3")
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
refute File.exists?("#{@emoji_path}/test_pack/dir_2/")
|
|
||||||
|
|
||||||
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir") end)
|
|
||||||
end
|
|
||||||
|
|
||||||
test "new with shortcode from url", %{admin_conn: admin_conn} do
|
|
||||||
mock(fn
|
|
||||||
%{
|
|
||||||
method: :get,
|
|
||||||
url: "https://test-blank/blank_url.png"
|
|
||||||
} ->
|
|
||||||
text(File.read!("#{@emoji_path}/test_pack/blank.png"))
|
|
||||||
end)
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank_url",
|
|
||||||
file: "https://test-blank/blank_url.png"
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"blank_url" => "blank_url.png",
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
assert File.exists?("#{@emoji_path}/test_pack/blank_url.png")
|
|
||||||
|
|
||||||
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/blank_url.png") end)
|
|
||||||
end
|
|
||||||
|
|
||||||
test "new without shortcode", %{admin_conn: admin_conn} do
|
|
||||||
on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/shortcode.png") end)
|
|
||||||
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> post("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
file: %Plug.Upload{
|
|
||||||
filename: "shortcode.png",
|
|
||||||
path: "#{Pleroma.Config.get([:instance, :static_dir])}/add/shortcode.png"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(200) == %{
|
|
||||||
"shortcode" => "shortcode.png",
|
|
||||||
"blank" => "blank.png",
|
|
||||||
"blank2" => "blank2.png"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "remove non existing shortcode in pack.json", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3")
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "Emoji \"blank3\" does not exist"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "update non existing emoji", %{admin_conn: admin_conn} do
|
|
||||||
assert admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank3",
|
|
||||||
new_shortcode: "blank4",
|
|
||||||
new_filename: "dir_2/blank_3.png"
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:bad_request) == %{
|
|
||||||
"error" => "Emoji \"blank3\" does not exist"
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
test "update with empty shortcode", %{admin_conn: admin_conn} do
|
|
||||||
assert %{
|
|
||||||
"error" => "Missing field: new_shortcode."
|
|
||||||
} =
|
|
||||||
admin_conn
|
|
||||||
|> put_req_header("content-type", "multipart/form-data")
|
|
||||||
|> patch("/api/pleroma/emoji/packs/test_pack/files", %{
|
|
||||||
shortcode: "blank",
|
|
||||||
new_filename: "dir_2/blank_3.png"
|
|
||||||
})
|
|
||||||
|> json_response_and_validate_schema(:bad_request)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe "POST/DELETE /api/pleroma/emoji/packs/:name" do
|
describe "POST/DELETE /api/pleroma/emoji/packs/:name" do
|
||||||
test "creating and deleting a pack", %{admin_conn: admin_conn} do
|
test "creating and deleting a pack", %{admin_conn: admin_conn} do
|
||||||
assert admin_conn
|
assert admin_conn
|
||||||
|
Loading…
Reference in New Issue
Block a user