Skip to content

Latest commit

 

History

History
23 lines (20 loc) · 1.45 KB

README.md

File metadata and controls

23 lines (20 loc) · 1.45 KB

example workflow codecov

HyperMashmau for Node.js and the Browser

We created this library because we feel Hypermedia APIs do not have any good frontend tools for traversing data. This library has a similar workflow to Falcor or GraphQL but gives you the power to use your HAL-based Hypermedia APIs.

This library tries not to be opinionated and keeps things open for extension.

The idea behind the library is simple "Write Less Do More". We took a look at what other successful libraries have done well and tried to mimic that in the Hypermedia context. The HyperMashmau is simple to use and easy to migrate to.

const hyperMashmau = new HyperMashmau({ apiRootUrl: 'https://example.org/api' });
const { name, age, gender } = await hyperMashmau.get<{name: string, age: number, gender: string}>(`/hm:users/0/{
  name,
  age,
  gender,
}`);

The code above will make multiple API requests if needed. Let’s say _embedded has a hm:user but that resource only has name then the library will get the self link of that resource and try to find the remaining values from the full resource. If it can't find the values their ether it will print an error but still return the data it could find.