Compare commits
	
		
			No commits in common. "master" and "v2.0.1" have entirely different histories.
		
	
	
		
	
		
							
								
								
									
										5
									
								
								.github/ISSUE_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/ISSUE_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							| @ -2,11 +2,10 @@ | |||||||
| ATTENTION! | ATTENTION! | ||||||
| ========== | ========== | ||||||
| 
 | 
 | ||||||
| Please report issues at https://git.coolaj86.com/coolaj86/greenlock-express.js | Please report issues at https://github.com/Daplie/letsencrypt-express | ||||||
| 
 | 
 | ||||||
| ======== | ======== | ||||||
| ACHTUNG! | ACHTUNG! | ||||||
| ======== | ======== | ||||||
| 
 | 
 | ||||||
| Bitte melden Sie Probleme bei | Bitte melden Sie Probleme bei https://github.com/Daplie/letsencrypt-express | ||||||
| https://git.coolaj86.com/coolaj86/greenlock-express.js |  | ||||||
|  | |||||||
							
								
								
									
										31
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								LICENSE
									
									
									
									
									
								
							| @ -1,32 +1,3 @@ | |||||||
| At your option you may choose either of the following licenses: |  | ||||||
| 
 |  | ||||||
|   * The MIT License (MIT) |  | ||||||
|   * The Apache License 2.0 (Apache-2.0) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| The MIT License (MIT) |  | ||||||
| 
 |  | ||||||
| Copyright (c) 2016-2018 AJ ONeal |  | ||||||
| 
 |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy |  | ||||||
| of this software and associated documentation files (the "Software"), to deal |  | ||||||
| in the Software without restriction, including without limitation the rights |  | ||||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |  | ||||||
| copies of the Software, and to permit persons to whom the Software is |  | ||||||
| furnished to do so, subject to the following conditions: |  | ||||||
| 
 |  | ||||||
| The above copyright notice and this permission notice shall be included in all |  | ||||||
| copies or substantial portions of the Software. |  | ||||||
| 
 |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |  | ||||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |  | ||||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |  | ||||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |  | ||||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |  | ||||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |  | ||||||
| SOFTWARE. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|                                  Apache License |                                  Apache License | ||||||
|                            Version 2.0, January 2004 |                            Version 2.0, January 2004 | ||||||
|                         http://www.apache.org/licenses/ |                         http://www.apache.org/licenses/ | ||||||
| @ -215,7 +186,7 @@ SOFTWARE. | |||||||
|       same "printed page" as the copyright notice for easier |       same "printed page" as the copyright notice for easier | ||||||
|       identification within third-party archives. |       identification within third-party archives. | ||||||
| 
 | 
 | ||||||
|    Copyright 2015 AJ ONeal |    Copyright {yyyy} {name of copyright owner} | ||||||
| 
 | 
 | ||||||
|    Licensed under the Apache License, Version 2.0 (the "License"); |    Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|    you may not use this file except in compliance with the License. |    you may not use this file except in compliance with the License. | ||||||
|  | |||||||
							
								
								
									
										166
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										166
									
								
								README.md
									
									
									
									
									
								
							| @ -1,139 +1,105 @@ | |||||||
| # Greenlock™ for Koa | <!-- BANNER_TPL_BEGIN --> | ||||||
| 
 | 
 | ||||||
| An Automated HTTPS ACME client (Let's Encrypt v2) for Koa | About Daplie: We're taking back the Internet! | ||||||
|  | -------------- | ||||||
| 
 | 
 | ||||||
| Greenlock™ for | Down with Google, Apple, and Facebook! | ||||||
| [Browsers](https://git.coolaj86.com/coolaj86/greenlock.html), |  | ||||||
| [Node.js](https://git.coolaj86.com/coolaj86/greenlock.js), |  | ||||||
| [Commandline](https://git.coolaj86.com/coolaj86/greenlock-cli.js), |  | ||||||
| [Express.js](https://git.coolaj86.com/coolaj86/greenlock-express.js), |  | ||||||
| [Node.js Cluster](https://git.coolaj86.com/coolaj86/greenlock-cluster.js), |  | ||||||
| [hapi](https://git.coolaj86.com/coolaj86/greenlock-hapi.js), |  | ||||||
| **Koa**, |  | ||||||
| and [rill](https://git.coolaj86.com/coolaj86/greenlock-rill.js) |  | ||||||
| | Sponsered by [ppl](https://ppl.family) |  | ||||||
| 
 | 
 | ||||||
| Features | We're re-decentralizing the web and making it read-write again - one home cloud system at a time. | ||||||
| ======== |  | ||||||
| 
 | 
 | ||||||
|   * [x] Automatic Registration via SNI (`httpsOptions.SNICallback`) | Tired of serving the Empire? Come join the Rebel Alliance: | ||||||
|   * [x] Secure domain approval callback |  | ||||||
|   * [x] Automatic renewal between 10 and 14 days before expiration |  | ||||||
|   * [x] Virtual Hosting (vhost) with Multiple Domains & SAN |  | ||||||
|   * [x] and [more](https://git.coolaj86.com/coolaj86/greenlock-express.js) |  | ||||||
|   * [x] plugins for AWS, redis, and more |  | ||||||
| 
 | 
 | ||||||
| This module is just an alias for greenlock-express.js, | <a href="mailto:jobs@daplie.com">jobs@daplie.com</a> | [Invest in Daplie on Wefunder](https://daplie.com/invest/) | [Pre-order Cloud](https://daplie.com/preorder/), The World's First Home Server for Everyone | ||||||
| which works with any middleware system. | 
 | ||||||
|  | <!-- BANNER_TPL_END --> | ||||||
|  | 
 | ||||||
|  | # greenlock-koa (letsencrypt-koa) | ||||||
|  | 
 | ||||||
|  | [](https://gitter.im/Daplie/letsencrypt-express?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) | ||||||
|  | 
 | ||||||
|  | | [letsencrypt (lib)](https://git.daplie.com/Daplie/node-greenlock) | ||||||
|  | | [letsencrypt-cli](https://git.daplie.com/Daplie/greenlock-cli)  | ||||||
|  | | [letsencrypt-express](https://git.daplie.com/Daplie/greenlock-express) | ||||||
|  | | [letsencrypt-cluster](https://git.daplie.com/Daplie/greenlock-cluster) | ||||||
|  | | **letsencrypt-koa** | ||||||
|  | | [letsencrypt-hapi](https://git.daplie.com/Daplie/greenlock-hapi) | ||||||
|  | | | ||||||
|  | 
 | ||||||
|  | Free SSL and Automatic HTTPS for node.js with KOA and other middleware systems via Let's Encrypt | ||||||
|  | 
 | ||||||
|  | * Automatic Registration via SNI (`httpsOptions.SNICallback`) | ||||||
|  |   * **registrations** require an **approval callback** in *production* | ||||||
|  | * Automatic Renewal (around 80 days) | ||||||
|  |   * **renewals** are *fully automatic* and happen in the *background*, with **no downtime** | ||||||
|  | * Automatic vhost / virtual hosting | ||||||
|  | 
 | ||||||
|  | All you have to do is start the webserver and then visit it at it's domain name. | ||||||
| 
 | 
 | ||||||
| ## Install | ## Install | ||||||
| 
 | 
 | ||||||
| ``` | ``` | ||||||
| npm install --save greenlock-koa@2.x | npm install --save letsencrypt-express@2.x | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| QuickStart | *Pay no attention to the man behind the curtain.* (just ignore that the name of the module is letsencrypt-express) | ||||||
| ========== | 
 | ||||||
|  | ### Part 1: Setup | ||||||
| 
 | 
 | ||||||
| ```javascript | ```javascript | ||||||
| 'use strict'; | 'use strict'; | ||||||
| 
 | 
 | ||||||
| ////////////////////// | var le = require('letsencrypt-express').create({ | ||||||
| // Greenlock Setup  // |   server: 'staging' // in production use 'https://acme-v01.api.letsencrypt.org/directory' | ||||||
| ////////////////////// |  | ||||||
|    |    | ||||||
| var greenlock = require('greenlock-koa').create({ | , configDir: require('os').homedir() + '/letsencrypt/etc' | ||||||
|   version: 'draft-11' // Let's Encrypt v2 |  | ||||||
|   // You MUST change this to 'https://acme-v02.api.letsencrypt.org/directory' in production |  | ||||||
| , server: 'https://acme-staging-v02.api.letsencrypt.org/directory' |  | ||||||
| 
 | 
 | ||||||
| , email: 'jon@example.com' | , approveDomains: function (opts, certs, cb) { | ||||||
| , agreeTos: true |     opts.domains = certs && certs.altnames || opts.domains; | ||||||
| , approveDomains: [ 'example.com' ] |     opts.email = 'john.doe@example.com' // CHANGE ME | ||||||
|  |     opts.agreeTos = true; | ||||||
| 
 | 
 | ||||||
|   // Join the community to get notified of important updates |     cb(null, { options: opts, certs: certs }); | ||||||
|   // and help make greenlock better |   } | ||||||
| , communityMember: true |  | ||||||
| 
 | 
 | ||||||
| , configDir: require('os').homedir() + '/acme/etc' |  , debug: true | ||||||
| 
 |  | ||||||
| //, debug: true |  | ||||||
| }); | }); | ||||||
|  | ``` | ||||||
| 
 | 
 | ||||||
|  | WARNING: If you don't do any checks and simply complete `approveRegistration` callback, an attacker will spoof SNI packets with bad hostnames and that will cause you to be rate-limited and or blocked from the ACME server. Alternatively, You can run registration *manually*: | ||||||
| 
 | 
 | ||||||
| ////////////////// | ```bash | ||||||
| // Just add Koa // | npm install -g letsencrypt-cli | ||||||
| ////////////////// |  | ||||||
| 
 | 
 | ||||||
|  | letsencrypt certonly --standalone \ | ||||||
|  |   --server 'https://acme-v01.api.letsencrypt.org/directory' \ | ||||||
|  |   --config-dir ~/letsencrypt/etc \ | ||||||
|  |   --agree-tos --domains example.com --email user@example.com | ||||||
|  |    | ||||||
|  | # Note: the '--webrootPath' option is also available if you don't want to shut down your webserver to get the cert. | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ### Part 2: Just add Koa | ||||||
|  | 
 | ||||||
|  | ```javascript | ||||||
| var http = require('http'); | var http = require('http'); | ||||||
| var https = require('https'); | var https = require('spdy'); | ||||||
| var koa = require('koa'); | var koa = require('koa'); | ||||||
| var app = new koa(); | var app = koa(); | ||||||
| 
 | 
 | ||||||
| app.use(function *() { | app.use(function *() { | ||||||
|   this.body = 'Hello World'; |   this.body = 'Hello World'; | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // https server | var server = https.createServer(le.httpsOptions, le.middleware(app.callback())); | ||||||
| var server = https.createServer(greenlock.tlsOptions, greenlock.middleware(app.callback())); |  | ||||||
| 
 | 
 | ||||||
| server.listen(443, function () { | server.listen(443, function () { | ||||||
|  console.log('Listening at https://localhost:' + this.address().port); |  console.log('Listening at https://localhost:' + this.address().port); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| // http redirect to https |  | ||||||
| var http = require('http'); | var http = require('http'); | ||||||
| var redirectHttps = app.use(require('koa-sslify')()).callback(); | var redirectHttps = koa().use(require('koa-sslify')()).callback(); | ||||||
| http.createServer(greenlock.middleware(redirectHttps)).listen(80, function () { | http.createServer(le.middleware(redirectHttps)).listen(80, function () { | ||||||
|   console.log('Listening on port 80 to handle ACME http-01 challenge and redirect to https'); |   console.log('handle ACME http-01 challenge and redirect to https'); | ||||||
| }); | }); | ||||||
| ``` | ``` | ||||||
| 
 |  | ||||||
| Handling a dynamic list of domains |  | ||||||
| ======================== |  | ||||||
| 
 |  | ||||||
| If you handle multiple domains and you dynamically add new ones, |  | ||||||
| you'll want to replace the static list of domains in `approveDomains` |  | ||||||
| with a function like this: |  | ||||||
| 
 |  | ||||||
| ```js |  | ||||||
| function approveDomains(opts, certs, cb) { |  | ||||||
|   // This is where you check your database and associated |  | ||||||
|   // email addresses with domains and agreements and such |  | ||||||
| 
 |  | ||||||
|   // The domains being approved for the first time are listed in opts.domains |  | ||||||
|   // Certs being renewed are listed in certs.altnames |  | ||||||
|   if (certs) { |  | ||||||
|     opts.domains = certs.altnames; |  | ||||||
|   } |  | ||||||
|   else { |  | ||||||
|     // Do something to |  | ||||||
|     opts.email = 'john.doe@example.com'; |  | ||||||
|     opts.agreeTos = true; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   opts.communityMember = true; |  | ||||||
| 
 |  | ||||||
|   // NOTE: you can also change other options such as `challengeType` and `challenge` |  | ||||||
|   // opts.challengeType = 'http-01'; |  | ||||||
|   // opts.challenge = require('le-challenge-fs').create({}); |  | ||||||
| 
 |  | ||||||
|   cb(null, { options: opts, certs: certs }); |  | ||||||
| } |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| **SECURITY**: Be careful with this. |  | ||||||
| If you don't check that the domains being requested are the domains you |  | ||||||
| allow an attacker can make you hit your rate limit for failed verification |  | ||||||
| attempts. |  | ||||||
| 
 |  | ||||||
| See the |  | ||||||
| [vhost example](https://git.coolaj86.com/coolaj86/greenlock-express.js/src/branch/master/examples/vhost.js) |  | ||||||
| for an idea of how this is done. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| More Usage & Troubleshooting |  | ||||||
| ============================ |  | ||||||
| 
 |  | ||||||
| See <https://git.coolaj86.com/coolaj86/greenlock-express.js> |  | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								index.js
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								index.js
									
									
									
									
									
								
							| @ -1,8 +0,0 @@ | |||||||
| 'use strict'; |  | ||||||
| 
 |  | ||||||
| module.exports = require('greenlock-express'); |  | ||||||
| module.exports._greenlockExpressCreate = module.exports.create; |  | ||||||
| module.exports.create = function (opts) { |  | ||||||
|   opts._communityPackage = opts._communityPackage || 'greenlock-koa'; |  | ||||||
|   return module.exports._greenlockExpressCreate(opts); |  | ||||||
| }; |  | ||||||
							
								
								
									
										13
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								package.json
									
									
									
									
									
								
							| @ -1,15 +1,14 @@ | |||||||
| { | { | ||||||
|   "name": "greenlock-koa", |   "name": "greenlock-koa", | ||||||
|   "homepage": "https://git.coolaj86.com/coolaj86/greenlock-koa.js", |   "version": "2.0.1", | ||||||
|   "version": "2.1.4", |   "description": "Free SSL and Automatic HTTPS for node.js with KOA and other middleware systems via ACME (Let's Encrypt)", | ||||||
|   "description": "An Automated HTTPS ACME client (Let's Encrypt v2) for Koa", |  | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "test": "echo \"Error: no test specified\" && exit 1" |     "test": "echo \"Error: no test specified\" && exit 1" | ||||||
|   }, |   }, | ||||||
|   "repository": { |   "repository": { | ||||||
|     "type": "git", |     "type": "git", | ||||||
|     "url": "git+https://git.coolaj86.com/coolaj86/greenlock-koa.js.git" |     "url": "git@git.daplie.com:Daplie/greenlock-koa.git" | ||||||
|   }, |   }, | ||||||
|   "keywords": [ |   "keywords": [ | ||||||
|     "acme", |     "acme", | ||||||
| @ -17,17 +16,17 @@ | |||||||
|     "cluster", |     "cluster", | ||||||
|     "free", |     "free", | ||||||
|     "greenlock", |     "greenlock", | ||||||
|     "freessl", |  | ||||||
|     "free ssl", |  | ||||||
|     "https", |     "https", | ||||||
|     "koa", |     "koa", | ||||||
|     "le", |     "le", | ||||||
|     "letsencrypt", |     "letsencrypt", | ||||||
|  |     "multi-core", | ||||||
|     "node", |     "node", | ||||||
|     "node.js", |     "node.js", | ||||||
|  |     "scale", | ||||||
|     "ssl", |     "ssl", | ||||||
|     "tls" |     "tls" | ||||||
|   ], |   ], | ||||||
|   "author": "AJ ONeal <coolaj86@gmail.com> (https://coolaj86.com/)", |   "author": "AJ ONeal <aj@daplie.com> (https://daplie.com/)", | ||||||
|   "license": "(MIT OR Apache-2.0)" |   "license": "(MIT OR Apache-2.0)" | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user