http-z

HTTP message parser and builder

Usage no npm install needed!

<script type="module">
  import httpZ from 'https://cdn.skypack.dev/http-z';
</script>

README

http-z

Build Status Code Coverage npm version

Features

HTTP message (request/response) parser/builder according to the rules defined in RFC 7230. Works in Node.js and in the browser.

Install

$ npm i http-z

Usage

const httpZ = require('http-z')

let rawMessage = [
  'GET /features?p1=v1 HTTP/1.1',
  'Host: example.com',
  'Accept: *',
  'Accept-Encoding: gzip,deflate',
  'Accept-Language: en-US;q=0.6, en;q=0.4',
  '',
  ''
].join('\r\n')

let messageModel = httpZ.parse(rawMessage)
console.log(JSON.stringify(messageModel, null, 2))

/* output:
{
  "protocolVersion": "HTTP/1.1",
  "method": "GET",
  "target": "/features?p1=v1",
  "host": "example.com",
  "path": "/features",
  "headersSize": 135,
  "bodySize": 0,
  "queryParams": [
    { "name": "p1", "value": "v1" }
  ],
  "headers": [
    { "name": "Host", "value": "example.com" },
    { "name": "Accept", value": "*" },
    { "name": "Accept-Encoding", "value": "gzip,deflate" },
    { "name": "Accept-Language", "value": "en-US;q=0.6, en;q=0.4" }
  ]
}
*/

rawMessage = httpZ.build(messageModel)
console.log(rawMessage)

/* output:
GET /features?p1=v1 HTTP/1.1
Host: example.com
Accept: *
Accept-Encoding: gzip,deflate
Accept-Language: en-US;q=0.6, en;q=0.4


*/

API

parse(rawMessage, opts)

Parses HTTP request/response raw message and returns a model.

  • rawMessage is HTTP raw message.
  • opts - options object, can be skipped.
build(messageModel, opts)

Builds HTTP request/response raw message from the model.

  • messageModel is HTTP message model.
  • opts - options object, can be skipped.

References

Licence

Licensed under the MIT license.

Author

Alexander Mac