2019-12-08 05:53:18 +01:00
|
|
|
defmodule PhilomenaWeb.Image.DeleteController do
|
|
|
|
use PhilomenaWeb, :controller
|
|
|
|
|
|
|
|
# N.B.: this would be Image.Hide, because it hides the image, but that is
|
|
|
|
# taken by the user action
|
|
|
|
|
2021-11-07 19:51:55 +01:00
|
|
|
alias PhilomenaWeb.ModerationLogPlug
|
2019-12-08 05:53:18 +01:00
|
|
|
alias Philomena.Images.Image
|
|
|
|
alias Philomena.Images
|
|
|
|
|
2020-09-07 05:59:50 +02:00
|
|
|
plug PhilomenaWeb.CanaryMapPlug, create: :hide, update: :hide, delete: :hide
|
2019-12-08 05:53:18 +01:00
|
|
|
plug :load_and_authorize_resource, model: Image, id_name: "image_id", persisted: true
|
2020-02-01 00:50:50 +01:00
|
|
|
plug :verify_deleted when action in [:update]
|
2019-12-08 05:53:18 +01:00
|
|
|
|
|
|
|
def create(conn, %{"image" => image_params}) do
|
|
|
|
image = conn.assigns.image
|
|
|
|
user = conn.assigns.current_user
|
|
|
|
|
|
|
|
case Images.hide_image(image, user, image_params) do
|
2021-11-07 19:51:55 +01:00
|
|
|
{:ok, result} ->
|
2019-12-08 05:53:18 +01:00
|
|
|
conn
|
|
|
|
|> put_flash(:info, "Image successfully hidden.")
|
2021-11-07 19:51:55 +01:00
|
|
|
|> ModerationLogPlug.call(details: &log_details/3, data: result.image)
|
2019-12-08 05:53:18 +01:00
|
|
|
|> redirect(to: Routes.image_path(conn, :show, image))
|
|
|
|
|
2020-09-10 18:02:01 +02:00
|
|
|
_error ->
|
|
|
|
conn
|
|
|
|
|> put_flash(:error, "Failed to hide image.")
|
|
|
|
|> redirect(to: Routes.image_path(conn, :show, image))
|
2019-12-08 05:53:18 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-02-01 00:50:50 +01:00
|
|
|
def update(conn, %{"image" => image_params}) do
|
|
|
|
image = conn.assigns.image
|
|
|
|
|
|
|
|
case Images.update_hide_reason(image, image_params) do
|
|
|
|
{:ok, image} ->
|
|
|
|
conn
|
|
|
|
|> put_flash(:info, "Hide reason updated.")
|
2021-11-07 19:51:55 +01:00
|
|
|
|> ModerationLogPlug.call(details: &log_details/3, data: image)
|
2020-02-01 00:50:50 +01:00
|
|
|
|> redirect(to: Routes.image_path(conn, :show, image))
|
|
|
|
|
|
|
|
{:error, _changeset} ->
|
|
|
|
conn
|
|
|
|
|> put_flash(:error, "Couldn't update hide reason.")
|
|
|
|
|> redirect(to: Routes.image_path(conn, :show, image))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defp verify_deleted(conn, _opts) do
|
|
|
|
case conn.assigns.image.hidden_from_users do
|
|
|
|
true ->
|
|
|
|
conn
|
2020-02-01 17:04:11 +01:00
|
|
|
|
2020-02-01 00:50:50 +01:00
|
|
|
_false ->
|
|
|
|
conn
|
|
|
|
|> put_flash(:error, "Cannot change hide reason on a non-hidden image!")
|
|
|
|
|> redirect(to: Routes.image_path(conn, :show, conn.assigns.image))
|
2020-05-04 09:18:36 +02:00
|
|
|
|> halt()
|
2020-02-01 00:50:50 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-12-08 05:53:18 +01:00
|
|
|
def delete(conn, _params) do
|
|
|
|
image = conn.assigns.image
|
|
|
|
|
2021-11-07 19:51:55 +01:00
|
|
|
{:ok, image} = Images.unhide_image(image)
|
2019-12-08 05:53:18 +01:00
|
|
|
|
|
|
|
conn
|
|
|
|
|> put_flash(:info, "Image successfully unhidden.")
|
2021-11-07 19:51:55 +01:00
|
|
|
|> ModerationLogPlug.call(details: &log_details/3, data: image)
|
2019-12-08 05:53:18 +01:00
|
|
|
|> redirect(to: Routes.image_path(conn, :show, image))
|
|
|
|
end
|
2021-11-07 19:51:55 +01:00
|
|
|
|
|
|
|
defp log_details(conn, action, image) do
|
|
|
|
body =
|
|
|
|
case action do
|
|
|
|
:create -> "Hidden image >>#{image.id} (#{image.deletion_reason})"
|
|
|
|
:update -> "Changed hide reason of >>#{image.id} (#{image.deletion_reason})"
|
|
|
|
:delete -> "Restored image >>#{image.id}"
|
|
|
|
end
|
|
|
|
|
|
|
|
%{
|
|
|
|
body: body,
|
|
|
|
subject_path: Routes.image_path(conn, :show, image)
|
|
|
|
}
|
|
|
|
end
|
2019-12-17 17:45:22 +01:00
|
|
|
end
|