2022-02-23 05:54:52 +00:00
|
|
|
package handlers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
|
|
|
|
"github.com/authorizerdev/authorizer/server/constants"
|
2022-05-29 11:52:46 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/memorystore"
|
2022-02-23 05:54:52 +00:00
|
|
|
"github.com/authorizerdev/authorizer/server/utils"
|
|
|
|
)
|
|
|
|
|
|
|
|
// OpenIDConfigurationHandler handler for open-id configurations
|
|
|
|
func OpenIDConfigurationHandler() gin.HandlerFunc {
|
|
|
|
return func(c *gin.Context) {
|
|
|
|
issuer := utils.GetHost(c)
|
2022-05-29 11:52:46 +00:00
|
|
|
jwtType, _ := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyJwtType)
|
2022-02-23 05:54:52 +00:00
|
|
|
|
|
|
|
c.JSON(200, gin.H{
|
|
|
|
"issuer": issuer,
|
|
|
|
"authorization_endpoint": issuer + "/authorize",
|
2022-02-28 07:44:16 +00:00
|
|
|
"token_endpoint": issuer + "/token",
|
2022-02-23 05:54:52 +00:00
|
|
|
"userinfo_endpoint": issuer + "/userinfo",
|
2022-02-26 12:44:43 +00:00
|
|
|
"jwks_uri": issuer + "/.well-known/jwks.json",
|
2022-02-23 05:54:52 +00:00
|
|
|
"response_types_supported": []string{"code", "token", "id_token", "code token", "code id_token", "token id_token", "code token id_token"},
|
|
|
|
"scopes_supported": []string{"openid", "email", "profile", "email_verified", "given_name", "family_name", "nick_name", "picture"},
|
|
|
|
"response_modes_supported": []string{"query", "fragment", "form_post"},
|
|
|
|
"id_token_signing_alg_values_supported": []string{jwtType},
|
|
|
|
"claims_supported": []string{"aud", "exp", "iss", "iat", "sub", "given_name", "family_name", "middle_name", "nickname", "preferred_username", "picture", "email", "email_verified", "roles", "gender", "birthdate", "phone_number", "phone_number_verified"},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|