| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | # letiny-core
 | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | A framework for building letsencrypt clients, forked from `letiny`. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   * browser | 
					
						
							|  |  |  |   * node with `forge` (works on windows) | 
					
						
							|  |  |  |   * node with `ursa` (works fast) | 
					
						
							|  |  |  |   * any javascript implementation | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Usage:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | ```bash | 
					
						
							|  |  |  | npm install --save letiny-core | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | ```javascript | 
					
						
							|  |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var leCore = require('leCore'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | leCore. | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | ## API
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 00:13:07 +00:00
										 |  |  | ```javascript | 
					
						
							|  |  |  | LeCore.registerNewAccount(options, cb); | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 00:13:07 +00:00
										 |  |  | LeCore.getCertificate(options, cb); | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 00:13:07 +00:00
										 |  |  | LeCore.Acme                               // Signs requests with JWK | 
					
						
							|  |  |  |   acme = new Acme(lePrivateKey)           // privateKey format is abstract | 
					
						
							|  |  |  |   acme.post(url, body, cb)                // POST with signature | 
					
						
							|  |  |  |   acme.parseLinks(link)                   // (internal) parses 'link' header | 
					
						
							|  |  |  |   acme.getNonce(url, cb)                  // (internal) HEAD request to get 'replay-nonce' strings | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | LeCore.leCrypto | 
					
						
							| 
									
										
										
										
											2015-12-16 00:13:07 +00:00
										 |  |  |   thumbprint(lePubKey)                          // generates thumbprint | 
					
						
							|  |  |  |   generateSignature(lePrivKey, bodyBuf, nonce)  // generates a signature | 
					
						
							|  |  |  |   importPemPrivateKey(privateKeyPem);           // returns abstract private key | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | For testing and development, you can also inject the dependencies you want to use: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```javascript | 
					
						
							|  |  |  | leCore.create({ | 
					
						
							|  |  |  |   request: require('request') | 
					
						
							|  |  |  | , leCrypto: rquire('./lib/letsencrypt-forge') | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Licence
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-13 17:50:04 +01:00
										 |  |  | MPL 2.0 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-15 22:07:02 +00:00
										 |  |  | All of the code is available under the MPL-2.0. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Some of the files are original work not modified from `letiny` | 
					
						
							|  |  |  | and are made available under MIT as well (check file headers). |