Skip to content

Commit

Permalink
Add serverUrlInternal option
Browse files Browse the repository at this point in the history
  • Loading branch information
MasterCarl committed Dec 12, 2024
1 parent 7f26b98 commit 7a54c10
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 1 deletion.
1 change: 1 addition & 0 deletions playground/.env.example
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ NUXT_OAUTH_BATTLEDOTNET_CLIENT_SECRET=
NUXT_OAUTH_KEYCLOAK_CLIENT_ID=
NUXT_OAUTH_KEYCLOAK_CLIENT_SECRET=
NUXT_OAUTH_KEYCLOAK_SERVER_URL=
NUXT_OAUTH_KEYCLOAK_SERVER_URL_INTERNAL=
NUXT_OAUTH_KEYCLOAK_REALM=
# LinkedIn
NUXT_OAUTH_LINKEDIN_CLIENT_ID=
Expand Down
1 change: 1 addition & 0 deletions src/module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -232,6 +232,7 @@ export default defineNuxtModule<ModuleOptions>({
clientId: '',
clientSecret: '',
serverUrl: '',
serverUrlInternal: '',
realm: '',
redirectURL: '',
})
Expand Down
10 changes: 9 additions & 1 deletion src/runtime/server/lib/oauth/keycloak.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,13 @@ export interface OAuthKeycloakConfig {
* @default process.env.NUXT_OAUTH_KEYCLOAK_SERVER_URL
*/
serverUrl?: string
/**
* Optional Keycloak OAuth Server URL to use internally, e.g. if Nuxt connects to a Docker hostname while the browser
* redirect goes to localhost
* @example http://keycloak:8080
* @default process.env.NUXT_OAUTH_KEYCLOAK_SERVER_URL_INTERNAL
*/
serverUrlInternal?: string
/**
* Keycloak OAuth Realm
* @default process.env.NUXT_OAUTH_KEYCLOAK_REALM
Expand Down Expand Up @@ -78,9 +85,10 @@ export function defineOAuthKeycloakEventHandler({
}

const realmURL = `${config.serverUrl}/realms/${config.realm}`
const realmURLInternal = `${config.serverUrlInternal || config.serverUrl}/realms/${config.realm}`

const authorizationURL = `${realmURL}/protocol/openid-connect/auth`
const tokenURL = `${realmURL}/protocol/openid-connect/token`
const tokenURL = `${realmURLInternal}/protocol/openid-connect/token`
const redirectURL = config.redirectURL || getOAuthRedirectURL(event)

if (!query.code) {
Expand Down

0 comments on commit 7a54c10

Please sign in to comment.