lib/boruta/openid/application.ex
defmodule Boruta.Openid.Application do
@moduledoc """
Implement this behaviour in the application layer of your OpenID Connect provider.
This behaviour gives all callbacks triggered invoking `Boruta.Openid` module functions.
> __Note__: This behaviour is splitted into `Boruta.Openid.JwksApplication` and `Boruta.Openid.UserinfoApplication` providing utilities to implement the different OpenID Connect endpoints independently.
"""
@doc """
This function will be triggered in case of success invoking `Boruta.Openid.jwks/2`
"""
@callback jwk_list(conn :: Plug.Conn.t(), jwk_keys :: list(%JOSE.JWK{})) ::
any()
@doc """
This function will be triggered in case of success invoking `Boruta.Openid.userinfo/2`
"""
@callback userinfo_fetched(conn :: Plug.Conn.t(), userinfo :: map()) ::
any()
@doc """
This function will be triggered when request is unauthorized invoking `Boruta.Openid.userinfo/2`
"""
@callback unauthorized(conn :: Plug.Conn.t(), error :: Boruta.Oauth.Error.t()) ::
any()
end