From f237a9a488670b3a056a07e91fb69d373a1742b6 Mon Sep 17 00:00:00 2001 From: Pauline Date: Thu, 28 Nov 2024 12:07:09 +0000 Subject: [PATCH] Explicitly specify scope and audience in client credentials config --- .../org/radarbase/ktor/auth/ClientCredentialsConfig.kt | 3 ++- .../kotlin/org/radarbase/ktor/auth/OAuthClientProvider.kt | 5 ++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/ClientCredentialsConfig.kt b/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/ClientCredentialsConfig.kt index 0f7b8ad..17797d9 100644 --- a/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/ClientCredentialsConfig.kt +++ b/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/ClientCredentialsConfig.kt @@ -6,7 +6,8 @@ data class ClientCredentialsConfig( val tokenUrl: String, val clientId: String? = null, val clientSecret: String? = null, - val additionalParameters: Map? = null, + val scope: String? = null, + val audience: String? = null, ) { /** * Fill in the client ID and client secret from environment variables. The variables are diff --git a/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/OAuthClientProvider.kt b/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/OAuthClientProvider.kt index 750a237..18a8e8a 100644 --- a/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/OAuthClientProvider.kt +++ b/radar-commons-kotlin/src/main/kotlin/org/radarbase/ktor/auth/OAuthClientProvider.kt @@ -56,9 +56,8 @@ fun Auth.clientCredentials( append("grant_type", "client_credentials") append("client_id", authConfig.clientId) append("client_secret", authConfig.clientSecret) - authConfig.additionalParameters?.forEach { (key, value) -> - append(key, value) - } + authConfig.scope?.let { append("scope", it) } + authConfig.audience?.let { append("audience", it) } }, ) { accept(ContentType.Application.Json)