Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

xfetch

Package Overview
Dependencies
Maintainers
1
Versions
36
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

xfetch

A light-weight module that brings window.fetch to Node.js (with HTTP_PROXY support).

  • 1.3.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
43
increased by437.5%
Maintainers
1
Weekly downloads
 
Created
Source

xfetch

Travis build status Coveralls NPM version Canonical Code Style

A light-weight module that brings window.fetch to Node.js (with HTTP_PROXY support).

API

/**
 * @see https://github.com/tim-kos/node-retry#retrytimeoutsoptions
 */
type RetryConfigurationType = {
  factor?: number,
  maxTimeout?: number,
  minTimeout?: number,
  randomize?: boolean,
  retries?: number
};

type ValidateResponseType = (response: Object) => Promise<boolean>;

type ConfigurationType = {
  +agent?: Object,
  +body?: string | Buffer | Blob | ReadableStream,
  +compress?: boolean,
  +follow?: number,
  +header?: {[key: string]: string | number},
  +method?: string,
  +redirect?: 'follow' | 'manual' | 'error',
  +retry?: RetryConfigurationType,
  +size?: number,
  +timeout?: number,
  +validateResponse?: ValidateResponseType
};

type fetch = (url: string, configuration?: ConfigurationType) => Promise<Object>;

Configuration

NameValue
retryUsed to retry requests that produce response that does not pass validation. Refer to Retry request and Validating response.
validateResponseUsed to validate response. Refer to Validate response.

For other configuration properties, refer to node-fetch documentation.

Behaviour

HTTP proxy

Uses HTTP_PROXY (http://host:port) environment variable value to configure HTTP proxy.

Note: You must also configure NODE_TLS_REJECT_UNAUTHORIZED=0. This is a lazy workaround to enable the proxy to work with TLS.

Throws an error if response code is non-2xx

Throws UnexpectedResponseCodeError error if response code is non-2xx.

This behaviour can be overrode using validateResponse configuration.

Cookbook

Retry request

Requests that result in non-2xx response will be retried.

retry option is used to configure request retry strategy.

The retry configuration shape matches configuration of the retry module.

Validate response

Define a custom validator function to force use the request retry strategy.

A custom validator is configured using validateResponse configuration, e.g.

import xfetch, {
  UnexpectedResponseError
};

const validateResponse = async (response) => {
  const body = await response.text();

  if (body.includes('rate error')) {
    throw new UnexpectedResponseError(response);
  }

  return true;
}

xfetch('http://gajus.com', {validateResponse});

A custom validator must return a boolean flag indicating whether the response is valid. A custom validator can throw an error that extends UnexpectedResponseError error.

xfetch default validator can be imported and used to extend a custom validator, e.g.

import xfetch, {
  UnexpectedResponseError,
  validateResponse as defaultValidateResponse
};

const validateResponse = async (response) => {
  const responseIsValid = await defaultValidateResponse(response);

  if (!responseIsValid) {
    return responseIsValid;
  }

  const body = await response.text();

  if (body.includes('rate error')) {
    throw new UnexpectedResponseError(response);
  }

  return true;
}

xfetch('http://gajus.com', {validateResponse});

Keywords

FAQs

Package last updated on 03 Mar 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc