defmodule Auth0.Management.Blacklist.Tokens.Add do
@moduledoc false
alias Auth0.Config
alias Auth0.Common.Util
alias Auth0.Common.Management.Http
@type params :: map()
@type config :: Config.t()
@type entity :: String.t()
@type response :: {:ok, entity} | {:error, integer, term} | {:error, term}
@endpoint "/api/v2/blacklists/tokens"
@doc """
Add the token identified by the jti to a blacklist for the tenant.
## see
https://auth0.com/docs/api/management/v2/blacklists/post-tokens
"""
@spec execute(params, config) :: response
def execute(%{} = params, %Config{} = config) do
body = params |> Util.remove_nil()
Http.post(@endpoint, body, config)
|> case do
{:ok, 204, _body} -> {:ok, ""}
error -> error
end
end
end