- NotificationsYou must be signed in to change notification settings 
- Fork1
En enkel Unleash-server med Google IAP pålogging
License
nais/unleash
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
SimpleUnleash v5 server withGoogle IAP authentication. Built to work well withUnleasherator our Kubernetes operator for managing Unleash instances.
sequenceDiagram    participant User    participant Google IAP    participant Google Auth    participant Unleash    autonumber    User->>Google IAP: request    alt is not authenticated        Google IAP->>Google Auth: Redirect to login        Google Auth->>Google IAP: Redirect to callback    end    alt is not authorized        Google IAP->>User: 403    end    Google IAP->>Unleash: request    Unleash->>User: response| environment variable | description | default | 
|---|---|---|
| GOOGLE_IAP_JWT_HEADER | Header name for JWT token from Google IAP | x-goog-iap-jwt-assertion | 
| GOOGLE_IAP_JWT_ISSUER | Issuer for JWT token from Google IAP | https://cloud.google.com/iap | 
| GOOGLE_IAP_JWT_AUDIENCE | Audience for JWT token from Google IAP | REQUIRED | 
| IAP_PUBLIC_KEY_CACHE_TIME | Cache time for JWT token public keys from Google IAP | 3600 | 
GOOGLE_IAP_JWT_AUDIENCE should be a string in the following format:
/projects/PROJECT_NUMBER/global/backendServices/SERVICE_ID| environment variable | description | default | 
|---|---|---|
| OAUTH_JWT_AUTH | Enable generic Oauth JWT validation | false | 
| OAUTH_JWT_HEADER | Header name for JWT token | X-Wonderwall-Forward-Auth-Token | 
| OAUTH_JWT_ISSUER | Issuer for JWT token | https://auth.nais.io | 
| OAUTH_JWT_AUDIENCE | Audience for JWT token | REQUIRED | 
| OAUTH_JWT_KEYSET | Keyset URL to fetch keyset from | https://auth.nais.io/oauth/v2/keys | 
| environment variable | description | default | 
|---|---|---|
| TEAMS_API_URL | URL for Teams API | REQUIRED | 
| TEAMS_API_TOKEN | Token for Teams API | REQUIRED | 
| TEAMS_ALLOWED_TEAMS | Teams allowed to access Unleash | REQUIRED | 
| TEAMS_USER_VALIDATION_CACHE_TIME | Cache time for Teams user validation | 3600 | 
| environment variable | description | default | 
|---|---|---|
| INIT_ADMIN_API_TOKENS | Admin API tokens to create on startup | REQUIRED | 
| AUTH_ENABLE_API_TOKEN | Enable API token authentication | true | 
| SERVER_PORT | Port to listen on | 4242 | 
| DATABASE_USERNAME | Username for database connection | unleash | 
| DATABASE_PASSWORD | Password for database connection | unleash | 
| DATABASE_NAME | Database name | unleash | 
| DATABASE_HOST | Database host | localhost | 
| DATABASE_SSL | Use SSL for database connection | false | 
| DATABASE_PORT | Database port | 5432 | 
The simplest way to run Unleash is to usedocker-compose:
docker-compose up --build
This will start a local Postgres database in a Docker container and expose Unleash onhttp://localhost:8080.
To build the code, runyarn build. This will compile the TypeScript files to ES2017 and place them in./dist/. Unleash can then be run withyarn start. For convenience you can also use theyarn build-and-start command.
Running Unleash locally requires a database. The easiest way to get one is to use Docker:
docker-compose up -d postgres
This will start a local Postgres database in a Docker container. You can then connect to it using the following credentials:
export DATABASE_USERNAME=unleashexport DATABASE_PASSWORD=unleashexport DATABASE_NAME=unleashexport DATABASE_HOST=localhostexport DATABASE_SSL=false
You also need the following environment variables:
export INIT_ADMIN_API_TOKENS=*:*.unleash4allexport GOOGLE_IAP_AUDIENCE=/projects/123/global/backendServices/123
Requests and questions can be made via issues on the repo. For NAV employees this can be done easiest via the slack channel#unleash.
About
En enkel Unleash-server med Google IAP pålogging
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Packages0
Uh oh!
There was an error while loading.Please reload this page.
Uh oh!
There was an error while loading.Please reload this page.