Skip to content

flexwie/oauth_device_flow

Repository files navigation

OAuth2 Device Flow Client

This is a client for using OAuth2 Device Flows in applications with limited interaction possibilities.

import { DeviceFlowClient } from "oauth_device_flow";

const app = new DeviceFlowClient({
  audience: "AUDIENCE",
  client_id: "CLIENT_ID",
  scopes: ["openid", "offline_access"],
  code_url: "DEVICE_CODE_URL",
  token_url: "TOKEN_URL",
}, {
  output: (str) => console.info(str)
});

// get token interactively
app
  .acquireToken()
  .then((token) => /* ...do stuff */);

// get token silently
app
  .acquireTokenSilently()
  .then((token) => /* ...do stuff */);

Configuration

The client requires the following parameter:

/**
 * Endpoint used to fetch tokens
 * @example https://tenant.eu.auth0.com/oauth/token
 */
token_url: string;
/**
 * Endpoint used to fetch the device and user code
 * @example https://tenant.eu.auth0.com/oauth/device/code
 */
code_url: string;
/**
 * The client ID
 * You get this from your OAuth provider
 */
client_id: string;
/**
 * The requested scopes
 * Will automatically include "offline_access" if you set the "refreshToken" option
 */
scopes: string[];
/**
 * The audience for your request
 */
audience: string;

Additionally you can provide a few other options to customize your experience and implement a cache:

/**
 * Provide a cache for the token and metadata
 */
cache?: {
  /**
   * Deerialize the cache
   */
  beforeCacheAccess: () => ClientCache;
  /**
   * Serialize the cache
   */
  afterCacheAccess: (cache: ClientCache) => void;
};
/**
 * Customize the console output
 */
output?: (str: string) => void;
/**
 * Request a refresh token?
 */
refreshToken?: boolean;

About

Node.JS Client for OAuth2 Device Flows

Resources

Stars

Watchers

Forks

Packages

No packages published