dame minimalistic HTTP client for the browser and Node.js
- π Lightweight
- βͺοΈ Zero dependencies.
- π Easy to use.
- π’ Node (http & https) and π» browser (Fetch).
- π Promise API.
- β Custom timeout.
- π Automatic transforms to JSON data.
- β Follows redirects.
π Changelog
- Table of contents
- Import
- Basic examples
- Response object
- Methods
- Config
- Configuring base instance
- Creating an instance
- Special statuses
- dame vs. others
- β Return to top
const dame = require("dame");
GET
const {response} = dame.get("https://rickandmortyapi.com/api/location/1");
POST
const {response} = dame.post("https://your.api.com/login", {
username: "Username",
password: "****",
});
{
isError: false,
code: 200,
status: "OK",
response: {...},
error: null,
redirectCount: 3,
}
- isError
boolean
: True if code is >= 200 and < 300 (this is configurable). - code
number
: Status code. - status
string
: Status. - response
any
: Response of the request. - error
any
: If there was any error during the request it will be here. - redirectCount
number
: How many redirects have been followed. Not present if there have been no redirects.
The response can be destructured like this:
const {isError, code, status, response} = dame.get("https://rickandmortyapi.com/api/location/1");
const {response} = dame.get(url, config);
const {response} = dame.delete(url, config);
- url
string
: Full URL or path.- If you set a
baseUrl
, thisurl
will be concatenated to it:baseUrl + url
. - If
url
starts with"http://"
or"https://"
thebaseUrl
from config will be ignored and url will be treated like a full url.
- If you set a
- config
object
: See Config.
const {response} = dame.post(url, body, config);
const {response} = dame.put(url, body, config);
const {response} = dame.patch(url, body, config);
- baseUrl
string
: Base URL that will be concatenated with theurl
of the requests. - headers
object
: Headers that will be attached to the request. - timeout
number
: Number of miliseconds that must pass before timeout the request. - checkIsError
function<boolean>
: Function that will receive the status code (number
) and must returnboolean
. DefaultisError = !(code >= 200 && < 300)
. - Any option that fits on request or fetch.
- maxRedirects
number
: Max redirects to follow. Default 20. Use 0 to disable redirects. - responseType
"arraybuffer" | "stream" | "json" | "text"
: Browser only. Default"json"
. Type of the data that the server will respond with.
Syntax:
dame.<configKey> = <value>;
- configKey: any key from Config.
- value: any value that fits on the config key.
Examples:
dame.baseUrl = "http://localhost:3010";
dame.headers.Authorization = `Bearer abcd.1234`;
dame.timeout = 5000;
Then you'll be able to:
dame.get("/protectedRoute");
// url will be β http://localhost:3010/protectedRoute
// headers will be β {Authorization: "Bearer abcd.1234"}
const dameInstance = dame.new(config, instanceName?);
- config
object
: See Config. - instanceName
string
: (optional) If filled, this instance will be saved ondame.instances.<instanceName>
.
Removing a saved instance:
delete dame.instances.<instanceNameToRemove>
Set base URL
const yourApi = dame.new({
"baseUrl": "http://localhost:3000",
});
Set headers
const yourApi = dame.new({
"headers": {
Authorization: "Bearer abc.123"
}
});
yourApi.headers.Authorization: "Bearer new.token";
Timeout
{
isError: true,
code: 0,
status: 'Timed out',
response: null
}
No response
{
isError: true,
code: -1,
status: "No response from server",
response: null
}
Offline
{
isError: true,
code: -2,
status: "No internet connection",
response: null
}
Package | Browser + Node | Dependencies | Size |
---|---|---|---|
dame | β | 0 | |
phin | β | ||
node-fetch | β | ||
axios | β | ||
got | β | ||
superagent | β | ||
request | β |