Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cap32/http-ask
A flexible promise based HTTP client for Node.js and browser.
https://github.com/cap32/http-ask
ajax http-client promise
Last synced: about 2 months ago
JSON representation
A flexible promise based HTTP client for Node.js and browser.
- Host: GitHub
- URL: https://github.com/cap32/http-ask
- Owner: Cap32
- Created: 2016-10-24T07:52:23.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-12-11T07:26:26.000Z (about 7 years ago)
- Last Synced: 2024-08-09T23:06:35.517Z (6 months ago)
- Topics: ajax, http-client, promise
- Language: JavaScript
- Size: 130 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
A flexible promise based HTTP client for Node.js and browser.
[![Build Status](https://travis-ci.org/Cap32/http-ask.svg?branch=master)](https://travis-ci.org/Cap32/http-ask) [![http-ask code style](https://img.shields.io/badge/code_style-http--ask-brightgreen.svg)](https://github.com/Cap32/http-ask) [![npm version](https://badge.fury.io/js/http-ask.svg)](https://badge.fury.io/js/http-ask)
## Features
- Cloneable and combinable request config
- Support Node.js and browser
- Promise/A+ based
- Chainable API
- Cancelable
- Support timeout## Installing
Using npm:
```bash
$ npm install http-ask
```Using yarn:
```bash
$ yarn add http-ask
```## Usage
Basic `GET` request
```js
// Fetch a user with query (eg: http://localhost/api/users?page=32)
Ask
.create('http://localhost/api/users')
.query({ page: 32 })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;// Optionally, you can use an `ask` instance
const ask = new Ask('http://localhost/api/users');
ask
.query({ page: 32 })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;
```Combinable `url`
```js
// Fetch a user by id. (eg: http://localhost/api/users/2333)
const id = 2333;Ask
.create(`http://localhost/api/users/${id}`)
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;// Above could also be done as
Ask
.create('http://localhost')
.url('api/users')
.url(id)
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;
```Combinable `query`
```js
// Fetch users with token and other query. (eg: http://localhost/api/users?token=asdf&page=23&count=10)
const token = 'asdf';Ask
.create('http://localhost/api/users')
.query({ token, page: 23, count: 10 })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;// Above could also be done as
Ask
.create('/users')
.query({ token })
.query({ page: 23, count: 10 })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;```
Clone `ask` instance
```js
const apiHost = 'http://localhost/api';
const token = 'asdf';// create a common api `ask` instance
const askApiWithToken = new Ask(apiHost).query({ token });askApiWithToken
.clone()
.url('users')
.query({ page: 23, count: 10 })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;askApiWithToken
.clone()
.url('users')
.query({ page: 1 })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;
```Performing `POST`, `PUT`, `DELETE` request
```js
// create a common posts `ask` instance
const askPosts = askApiWithToken.clone().url('posts');// post
askPosts
.clone()
.post()
.body({ name: 'Chirs' })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;// put
askPosts
.clone()
.put(id)
.body({ name: 'Chirs' })
.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;// delete
askPosts
.clone().method('delete')
.url(id)
// Above two lines are equal with `.delete(id)`.exec()
.then((data) => console.log(data))
.catch((error) => console.log(error))
;```
## API
### Class: new Ask([url[, config]])
Create an ask instance.
##### Arguments
1. `url` (String): Request URL. In fact, it could be a part (or prefix) of URL.
2. `config` (Object): Support `query`, `method`, `url`, `headers`, `cancellation`, `timeout`, and any other options from [fetch api options](https://developer.mozilla.org/en-US/docs/Web/API/GlobalFetch/fetch)##### Return
(Object): `ask` instance.
##### Example
```js
// es6
import Ask from 'http-ask';// es5
// var Ask = require('http-ask').default;const ask = new Ask('url', {
method: 'post',
body: { ur: 'awesome' }
});
```---
#### Static Method: Ask.create([url[, config]])
The same with `new Ask()`.
##### Return
(Object): `ask` instance.
---
#### Static Method: Ask.request(url[, config])
Short hand for `Ask.create(url, config).exec()`;
##### Return
(Promise): A promise to get response data.
---
#### Static Method: Ask.clone(ask)
The same with `ask.clone()`.
##### Return
(Object): `ask` instance.
---
#### Static Property: Ask.Cancellation()
See the follow `Cancellation` section for detail.
##### Return
(Object): `cancellation` instance, which has a `cancel` method.
---
#### Method: ask#method(method)
Set HTTP request method
##### Arguments
1. `method` (String): All HTTP methods are supported. Default to `get`.
##### Return
(Object): `ask` instance.
---
#### Method: ask#get([url])
Set `GET` method and url.
##### Arguments
1. [`url`] (String): Request URL.
##### Return
(Object): `ask` instance.
---
#### Method: ask#post([url])
Set `POST` method and url.
##### Arguments
1. [`url`] (String): Request URL.
##### Return
(Object): `ask` instance.
---
#### Method: ask#put([url])
Set `PUT` method and url.
##### Arguments
1. [`url`] (String): Request URL.
##### Return
(Object): `ask` instance.
---
#### Method: ask#patch([url])
Set `PATCH` method and url.
##### Arguments
1. [`url`] (String): Request URL.
##### Return
(Object): `ask` instance.
---
#### Method: ask#delete([url])
Set `DELETE` method and url.
##### Arguments
1. [`url`] (String): Request URL.
##### Return
(Object): `ask` instance.
---
#### Method: ask#url(url)
Set or join URL.
##### Arguments
1. `url` (String): Request URL.
##### Return
(Object): `ask` instance.
##### Example
```js
// `url` doesn't start with `/`
Ask
.create('http://you.are')
.url('very/very')
.url('awesome')
.exec()
// the final url is: 'http://you.are/very/very/awesome'
;// `url` starts with '/'
Ask
.create('http://you.are')
.url('very/very')
.url('/awesome') // start with `/`
.exec()
// the final url is: 'http://you.are/awesome'
;
```---
#### Method: ask#query(query)
Set URL query.
##### Arguments
1. `query` (Object): URL query `JSON`.
##### Return
(Object): `ask` instance.
##### Example
```js
Ask
.create('http://localhost', {
query: { a: 1, b: 2 },
})
.query({ b: 3, c: 4 })
.query({ c: 5 })
.exec()
// the final url is: 'http://localhost/?a=1&b=3&c=5'
;
```---
#### Method: ask#body(body)
Set HTTP request body.
##### Arguments
1. `body` (Object): A `JSON` or instance of `FormData` as usual.
##### Return
(Object): `ask` instance.
---
#### Method: ask#set(headerKey, headerValue)
Set HTTP request header.
##### Arguments
1. `headerKey` (String): Header key.
2. `headerValue` (String): Header value.##### Return
(Object): `ask` instance.
---
#### Method: ask#parser(parser)
Add a response parser.
A parser is a function that receives two arguments:
1. `data` (Any): The response data
2. `response` (Response): The Response instanceParser should return a promise. The promise value will be passed to the next parser.
##### Arguments
1. `parser` (Function): Response parser.
##### Return
(Object): `ask` instance.
##### Example
```js
Ask
.create('http://localhost/test')
.parser((data, response) => {
console.log('Status:', response.status);
Promise.resolve('awesome!!!');
})
.parser((data, response) => {
console.log('Data:', data);
return data;
})
.exec()
;
// will log:// Status: 200
// Data: awesome!!!
```---
#### Method: ask#timeout(ms)
Set HTTP request timeout.
##### Arguments
1. `ms` (Number): Timeout(ms). Defaults to 30000.
##### Return
(Object): `ask` instance.
---
#### Method: ask#cancellation(cancellation)
Set a cancellation token. See the follow example for detail.
##### Arguments
1. `cancellation` (Cancellation).
##### Return
(Object): `ask` instance.
##### Example
```js
import Ask, { Cancellation } from 'http-ask';const cancellation = new Cancellation();
setTimeout(() => {
cancellation.cancel(); // trigger cancel
}, 0);return Ask
.create('http://localhost/')
.cancellation(cancellation) // register a cancellation
.exec()
.then(() => assert(false, 'should not go here'))
.catch((err) => assert(err instanceof Cancellation))
;
```---
#### Method: ask#clone()
Clone `ask` with current config.
##### Return
(Object): `ask` instance.
---
#### Method: ask#exec()
Execute request.
##### Return
(Promise): A promise to get response data.
---
#### Property: ask#response
Http Response instance. It is `null` before `.exec()`.
##### Example
```js
const ask = new Ask('http://localhost/');
ask.exec().then((data) => {
console.log('response data', data);
console.log('response status', ask.response.status);
});
```---
## License
MIT