# Pleroma: A lightweight social networking server # Copyright © 2017-2021 Pleroma Authors # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.Plugs.EnsureStaffPrivilegedPlug do @moduledoc """ Ensures if staff are privileged enough to do certain tasks """ import Pleroma.Web.TranslationHelpers import Plug.Conn alias Pleroma.User alias Pleroma.Config def init(options) do options end def call(%{assigns: %{user: %User{is_admin: true}}} = conn, _), do: conn def call(conn, _) do if Config.get!([:instance, :privileged_staff]) do conn else conn |> render_error(:forbidden, "User is not an admin.") |> halt() end end end