Sha256: 274c6cbbc921c95550f3c0812cecaba402b30daa492fcf70695eda3563613289

Contents?: true

Size: 1.56 KB

Versions: 181

Compression:

Stored size: 1.56 KB

Contents

# node-http-signature

node-http-signature is a node.js library that has client and server components
for Joyent's [HTTP Signature Scheme](http_signing.md).

## Usage

Note the example below signs a request with the same key/cert used to start an
HTTP server. This is almost certainly not what you actually want, but is just
used to illustrate the API calls; you will need to provide your own key
management in addition to this library.

### Client

```js
var fs = require('fs');
var https = require('https');
var httpSignature = require('http-signature');

var key = fs.readFileSync('./key.pem', 'ascii');

var options = {
  host: 'localhost',
  port: 8443,
  path: '/',
  method: 'GET',
  headers: {}
};

// Adds a 'Date' header in, signs it, and adds the
// 'Authorization' header in.
var req = https.request(options, function(res) {
  console.log(res.statusCode);
});


httpSignature.sign(req, {
  key: key,
  keyId: './cert.pem'
});

req.end();
```

### Server

```js
var fs = require('fs');
var https = require('https');
var httpSignature = require('http-signature');

var options = {
  key: fs.readFileSync('./key.pem'),
  cert: fs.readFileSync('./cert.pem')
};

https.createServer(options, function (req, res) {
  var rc = 200;
  var parsed = httpSignature.parseRequest(req);
  var pub = fs.readFileSync(parsed.keyId, 'ascii');
  if (!httpSignature.verifySignature(parsed, pub))
    rc = 401;

  res.writeHead(rc);
  res.end();
}).listen(8443);
```

## Installation

    npm install http-signature

## License

MIT.

## Bugs

See <https://github.com/joyent/node-http-signature/issues>.

Version data entries

181 entries across 149 versions & 27 rubygems

Version Path
optimacms-0.1.61 spec/dummy/node_modules/http-signature/README.md
disco_app-0.18.0 test/dummy/node_modules/http-signature/README.md
disco_app-0.18.2 test/dummy/node_modules/http-signature/README.md
tang-0.2.1 spec/tang_app/node_modules/http-signature/README.md
groonga-client-model-6.0.0 test/apps/rails6.1.3/node_modules/http-signature/README.md
groonga-client-model-6.0.0 test/apps/rails6.0.3.5/node_modules/http-signature/README.md
ruby2js-4.0.4 lib/tasks/testrails/node_modules/http-signature/README.md
ruby2js-4.0.3 lib/tasks/testrails/node_modules/http-signature/README.md
tang-0.2.0 spec/tang_app/node_modules/http-signature/README.md
tang-0.1.0 spec/tang_app/node_modules/http-signature/README.md
tang-0.0.9 spec/tang_app/node_modules/http-signature/README.md
enju_library-0.3.8 spec/dummy/node_modules/http-signature/README.md
ilog-0.4.1 node_modules/http-signature/README.md
ilog-0.4.1 node_modules/node-sass/node_modules/http-signature/README.md
ilog-0.4.1 node_modules/node-gyp/node_modules/http-signature/README.md
ilog-0.4.0 node_modules/node-gyp/node_modules/http-signature/README.md
ilog-0.4.0 node_modules/http-signature/README.md
ilog-0.4.0 node_modules/node-sass/node_modules/http-signature/README.md
ilog-0.3.3 node_modules/node-gyp/node_modules/http-signature/README.md
ilog-0.3.3 node_modules/http-signature/README.md