Skip to content

Commit

Permalink
feat: changed ttl for keycloak access token (#81)
Browse files Browse the repository at this point in the history
* feat: changed ttl for keycloak access token

* feat: added ttl to env and update readme
  • Loading branch information
ElderMatt authored Jul 10, 2023
1 parent 6533f64 commit 8262084
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 0 deletions.
11 changes: 11 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,18 @@ This readme is aimed at development. If you wish to contribute please read our D
## Development

Make sure your expected environment variables exist in a mandatory `.env` file (see `.env.sample`).
#
**Important**
When using `npm i` and you get the errors `Unauthorized` and `Permission denied` on the installation regarding getting packages from redkubes
> Example: `npm ERR! 403 403 Forbidden - GET https://npm.pkg.github.com/redkubes/@redkubes%2fgitea-client-node - Permission denied`
This can be fixed by adding the following line to the `.npmrc` file.
`//npm.pkg.github.com/:_authToken=PERSONAL_ACCESS_TOKEN_HERE`

To create a personal access token, go to GitHub -> settings -> developer settings -> personal access token -> give read permission on packages and create the token

**Remember not to push this token**
#
Then start a proxy to the api you wish to target:

- drone: `k -n team-admin port-forward svc/drone 8081:80 &`
Expand Down
6 changes: 6 additions & 0 deletions src/tasks/keycloak/keycloak.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ import {
KEYCLOAK_ADMIN,
KEYCLOAK_ADMIN_PASSWORD,
KEYCLOAK_REALM,
KEYCLOAK_TOKEN_TTL,
} from '../../validators'
import { keycloakRealm } from './config'
import {
Expand All @@ -55,6 +56,7 @@ const env = cleanEnv({
KEYCLOAK_ADDRESS,
KEYCLOAK_ADDRESS_INTERNAL,
KEYCLOAK_REALM,
KEYCLOAK_TOKEN_TTL,
FEAT_EXTERNAL_IDP,
})

Expand Down Expand Up @@ -102,6 +104,10 @@ async function main(): Promise<void> {

// Create realm 'otomi'
const realmConf = createRealm(keycloakRealm)
realmConf.ssoSessionIdleTimeout = env.KEYCLOAK_TOKEN_TTL
realmConf.ssoSessionMaxLifespan = env.KEYCLOAK_TOKEN_TTL
realmConf.accessTokenLifespan = env.KEYCLOAK_TOKEN_TTL
realmConf.accessTokenLifespanForImplicitFlow = env.KEYCLOAK_TOKEN_TTL
// the api does not offer a list method, and trying to get by id throws an error
// which we wan to discard, so we run the next command with an empty errors array
const existingRealm = (await doApiCall([], `Getting realm ${keycloakRealm}`, () =>
Expand Down
4 changes: 4 additions & 0 deletions src/validators.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,10 @@ export const KEYCLOAK_CLIENT_ID = str({ desc: 'Default Keycloak Client', default
export const KEYCLOAK_CLIENT_SECRET = str({ desc: 'The keycloak client secret' })
export const KEYCLOAK_REALM = str({ desc: 'The Keycloak Realm', default: 'master' })
export const KEYCLOAK_THEME_LOGIN = str({ desc: 'The Keycloak login theme', default: 'default' })
export const KEYCLOAK_TOKEN_TTL = num({
desc: 'The Keycloak access token TTL in seconds, 28800 seconds = 8 hours',
default: 28800,
})
export const NODE_EXTRA_CA_CERTS = str({ default: undefined })
export const NODE_TLS_REJECT_UNAUTHORIZED = bool({ default: true })
export const OIDC_CLIENT_SECRET = str({ desc: 'The OIDC client secret used by keycloak to access the IDP' })
Expand Down

0 comments on commit 8262084

Please sign in to comment.