forked from AkkomaGang/akkoma
Add an endpoint for emoji pack metadata updating
This commit is contained in:
parent
adf31d596e
commit
bcc0bfd0c5
2 changed files with 49 additions and 1 deletions
|
@ -196,7 +196,7 @@ def download_from(conn, %{"instance_address" => address, "pack_name" => name} =
|
||||||
if pinfo[:fallback] do
|
if pinfo[:fallback] do
|
||||||
pack_file_path = Path.join(pack_dir, "pack.json")
|
pack_file_path = Path.join(pack_dir, "pack.json")
|
||||||
|
|
||||||
File.write!(pack_file_path, Jason.encode!(full_pack))
|
File.write!(pack_file_path, Jason.encode!(full_pack, pretty: true))
|
||||||
end
|
end
|
||||||
|
|
||||||
conn |> text("ok")
|
conn |> text("ok")
|
||||||
|
@ -222,4 +222,51 @@ def delete(conn, %{"name" => name}) do
|
||||||
conn |> put_status(:internal_server_error) |> text("Couldn't delete the pack #{name}")
|
conn |> put_status(:internal_server_error) |> text("Couldn't delete the pack #{name}")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def update_metadata(conn, %{"name" => name, "new_data" => new_data}) do
|
||||||
|
pack_dir = Path.join(@emoji_dir_path, name)
|
||||||
|
pack_file_p = Path.join(pack_dir, "pack.json")
|
||||||
|
|
||||||
|
full_pack = Jason.decode!(File.read!(pack_file_p))
|
||||||
|
|
||||||
|
new_data =
|
||||||
|
if not is_nil(new_data["fallback-src"]) and is_nil(new_data["fallback-src-sha256"]) do
|
||||||
|
pack_arch = Tesla.get!(new_data["fallback-src"]).body
|
||||||
|
|
||||||
|
{:ok, flist} = :zip.unzip(pack_arch, [:memory])
|
||||||
|
|
||||||
|
# Check if all files from the pack.json are in the archive
|
||||||
|
has_all_files =
|
||||||
|
Enum.all?(full_pack["files"], fn {_, from_manifest} ->
|
||||||
|
Enum.find(flist, fn {from_archive, _} ->
|
||||||
|
to_string(from_archive) == from_manifest
|
||||||
|
end)
|
||||||
|
end)
|
||||||
|
|
||||||
|
unless has_all_files do
|
||||||
|
{:error,
|
||||||
|
conn
|
||||||
|
|> put_status(:bad_request)
|
||||||
|
|> text("The fallback archive does not have all files specified in pack.json")}
|
||||||
|
else
|
||||||
|
fallback_sha = :crypto.hash(:sha256, pack_arch) |> Base.encode16()
|
||||||
|
|
||||||
|
{:ok, new_data |> Map.put("fallback-src-sha256", fallback_sha)}
|
||||||
|
end
|
||||||
|
else
|
||||||
|
{:ok, new_data}
|
||||||
|
end
|
||||||
|
|
||||||
|
case new_data do
|
||||||
|
{:ok, new_data} ->
|
||||||
|
full_pack = Map.put(full_pack, "pack", new_data)
|
||||||
|
File.write!(pack_file_p, Jason.encode!(full_pack, pretty: true))
|
||||||
|
|
||||||
|
# Send new data back with fallback sha filled
|
||||||
|
conn |> json(new_data)
|
||||||
|
|
||||||
|
{:error, e} ->
|
||||||
|
e
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -218,6 +218,7 @@ defmodule Pleroma.Web.Router do
|
||||||
# Modifying packs
|
# Modifying packs
|
||||||
pipe_through([:admin_api, :oauth_write])
|
pipe_through([:admin_api, :oauth_write])
|
||||||
|
|
||||||
|
post("/update_metadata/:name", EmojiAPIController, :update_metadata)
|
||||||
delete("/delete/:name", EmojiAPIController, :delete)
|
delete("/delete/:name", EmojiAPIController, :delete)
|
||||||
post("/download_from", EmojiAPIController, :download_from)
|
post("/download_from", EmojiAPIController, :download_from)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue