Api is simple HTTP client wrapper that lets us define REST methods in single line of code.
import api from 'bivrost/http/api'
import fetchAdapter from 'bivrost-fetch-adapter';
const githubApi = api({
protocol: 'https:'
host: 'api.github.com',
adapter: fetchAdapter()
});
Options:
- protocol - http protocol. Available values - http: an https:
- host - server hostname
- prefix - api url prefix. Useful when there are multiple api versions:
- /user
- /v1/user
- /v2/user
Example:
// Create a new repository for the authenticated user
const createRepository = githubApi('POST /user/repos');
createRepository({
name: 'My new repo',
}).then(response => {});
// List all public repositories
const getRepositoryList = githubApi('GET /repositories');
// Stringify url according to params
getRepositoryList.stringify({
since: 364,
}); // https://api.github.com/repositories?since=364
getRepositoryList({
since: 364, // The integer ID of the last Repository that you've seen.
}).then(response => {});
// List of users repositories
const getRepositoryInfo = githubApi('GET /repos/:owner/:repo');
getUserRepositories({
owner: 'tuchk4',
repo: 'bivrost',
}).then(response => {});
# Api url definition and placeholders
PUT /user/:id
- id parameter is required. id will be removed from request body. All other parameters will be passed to request body.
const updateUser = api('PUT /user/:id');
updateUser({
id: 1,
name: 'Valerii',
});
// Make PUT request to /user/1
// with request body
// name=Valerii
POST /user?:hash&:version
- hash and version parameters are required. These parameters will be removed from request body and passed to query. All other parameters will be passed to request body.
const createUser = api('POST /user?:hash&:version&');
createUser({
name: 'John Doe',
hash: 'eecab3',
version: 'v1.2.0',
});
// Make POST request to /user?hash=eecab3&version=v1.2.0
// with request body
// name=tuchk4
GET /users
- for GET requests all parameters are passed to query.
const getUsers = api('GET /users');
getUsers({
group: 'admin',
orderBy: 'loginDate',
});
// Make GET request to /users?group=admin&orderBy=loginDate
# Under the hood: adapters
POST /user?:hash&:version
does not guarantee that XHR POST method will be called. What will be done depends on used adapter - api just calls adapter function with generated config. In case of localStorage adapter - it will save or load data to localStorage.