Package Exports
- http-link-header
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (http-link-header) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
HTTP Link Header
Parse & format HTTP link headers according to RFC 5988
Install via npm
$ npm install --save http-link-header
Usage
var LinkHeader = require( 'http-link-header' )
Parse a HTTP link header
var link = LinkHeader.parse(
'<example.com>; rel="example"; title="Example Website", ' +
'<example-01.com>; rel="alternate"; title="Alternate Example Domain"'
)
> Link {
refs: [
{ uri: 'example.com', rel: 'example', title: 'Example Website' },
{ uri: 'example-01.com', rel: 'alternate', title: 'Alternate Example Domain' },
]
}
Check whether it has a reference with a given attribute & value
link.has( 'rel', 'alternate' )
> true
Retrieve a reference with a given attribute & value
link.get( 'title', 'alternate' )
> { uri: 'example-01.com', rel: 'alternate', title: 'Alternate Example Domain' }
// Shorthand for `rel` attributes
link.rel( 'alternate' )
> { uri: 'example-01.com', rel: 'alternate', title: 'Alternate Example Domain' }
Set references
link.set({ rel: 'next', uri: 'http://example.com/next' })
> Link {
refs: [
{ uri: 'example.com', rel: 'example', title: 'Example Website' },
{ uri: 'example-01.com', rel: 'alternate', title: 'Alternate Example Domain' },
{ rel: 'next', uri: 'http://example.com/next' }
]
}
NOTE: According to RFC 5988 only one reference with the same rel
attribute is allowed,
so the following effectively replaces an existing reference:
link.set({ uri: 'http://not-example.com', rel: 'example' })
> Link {
refs: [
{ uri: 'http://not-example.com', rel: 'example' },
{ uri: 'example-01.com', rel: 'alternate', title: 'Alternate Example Domain' },
]
}
Stringify to HTTP header format
link.toString()
> '<example.com>; rel="example"; title="Example Website", <example-01.com>; rel="alternate"; title="Alternate Example Domain"'
Speed
$ npm run benchmark
http-link-header
parse .......................................... 210,211 op/s
toString ....................................... 922,244 op/s