Files
policy-service/lib/policy_service_web/router.ex
HaimKortovich 44d89014fd
Some checks failed
Build and Publish / build-release (push) Failing after 1m49s
add authentication with zitadel
2026-05-04 15:52:09 -05:00

49 lines
1.4 KiB
Elixir

defmodule PolicyServiceWeb.Router do
use PolicyServiceWeb, :router
alias PolicyServiceWeb.PolicyController
alias PolicyServiceWeb.HealthController
pipeline :api do
plug OpenApiSpex.Plug.PutApiSpec, module: PolicyServiceWeb.ApiSpec
end
pipeline :authenticated do
plug PolicyServiceWeb.Plugs.AuthenticationPlug,
provider: PolicyService.ZitadelProvider,
client_id: {__MODULE__, :get_zitadel_config, [:client_id]},
client_secret: {__MODULE__, :get_zitadel_config, [:client_secret]},
required_scopes: {__MODULE__, :get_zitadel_config, [:required_scopes]}
end
pipeline :authorized do
plug PolicyServiceWeb.Plugs.AuthorizationPlug
end
get "/health", HealthController, :health
get "/health/ready", HealthController, :ready
scope "/api" do
pipe_through [:api]
get "/openapi", OpenApiSpex.Plug.RenderSpec, []
scope "/v1" do
pipe_through [:authenticated, :authorized]
get "/policies", PolicyController, :index
get "/policies/:application_id", PolicyController, :show
post "/policies", PolicyController, :create
post "/policies/:application_id/accept", PolicyController, :accept
end
end
scope "/swaggerui" do
get "/", OpenApiSpex.Plug.SwaggerUI, path: "/api/openapi"
end
def get_zitadel_config(key) do
Application.get_env(:policy_service, :zitadel)[key]
end
end