You can not 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
						
					
					
				
			
		
		
	
	
							66 lines
						
					
					
						
							1.8 KiB
						
					
					
				| # ecdsa-sig-formatter
 | |
| 
 | |
| [](https://travis-ci.org/Brightspace/node-ecdsa-sig-formatter) [](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
 |