Skip to content
/ hal9k Public

A pure JavaScript library for creating, modifying and validating HAL conform objects based on https://tools.ietf.org/html/draft-kelly-json-hal-08

License

Notifications You must be signed in to change notification settings

coliquio/hal9k

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

coliquio Build Status

hal9k - coliquio's internal HAL library

A pure JavaScript library for creating, modifying and validating HAL conform objects based on draft-kelly-json-hal-08

Requirements

Installation

npm install hal9k

Example

Basic Resource

const hal9k = require('hal9k');
hal9k.resource()
.link('self', '/order/123')
.state({
    "currency": "USD",
    "status": "shipped",
    "total": 10.20
});

API

hal9k

const hal9k = require('hal9k');

hal9k.fromJSON(json) - Create a resource from JSON

// As object...
hal9k.fromJSON({
 _links: {
   self: { href: '/orders' },
   curies: [{
     name: 'acme',
     href: 'http://docs.acme.com/relations/{rel}',
     templated: true
   }],
   'acme:widgets': { href: '/widgets' }
 }
});

// or as string.
hal9k.fromJSON(`{
    "_links": {
        "self": {
            "href": "/orders/523"
        },
        "warehouse": {
            "href": "/warehouse/56"
        },
        "invoice": {
            "href": "/invoices/873"
        }
    },
    "currency": "USD",
    "status": "shipped",
    "total": 10.20
}`);

hal9k.isValidHal(json) - Validates resource syntax and structure

Possible inputs
// As json string...
hal9k.isValidHAL(`{
    "_links": {
        "self": {
            "href": "/orders/523"
        },
        "warehouse": {
            "href": "/warehouse/56"
        },
        "invoice": {
            "href": "/invoices/873"
        }
    },
    "currency": "USD",
    "status": "shipped",
    "total": 10.20
}`);

// as json object...
hal9k.isValidHAL({
    "_links": {
        "self": {
            "href": "/orders/523"
        },
        "warehouse": {
            "href": "/warehouse/56"
        },
        "invoice": {
            "href": "/invoices/873"
        }
    },
    "currency": "USD",
    "status": "shipped",
    "total": 10.20
});

// or as resource object
hal9k.isValidHAL(
    hal9k.resource({
        "currency": "USD",
        "status": "shipped",
        "total": 10.20
    })
    .link('self', '/orders/523')
    .link('warehouse', '/warehouse/56')
    .link('invoice', '/invoices/873')
);
Possible outputs
// valid Hal
{
    warnings: [],
    errors: []
}
// with warnings
{
    warnings: [
        {
            resourceRel: 'root',
            title: 'missing self link',
            description: 'Each Resource Object SHOULD contain a self link.'
        }
    ],
    errors: []
}
// with errors
{
    warnings: [],
    errors: [
        {
            resourceRel: 'yourResource',
            title: 'missing href in link',
            description: 'The "href" property is REQUIRED.'
        }
    ]
}

hal9k.resource(data) - Create a resource object

// creates an empty resource
hal9k.resource();

// resource with state
hal9k.resource({
    "currency": "USD",
    "status": "shipped",
    "total": 10.20
});

The resource object chains

.link(rel, href, optionalParams) - Add links

optionalParams:
href, templated, type, deprecation, name, profile, title, hreflang

hal9k.resource()
.link('self', '/example/href/2');

hal9k.resource()
.link('self', '/example/href', {
    type: 'json',
    deprecation: 'url/to/further/information/concerning/deprecation',
    name: 'sample name'
});

hal9k.resource()
.link('self', {
    href: '/example/href',
    type: 'json',
    deprecation: 'url/to/further/information/concerning/deprecation',
    name: 'sample name'
});

hal9k.resource()
.link('items', [
    '/first_item',
    '/second_item'
]);

.embed(rel, resource) - Embed resources

hal9k.resource()
.link('self', '/example/href/2')
.embed('order', hal9k.resource());

hal9k.resource()
.link('self', '/example/href/2')
.embed('orders', [
    hal9k.resource(),
    hal9k.resource()
]);

.state(data) - Add state

hal9k.resource()
.link('self', '/example/href/2')
.state({
    key1: 'value1',
    key2: 'value2',
    key3: 'value3',
});

.toJSON() - Returns valid HAL-JSON-Object (end of chain)

Input
hal9k.resource({
    "currency": "USD",
    "status": "shipped",
    "total": 10.20
})
.link('self', '/orders/523')
.link('warehouse', '/warehouse/56')
.link('invoice', '/invoices/873')
.toJSON();
Result
{
 "_links": {
   "self": { "href": "/orders/523" },
   "warehouse": { "href": "/warehouse/56" },
   "invoice": { "href": "/invoices/873" }
 },
 "currency": "USD",
 "status": "shipped",
 "total": 10.20
}

.curie(name, href) - Add a link relation abbreviated via CURIE syntax

Input
hal9k.resource()
.link('self', '/orders')
.curie('acme', 'http://docs.acme.com/relations/{rel}')
.link('acme:widgets', '/widgets')
.toJSON();
Result
{
    "_links": {
        "self": {
            "href": "/orders"
        },
        "curies": [{
            "name": "acme",
            "href": "http://docs.acme.com/relations/{rel}",
            "templated": true
        }],
        "acme:widgets": {
            "href": "/widgets"
        }
    }
}

License

See LICENSE.

About

coliquio ist mit über 170.000 registrierten Ärzten
aller Fachrichtungen das größte Ärzte-Netzwerk im deutschsprachigen Raum.

coliquios Applikationslandschaft setzt auf eine moderne Microservice-basierte
Architektur. Standardisierte API sind daher ein großer und wichtiger Teil unserer
Arbeit. HAL (Hypertext Application Language) hilft uns unsere API von innen
heraus zu entdecken und erleichtert das schnelle Arbeiten mit den Schnittstellen.
Ein wichtiger Faktor um unsere Produktivität zu erhöhen. Diese Library ist nach
dem neuesten HAL Draft erstellt worden.

coliquio is today with over 170,000 physicians of all disciplines
the largest medical community in the German-speaking world.

coliquios application landscape is based on a modern microservice
architecture. Standardized APIs are therefore a large and important part of our
business. HAL (Hypertext Application Language) helps us to discover our APIs
and facilitate fast working with our interfaces.
It's an important factor to increase our productivity.
This library has been created according to the latest HAL Draft.

Disclaimer

This is a project for the community, from developers for developers. This is NOT an official coliquio product. I.e. Maintenance and support are provided by the individual developers but not officially by coliquio.

About

A pure JavaScript library for creating, modifying and validating HAL conform objects based on https://tools.ietf.org/html/draft-kelly-json-hal-08

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published