fasquest

3.1.5 • Public • Published

Fasquest

A fast node request model, works very similar to request module but way faster and no dependencies + it works in the browser!

Install

npm install fasquest

Basic Node Example

const Fasquest = require('fasquest');

var options = {
  uri: 'http://127.0.0.1/',
  resolveWithFullResponse: true
}

Fasquest.request(options).then(res=>{
  console.log('hey look I got a response')
})

Basic Web Example

import Fasquest from "fasquest";
var options = {
  uri: 'http://127.0.0.1/',
  resolveWithFullResponse: true
}

await Fasquest.request(options);

Options

  • uri (string): The URL to make the request to.
  • method (string): The HTTP method to use (default: 'GET').
  • qs (object): An object containing query string parameters to be appended to the URL.
  • headers (object): An object containing request headers.
  • body (string|object): The body of the request. If json is set to true, this should be an object.
  • json (boolean): If true, sets the Content-Type header to application/json and stringifies the body.
  • form (object): An object containing form data. Sets the Content-Type header to application/x-www-form-urlencoded.
  • timeout (number): The number of milliseconds to wait for a response before timing out.
  • resolveWithFullResponse (boolean): If true, the full response object is returned, otherwise only the response body is returned.
  • simple (boolean): If true, only resolves the promise if the status code is 2xx otherwise throws an error.
  • authorization (object): An object containing authorization information. Supports basic and bearer tokens.
  • redirect_max (number): The maximum number of redirects to follow (default: 5).
  • agent (object): An object containing custom HTTP/HTTPS agents.

Example with Options

const Fasquest = require('fasquest');

var options = {
  uri: 'http://127.0.0.1/',
  method: 'POST',
  qs: { key1: 'value1', key2: 'value2' },
  headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify({ key: 'value' }),
  json: true,
  form: { key: 'value' },
  timeout: 5000,
  resolveWithFullResponse: true,
  simple: false,
  authorization: { bearer: 'token' },
  redirect_max: 10,
  agent: { http: new http.Agent(), https: new https.Agent() }
}

Fasquest.request(options).then(res=>{
  console.log('Response:', res)
}).catch(err=>{
  console.error('Error:', err)
})

Possible Errors

  • FR_Simple: Thrown when the simple option is true and the response status code is not 2xx.
  • FR_Request_<ErrorName>: Thrown when there is an error with the request. <ErrorName> will be replaced with the specific error name.
  • FR_Request_Timeout: Thrown when the request times out.

Changelog

Changelog

All notable changes to this project will be documented in this file. Dates are displayed in UTC.

20 November 2024

18 April 2022

8 February 2021

  • Fixed bug with urls with : in their path f123cfa

8 February 2021

  • Default to text/plain if no content type is provided with body dad6486

5 February 2021

20 October 2020

  • Fixed issue with timeouts, removed default timeout logic if no timeout is set in options 5113537

22 September 2020

  • Fixed tests and fixed issue with options being mutated 0e90d84

14 September 2020

  • added a way to set the agent 25a8521

11 September 2020

11 September 2020

  • Update index.mjs e5e037f
  • Added timeout functionality and fixed error message names. 9b7e593

1 September 2020

  • Added npm publish at the end of postversion 7266053

1 September 2020

1 September 2020

8 July 2020

8 July 2020

8 July 2020

  • Added browser es module version c54e7cc

23 October 2019

  • Protect against response body not being able to be parsed #1
  • 1.2.3 json empty body fix b6f1f07

12 September 2019

  • 1.2.2 Fixed content-length bug fb48137

12 September 2019

  • 1.2.1 Fixed content-length bug 00f6b9d

v1.2.0

11 September 2019

Package Sidebar

Install

npm i fasquest

Weekly Downloads

787

Version

3.1.5

License

GPL-3.0-or-later

Unpacked Size

154 kB

Total Files

12

Last publish

Collaborators

  • phara0h