You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
66 lines
1.8 KiB
Markdown
66 lines
1.8 KiB
Markdown
10 months ago
|
# ecdsa-sig-formatter
|
||
|
|
||
|
[![Build Status](https://travis-ci.org/Brightspace/node-ecdsa-sig-formatter.svg?branch=master)](https://travis-ci.org/Brightspace/node-ecdsa-sig-formatter) [![Coverage Status](https://coveralls.io/repos/Brightspace/node-ecdsa-sig-formatter/badge.svg)](https://coveralls.io/r/Brightspace/node-ecdsa-sig-formatter)
|
||
|
|
||
|
Translate between JOSE and ASN.1/DER encodings for ECDSA signatures
|
||
|
|
||
|
## Install
|
||
|
```sh
|
||
|
npm install ecdsa-sig-formatter --save
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
```js
|
||
|
var format = require('ecdsa-sig-formatter');
|
||
|
|
||
|
var derSignature = '..'; // asn.1/DER encoded ecdsa signature
|
||
|
|
||
|
var joseSignature = format.derToJose(derSignature);
|
||
|
|
||
|
```
|
||
|
|
||
|
### API
|
||
|
|
||
|
---
|
||
|
|
||
|
#### `.derToJose(Buffer|String signature, String alg)` -> `String`
|
||
|
|
||
|
Convert the ASN.1/DER encoded signature to a JOSE-style concatenated signature.
|
||
|
Returns a _base64 url_ encoded `String`.
|
||
|
|
||
|
* If _signature_ is a `String`, it should be _base64_ encoded
|
||
|
* _alg_ must be one of _ES256_, _ES384_ or _ES512_
|
||
|
|
||
|
---
|
||
|
|
||
|
#### `.joseToDer(Buffer|String signature, String alg)` -> `Buffer`
|
||
|
|
||
|
Convert the JOSE-style concatenated signature to an ASN.1/DER encoded
|
||
|
signature. Returns a `Buffer`
|
||
|
|
||
|
* If _signature_ is a `String`, it should be _base64 url_ encoded
|
||
|
* _alg_ must be one of _ES256_, _ES384_ or _ES512_
|
||
|
|
||
|
## Contributing
|
||
|
|
||
|
1. **Fork** the repository. Committing directly against this repository is
|
||
|
highly discouraged.
|
||
|
|
||
|
2. Make your modifications in a branch, updating and writing new unit tests
|
||
|
as necessary in the `spec` directory.
|
||
|
|
||
|
3. Ensure that all tests pass with `npm test`
|
||
|
|
||
|
4. `rebase` your changes against master. *Do not merge*.
|
||
|
|
||
|
5. Submit a pull request to this repository. Wait for tests to run and someone
|
||
|
to chime in.
|
||
|
|
||
|
### Code Style
|
||
|
|
||
|
This repository is configured with [EditorConfig][EditorConfig] and
|
||
|
[ESLint][ESLint] rules.
|
||
|
|
||
|
[EditorConfig]: http://editorconfig.org/
|
||
|
[ESLint]: http://eslint.org
|