Skip to content

Keycloakd middleware to simply use keycloak validation and verifications.

License

Notifications You must be signed in to change notification settings

rafaelcascalho/keycloak-middleware-ts

Repository files navigation

keycloak-middleware-ts

codecov

This is an TS implementation of the JS version of the keycloak-backend npm package..

Description

This module provides a minimal, simple to use and direct approach to enable backend integration with keycloak enabling most usual features of authentication, token handling and user management. Check more about keycloak here.

Quick Start

Install Via NPM

npm install -S keycloak-middleware-ts

Set Up Your Keycloak Realm and Client For The Backend

It's necessary to have a realm and an active client correctly configured to be able to access all the features. Check this guide to see how to do that.

Usage

Just create a new keycloak context and use the methods of the lib API.

// import the createKeycloakCtx method from the module
import createKeycloakCtx from "keycloak-middleware-ts";

// create the keycloak context
const keycloak = createKeycloakCtx({
  realm: "realm name",
  authServerUrl: "keycloak server url",
  clientId: "client name",
  clientSecret: "client secret", // if required
  username: "service username",
  password: "service password",
  jwtKey: "realm public key", // optional
  jwtKeyAlgorithms: ["realm public key to decode JWT keys"], // optional
});

// use the created context easily
const accessToken = await keycloak.accessToken.get();
const tokenInfo = await keycloak.accessToken.info(accessToken);
const token = await keycloak.jwt.verify(accessToken);
if (token.isExpired()) throw new Error("your error message");

To check the full API refer to the lib API docs here.

Contributing

To contribute you can create issues or modify the code or docs yourself, and submit the PRs for new versions. If you're willing to help beyound issues creation, just fork this repo, update the code or docs, create tests if some code were added, and submit the PR. To make everything tight, first create and claim an issue. Then, just code it 😄

Installing Dependencies

npm install -D

Tests

npm test

To generate coverage run the command below (this will be improved in the future).

npm run test:cov

Next Steps

For the foreseeable future, these are the next steps:

  • [ ] create pipelines to run the automated tests, static code analysis
  • [ ] add pre commit step automation for tests, linting and formatting
  • [ ] improve code coverage to enable threshold of 90-100%
  • [ ] add tech stack

About

Keycloakd middleware to simply use keycloak validation and verifications.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •