A module for modern HTTP/HTTPS requests with support for form data, file uploads, JSON, binary data, streams, and more.
Go to file
2017-12-14 22:33:48 +01:00
dist remove need for Content Type application/json on post 2017-12-14 22:33:48 +01:00
test remove need for Content Type application/json on post 2017-12-14 22:33:48 +01:00
ts remove need for Content Type application/json on post 2017-12-14 22:33:48 +01:00
.gitignore initial 2017-01-29 00:52:58 +01:00
.gitlab-ci.yml update for new infrastructure 2017-06-09 22:03:35 +02:00
npmextra.json update for new infrastructure 2017-06-09 22:03:35 +02:00
package.json remove need for Content Type application/json on post 2017-12-14 22:33:48 +01:00
README.md fix README 2017-01-29 01:44:29 +01:00
tslint.json improve README 2017-01-29 01:21:48 +01:00
yarn.lock remove need for Content Type application/json on post 2017-12-14 22:33:48 +01:00

smartrequest

dropin replacement for request

Availabililty

npm git git docs

Status for master

build status coverage report npm downloads per month Dependency Status bitHound Dependencies bitHound Code TypeScript node JavaScript Style Guide

Usage

Use TypeScript for best in class instellisense.

note: smartrequest uses the native node request module under the hood (not the one from npm)

import * as smartrequest from 'smartrequest'

// simple post
let options: smartrequest.ISmartRequestOptions = { // typed options
    headers: {
        "Content-Type": "application/json"
        "Authorization": "Bearer token"
    },
    requestBody: {
        key1: 'value1',
        key2: 3
    }
}

smartrequest.post('https://example.com', options).then(res => {
    console.log(res.status)
    console.log(res.body) // if json, body will be parsed automatically
}).catch(err => {
    console.log(err)
})

// also available
smartrequest.get(...)
smartrequest.put(...)
smartrequest.del(...)

// streaming
smartrequest.get('https://example.com/bigfile.mp4', optionsArg, true).then(res => { // third arg = true signals streaming
    console.log(res.status)
    res.on('data', data => {
        // do something with the data chunk here
    }
    res.on('end', () => {
        // do something when things have ended
    })
})

npm