Skip to content

Commit

Permalink
feat: default jwt secret
Browse files Browse the repository at this point in the history
  • Loading branch information
shahargl committed Oct 15, 2024
1 parent 2b2f9e7 commit 938487a
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 8 deletions.
7 changes: 3 additions & 4 deletions docs/deployment/configuration.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -75,10 +75,9 @@ Authentication configuration determines how Keep verifies user identities and ma
| Env var | Purpose | Required | Default Value | Valid options |
|:-------------------:|:-------:|:----------:|:-------------:|:-------------:|
| **AUTH_TYPE** | Specifies the authentication type | No | "noauth" | "auth0", "keycloak", "db", "noauth", "oauth2proxy" |
| **JWT_SECRET** | Secret key for JWT token generation and validation | Yes | None | Any strong secret string |
| **JWT_ALGORITHM** | Algorithm used for JWT | No | "HS256" | Any valid JWT algorithm |
| **KEEP_DEFAULT_USERNAME** | Default username for the admin user | No | "keep" | Any valid username string |
| **KEEP_DEFAULT_PASSWORD** | Default password for the admin user | No | "keep" | Any strong password string |
| **KEEP_JWT_SECRET** | Secret key for JWT token generation and validation (DB auth only) | Yes | None | Any strong secret string |
| **KEEP_DEFAULT_USERNAME** | Default username for the admin user (DB auth only) | No | "keep" | Any valid username string |
| **KEEP_DEFAULT_PASSWORD** | Default password for the admin user (DB auth only)| No | "keep" | Any strong password string |
| **KEEP_FORCE_RESET_DEFAULT_PASSWORD** | Forces reset of default user password | No | "false" | "true" or "false" |
| **KEEP_DEFAULT_API_KEYS** | Comma-separated list of default API keys to provision | No | "" | Format: "name:role:secret,name:role:secret" |

Expand Down
10 changes: 6 additions & 4 deletions keep/identitymanager/identity_managers/db/db_authverifier.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,12 @@ class DbAuthVerifier(AuthVerifierBase):

def _verify_bearer_token(self, token: str) -> AuthenticatedEntity:
# validate the token
jwt_secret = os.environ.get("KEEP_JWT_SECRET")
if not jwt_secret:
self.logger.warning("missing KEEP_JWT_SECRET environment variable")
raise HTTPException(status_code=401, detail="Missing JWT secret")
jwt_secret = os.environ.get("KEEP_JWT_SECRET", "jwtsecret")
# if default
if jwt_secret == "jwtsecret":
self.logger.warning(
"KEEP_JWT_SECRET environment variable is not set, using default value. Should be set in production."
)

try:
payload = jwt.decode(
Expand Down

0 comments on commit 938487a

Please sign in to comment.