Giter Club home page Giter Club logo

node-oauth2-client's Introduction

npm last build PRs Welcome

@egomobile/oauth2-client

Creates and setups pre-configured axios clients, using OAuth 2.0 workflow(s)., written in TypeScript.

Install

Execute the following command from your project folder, where your package.json file is stored:

npm install --save @egomobile/oauth2-client

Usage

client_credentials

import { createClientCredentialsClientFactory } from "@egomobile/oauth2-client";

// create a factory function, that creates
// a pre-configured API client that already
// has an access_token, submitted as Bearer by default
export const createApiClient = createClientCredentialsClientFactory({
  // data for client authorization
  auth: {
    clientId: "foo",
    clientSecret: "bar",
  },

  // base URL of the API
  baseURL: "https://api.example.com",
  // URL from where to get the token from
  tokenURL: "https://api.example.com/oauth2/token",

  // optional extra default headers
  headers: {
    "x-baz": "some value for an extra header",
  },

  // optional and additional / custom
  // axios configuration
  config: {
    // this always accept any status code
    // and will now throw errors on HTTP error codes
    validateStatus: (status) => status < 400,
  },
});

function doApiCall() {
  // create client with the new factory
  // without subitting the credentials
  // every time
  const client = await createClient();

  // now, do some API call with a pre-configured client
  // that submits the access_token as Bearer via
  // Authorization header
  return client.get("/foo?bar=baz"); // [GET] https://api.example.com/foo?bar=baz
}

const response = await doApiCall();

password

import { createPasswordClientFactory } from "@egomobile/oauth2-client";

// create a factory function, that creates
// a pre-configured API client that already
// has an access_token, submitted as Bearer by default
export const createApiClient = createPasswordClientFactory({
  // data for client authorization
  auth: {
    clientId: "foo",
    clientSecret: "bar",
    username: "bill",
    password: "G@tes1234!",
  },

  // base URL of the API
  baseURL: "https://api.example.com",
  // URL from where to get the token from
  tokenURL: "https://api.example.com/oauth2/token",

  // optional extra default headers
  headers: {
    "x-baz": "some value for an extra header",
  },

  // optional and additional / custom
  // axios configuration
  config: {
    // this always accept any status code
    // and will now throw errors on HTTP error codes
    validateStatus: (status) => status < 400,
  },
});

function doApiCall() {
  // create client with the new factory
  // without subitting the credentials
  // every time
  const client = await createClient();

  // now, do some API call with a pre-configured client
  // that submits the access_token as Bearer via
  // Authorization header
  return client.get("/foo?bar=baz"); // [GET] https://api.example.com/foo?bar=baz
}

const response = await doApiCall();

Documentation

The API documentation can be found here.

node-oauth2-client's People

Contributors

ekmobile avatar

Forkers

atb-as

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.