philomena/lib/philomena_web/controllers/admin/badge_controller.ex
2024-06-06 22:28:35 +02:00

61 lines
1.7 KiB
Elixir

defmodule PhilomenaWeb.Admin.BadgeController do
use PhilomenaWeb, :controller
alias Philomena.Badges.Badge
alias Philomena.Badges
alias Philomena.Repo
import Ecto.Query
plug :verify_authorized
plug :load_resource, model: Badge, only: [:edit, :update]
def index(conn, _params) do
badges =
Badge
|> order_by(asc: :title)
|> Repo.paginate(conn.assigns.scrivener)
render(conn, "index.html", title: "Admin - Badges", badges: badges)
end
def new(conn, _params) do
changeset = Badges.change_badge(%Badge{})
render(conn, "new.html", title: "New Badge", changeset: changeset)
end
def create(conn, %{"badge" => badge_params}) do
case Badges.create_badge(badge_params) do
{:ok, _badge} ->
conn
|> put_flash(:info, "Badge created successfully.")
|> redirect(to: ~p"/admin/badges")
{:error, :badge, changeset, _changes} ->
render(conn, "new.html", changeset: changeset)
end
end
def edit(conn, _params) do
changeset = Badges.change_badge(conn.assigns.badge)
render(conn, "edit.html", title: "Editing Badge", changeset: changeset)
end
def update(conn, %{"badge" => badge_params}) do
case Badges.update_badge(conn.assigns.badge, badge_params) do
{:ok, _badge} ->
conn
|> put_flash(:info, "Badge updated successfully.")
|> redirect(to: ~p"/admin/badges")
{:error, :badge, changeset, _changes} ->
render(conn, "edit.html", changeset: changeset)
end
end
defp verify_authorized(conn, _opts) do
case Canada.Can.can?(conn.assigns.current_user, :index, Badge) do
true -> conn
_false -> PhilomenaWeb.NotAuthorizedPlug.call(conn)
end
end
end