Skip to content

Latest commit

 

History

History
108 lines (79 loc) · 2.64 KB

api-function.md

File metadata and controls

108 lines (79 loc) · 2.64 KB

Api function

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.