Skip to content

Sagacify/api-reader

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ApiReader

⚠️ This package is deprecated in favor of Wretch ⚠️

CircleCI Coverage Status npm version

Description

ApiReader is a NodeJS & Browser package meant to simplify your requests to any Api. Browser version is based on native fetch to be as tiny as possible if you use treechecking in your toolbelt (like webpack, create-react-app, ...). It features:

  • API base url recording at constuction for smaller calls
  • automatic query string stringification (based on qs)
  • automatic request body JSON stringifying based body type (objects are stringified)
  • automatic response body JSON parsing based on the Content-Type of the Api response
  • automatic base64 encoding on Basic Authentication
  • custom http error handling hook

Acknowledgment

Most of the code structure and part of the code is inspired from the great bent package. If you don't know it, check it out !

Installation

$ npm install @sagacify/api-reader

Usage

In your project (Browser or NodeJS)

const { ApiReader } = require('@sagacify/api-reader');
// OR
import { ApiReader } from '@sagacify/api-reader';

const main = () => {
  const bearerToken = 'super-secret-token';
  const apiReader = new ApiReader('https://api.twitter.com/2/', {
    headers: {
      authorization: `Bearer ${bearerToken}`
    },
    httpErrorHandler: (req, res) => {
      console.error(`My custom error ${res.status} for ${req.method} on ${req.url}`)
    }
  });

  try {
    const result = await apiReader.get('/2/tweets', {
      query: {
        id: 'some-tweet-id'
      },
    });

    console.log(result);
  } catch (err) {
    // This is an unexpected error, like an network issue
    console.error(err);
  }
}

main();

Note: based on the context either the Browser or the NodeJS version will be used

API

constructor(baseUrl, options)

Parameters
  • baseUrl: the base url of the api (e.g.: https://api.twitter.com/2/)
  • options:
    • auth:

      • username: the username of the Basic Authentication
      • password: the password of the Basic Authentication
    • headers:

      • [header-name]: header value
    • queryOptions: query stringification is based on the qs stringify package, here you can pass any qs option you need

    • preRequestHandler: a pre-request handler function which recieve the fetch options and must return the final fetch options:

      {
        method: <string>, // in uppercase
        headers: <Headers>, // see: https://developer.mozilla.org/fr/docs/Web/API/Headers
        body: <string | object>
      }

      Note: if the final fetchOptions.body is an objet, it will be JSON stringified automatically and the Content-Type will set to "application/json"

    • httpErrorHandler: an http error handler function which recieve the request object.

      The reponse object is a simplified plain version of Response:

      {
        url: <string>,
        method: <string>,
        headers: <object>,
        body: <string | object>
      }

      and the response object The reponse object is a simplified plain version of Response:

      {
        url: <string>,
        status: <number>,
        ok: <boolean>,
        redirected: <boolean>,
        type: <string>,
        headers: <object>,
        body: <string | object> // depend on the parsing
      }

      By default any error will generate a basic error with the code field set to "HTTP_${response.status}"

head(path, options)

Performs an HEAD request to the api

Parameters
  • path: the path from the baseUrl
  • options:
    • headers:
      • [header-name]: header value
    • query: query object
    • body: body value, object will be automatically JSON stringified
Response

Returns the response body automatically parsed according the response's Content-Type

get(path, options)

Performs an GET request to the api

Parameters
  • path: the path from the baseUrl
  • options:
    • headers:
      • [header-name]: header value
    • query: query object
    • body: body value, object will be automatically JSON stringified
Response

Returns the response body automatically parsed according the response's Content-Type

post(path, options)

Performs an POST request to the api

Parameters
  • path: the path from the baseUrl
  • options:
    • headers:
      • [header-name]: header value
    • query: query object
    • body: body value, object will be automatically JSON stringified
Response

Returns the response body automatically parsed according the response's Content-Type

put(path, options)

Performs an PUT request to the api

Parameters
  • path: the path from the baseUrl
  • options:
    • headers:
      • [header-name]: header value
    • query: query object
    • body: body value, object will be automatically JSON stringified
Response

Returns the response body automatically parsed according the response's Content-Type

patch(path, options)

Performs an PATCH request to the api

Parameters
  • path: the path from the baseUrl
  • options:
    • headers:
      • [header-name]: header value
    • query: query object
    • body: body value, object will be automatically JSON stringified
Response

Returns the response body automatically parsed according the response's Content-Type

delete(path, options)

Performs an DELETE request to the api

Parameters
  • path: the path from the baseUrl
  • options:
    • headers:
      • [header-name]: header value
    • query: query object
    • body: body value, object will be automatically JSON stringified
Response*=

Returns the response body automatically parsed according the response's Content-Type

Running all tests

$ npm test:all

Note: that's the one you want to use most of the time

To do

  • improve automatique response parsing, for now buffer are not managed
  • add browser unit tests

Reporting bugs and contributing

If you want to report a bug or request a feature, please open an issue. If want to help us improve api-reader, fork and make a pull request. Please use commit format as described here. And don't forget to run npm run format before pushing commit.

Repository

License

The MIT License (MIT)

Copyright (c) 2020 Sagacify

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

About

REST API request handler

Resources

License

Stars

Watchers

Forks

Packages

No packages published