GithubHelp home page GithubHelp logo

bent's Introduction

bent

2377 1106

Functional HTTP client for Node.js and Browsers w/ async/await.

Incredibly small browser version built on fetch w/ no external dependencies or polyfills.

Usage

const bent = require('bent')

const getJSON = bent('json')
const getBuffer = bent('buffer')

let obj = await getJSON('http://site.com/json.api')
let buffer = await getBuffer('http://site.com/image.png')

As you can see, bent is a function that returns an async function.

Bent takes options which constrain what is accepted by the client. Any response that falls outside the constraints will generate an error.

You can provide these options in any order, and Bent will figure out which option is which by inspecting the option's type and content.

const post = bent('http://localhost:3000/', 'POST', 'json', 200);
const response = await post('cars/new', {name: 'bmw', wheels: 4});

If you don't set a response encoding ('json', 'string' or 'buffer') then the native response object will be returned after the statusCode check.

const bent = require('bent')

const getStream = bent('http://site.com')

let stream = await getStream('/json.api')

The following options are available.

  • HTTP Method: 'GET', 'PUT', or any other ALLCAPS string will be used to set the HTTP method. Defaults to 'GET'.
  • Response Format: Available formats are 'string', 'buffer', and 'json'. By default, the response object/stream will be returned instead of a decoded response. Browser returns ArrayBuffer instead of Buffer.
  • Status Codes: Any number will be considered an acceptable status code. By default, 200 is the only acceptable status code. When any status codes are provided, 200 must be included explicitly in order to be acceptable.
  • Headers: An object can be passed to set request headers.
  • Base URL: Any string that begins with 'https:' or 'http:' is considered the Base URL. Subsequent queries need only pass the remaining URL string.

The returned async function is used for subsequent requests.

When working with Binary this library uses different types in the browser and Node.js. In Node.js all binary must be done the Buffer type. In the browser you can use ArrayBuffer or any ArrayBuffer view type (UInt8Array, etc).

async request(url[, body=null, headers={}])

  • url: Fully qualified URL to the remote resource, or in the case that a base URL is passed the remaining URL string.
  • body: Request body. Can be a string, a stream (node.js), a buffer (node.js) (see note below), an ArrayBuffer (browser), or a JSON object.
  • headers: An object of any headers you need to set for just this request.
const bent = require('bent')

const put = bent('PUT', 201)
await put('http://site.com/upload', Buffer.from('test'))

Or

const bent = require('bent')

const put = bent('PUT', 201, 'http://site.com')
await put('/upload', Buffer.from('test'))

NOTE: If the body is passed as an object, it will be treated as JSON, stringified and the Content-Type will be set to application/json unless already set. A common requirement is to POST using form-urlencoded. This will require you to set the Content-Type header to application/x-www-form-urlencoded and to encode the body yourself, perhaps using form-urlencoded.

bent's People

Contributors

aral avatar bertyhell avatar cblanc avatar dependabot-support avatar eomm avatar garbados avatar gimenete avatar mikeal avatar ovyerus avatar srl295 avatar

Stargazers

 avatar

Watchers

 avatar

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.