2019-10-19 06:16:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Greenlock v3 on its way (Nov 1st, 2019)
  
						 
					
						
							
								
									
										
										
										
											2019-09-04 00:11:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-10-19 06:16:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Greenlock v3 is in private beta (for backers) and will be available publicly by Nov 1st.
							 
						 
					
						
							
								
									
										
										
										
											2019-09-04 00:11:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-10-19 06:16:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								You can keep an eye for updates on the [campaign page ](https://indiegogo.com/at/greenlock ) and,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if this has been a useful project that's saved you time, [please contribute ](https://paypal.me/rootprojects/99 ).
							 
						 
					
						
							
								
									
										
										
										
											2019-09-04 00:11:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-16 14:44:20 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-12 08:03:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# [Greenlock](https://git.rootprojects.org/root/greenlock.js)™ for node.js | a [Root](https://rootprojects.org) project
  
						 
					
						
							
								
									
										
										
										
											2016-04-22 12:17:54 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Greenlock provides Free SSL, Free Wildcard SSL, and Fully Automated HTTPS < br > 
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< small > certificates issued by Let's Encrypt v2 via [ACME ](https://git.rootprojects.org/root/acme-v2.js )</ small >  
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-14 23:40:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-16 01:14:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-14 23:40:51 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Greenlock works
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								in the [Commandline ](https://git.rootprojects.org/root/greenlock-cli.js ) (cli),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								as a [Web Server ](https://git.rootprojects.org/root/greenlock-express.js ),
							 
						 
					
						
							
								
									
										
										
										
											2018-12-17 00:43:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								in [Web Browsers ](https://greenlock.domains ) (WebCrypto),
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								and with **node.js**  ([npm ](https://www.npmjs.com/package/greenlock )).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-17 00:43:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Features
  
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    [x] Actively Maintained and Commercially Supported 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] VanillaJS
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Limited Dependencies
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] MPL-2.0 licensed (great for hobbyists and DIYers)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] [Contact us ](mailto:support@rootprojects.org?subject=Greenlock%20Commercial%20Support ) for Business Support Plans and Commercial LTS Licensing (great for IoT, On-Prem, Web Hosting, etc)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] Automatic HTTPS 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Free SSL
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Free Wildcard SSL
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Multiple domain support (up to 100 altnames per SAN)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Dynamic Virtual Hosting (vhost)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Automatical renewal (10 to 14 days before expiration)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] Great ACME support via [acme.js ](https://git.rootprojects.org/root/acme-v2.js ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] "dry run" with self-diagnostics
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] ACME draft 12
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Let's Encrypt v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] ~Let's Encrypt v1~ (deprecated)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] [Commandline ](https://git.rootprojects.org/root/greenlock-cli.js ) (cli) Utilities 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] Works with `bash` , `fish` , `zsh` , `cmd.exe` , `PowerShell` , and more
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] [Browser ](https://git.rootprojects.org/root/greenlock.html ) Support 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] Full node.js support, with modules for 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] [http/https ](https://git.rootprojects.org/root/greenlock-express.js/src/branch/master/examples ), [Express.js ](https://git.rootprojects.org/root/greenlock-express.js ), [hapi ](https://git.rootprojects.org/root/greenlock-hapi.js ), [Koa ](https://git.rootprojects.org/root/greenlock-koa.js ), [rill ](https://git.rootprojects.org/root/greenlock-rill.js ), spdy, etc
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] Great for securing your Raspberry Pi and IoT projects 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] Extensible Plugin Support 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    [x] AWS S3, AWS Route53, Azure, CloudFlare, Consul, Digital Ocean, etcd, Redis
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Greenlock.js for Middleware
  
						 
					
						
							
								
									
										
										
										
											2015-12-11 03:23:47 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Documentation for using Greenlock with
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[http/https ](https://git.rootprojects.org/root/greenlock-express.js/src/branch/master/examples ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Express.js ](https://git.rootprojects.org/root/greenlock-express.js ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[hapi ](https://git.rootprojects.org/root/greenlock-hapi.js ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Koa ](https://git.rootprojects.org/root/greenlock-koa.js ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[rill ](https://git.rootprojects.org/root/greenlock-rill.js ).
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Table of Contents
  
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    Install 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    **QuickStart**  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Simple Examples 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Example with ALL OPTIONS 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    API 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Developer API 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Change History 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    License 
						 
					
						
							
								
									
										
										
										
											2015-12-13 01:04:44 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Install
  
						 
					
						
							
								
									
										
										
										
											2016-04-18 17:01:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```bash
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								npm install --save greenlock@2 .x
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								**Optional** for _more efficient_  RSA key generation you must use node v10.12+
							 
						 
					
						
							
								
									
										
										
										
											2018-06-29 02:51:35 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< small > (important for those on ARM devices like Raspberry Pi)< / small >  
						 
					
						
							
								
									
										
										
										
											2018-06-29 02:28:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-19 17:42:49 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Production vs Staging
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If at first you don't succeed, stop and switch to staging.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								I've implemented a "dry run" loopback test with self diagnostics
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								so it's pretty safe to start off with the production URLs
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and be far less likely to hit the bad request rate limits.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								However, if your first attempt to get a certificate fails
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								I'd recommend switching to the staging acme server to debug -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								unless you're very clear on what the failure was and how to fix it.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ server: 'https://acme-staging-v02.api.letsencrypt.org/directory' }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-22 10:50:27 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### QuickStart Screencast
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-17 00:43:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Watch the QuickStart demonstration: [https://youtu.be/e8vaR4CEZ5s ](https://youtu.be/e8vaR4CEZ5s )
							 
						 
					
						
							
								
									
										
										
										
											2018-08-22 10:50:27 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< a  href = "https://www.youtube.com/watch?v=e8vaR4CEZ5s&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk" > < img  src = "https://i.imgur.com/Y8ix6Ts.png"  title = "QuickStart Video"  alt = "YouTube Video Preview"  / > < / a >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    [0:00 ](https://www.youtube.com/watch?v=e8vaR4CEZ5s&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk#t=0 ) - Intro 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [2:22 ](https://www.youtube.com/watch?v=e8vaR4CEZ5s&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk#t=142 ) - Demonstrating QuickStart Example 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [6:37 ](https://www.youtube.com/watch?v=e8vaR4CEZ5s&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk?t=397 ) - Troubleshooting / Gotchas 
						 
					
						
							
								
									
										
										
										
											2018-08-22 10:50:27 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Production Configuration (Part 2)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    [1:00 ](https://www.youtube.com/watch?v=bTEn93gxY50&index=2&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk&t=60 ) - Bringing Greenlock into an Existing Express Project 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [2:26 ](https://www.youtube.com/watch?v=bTEn93gxY50&index=2&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk&t=146 ) - The `approveDomains`  callback 
						 
					
						
							
								
									
										
										
										
											2018-08-22 10:50:27 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Security Concerns (Part 3)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    [0:00 ](https://www.youtube.com/watch?v=aZgVqPzoZTY&index=3&list=PLZaEVINf2Bq_lrS-OOzTUJB4q3HxarlXk ) - Potential Attacks, and Mitigation 
						 
					
						
							
								
									
										
										
										
											2018-05-19 17:42:49 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Easy as 1, 2, 3... 4
  
						 
					
						
							
								
									
										
										
										
											2016-04-18 11:27:55 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Greenlock is built to incredibly easy to use, without sacrificing customization or extensibility.
							 
						 
					
						
							
								
									
										
										
										
											2016-04-18 17:01:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The following examples range from just a few lines of code for getting started,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to more robust examples that you might start with for an enterprise-grade use of the ACME api.
							 
						 
					
						
							
								
									
										
										
										
											2016-04-18 11:26:15 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    Automatic HTTPS (for single sites) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Fully Automatic HTTPS (for multi-domain vhosts) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Manual HTTPS (for API integration) 
						 
					
						
							
								
									
										
										
										
											2018-04-20 06:36:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Automatic HTTPS
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								**Note**: For (fully) automatic HTTPS you may prefer
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								the [Express.js module ](https://git.rootprojects.org/root/greenlock-express.js )
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:20:19 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This works for most people, but it's not as fun as some of the other examples.
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:20:19 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Great when
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    [x] You only need a limited number of certificates 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] You want to use the bare node http and https modules without fluff 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// INIT GREENLOCK //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-22 10:50:27 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var greenlock = require('greenlock').create({
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									email: 'user@example .com', // IMPORTANT: Change email and domains
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									agreeTos: true, // Accept Let's Encrypt v2 Agreement
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									configDir: '~/.config/acme', // A writable folder (a non-fs plugin)
							 
						 
					
						
							
								
									
										
										
										
											2018-12-22 07:35:54 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									communityMember: true, // Get (rare) non-mandatory updates about cool greenlock-related stuff (default false)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									securityUpdates: true // Important and mandatory notices related to security or breaking API changes (default true)
							 
						 
					
						
							
								
									
										
										
										
											2018-08-22 11:00:29 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// CREATE SERVERS //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								var redir = require('redirect-https')();
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								require('http')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.createServer(greenlock.middleware(redir))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.listen(80);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								require('spdy')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.createServer(greenlock.tlsOptions, function(req, res) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										res.end('Hello, Secure World!');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.listen(443);
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Fully Automatic HTTPS
  
						 
					
						
							
								
									
										
										
										
											2016-08-30 08:54:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								**Note**: For (fully) automatic HTTPS you may prefer
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								the [Express.js module ](https://git.rootprojects.org/root/greenlock-express.js )
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:16:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Great when
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:16:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    [x] You have a growing number of domains 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] You're integrating into your own hosting solution 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    [x] Customize ACME http-01 or dns-01 challenge 
						 
					
						
							
								
									
										
										
										
											2015-12-16 05:07:56 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// INIT GREENLOCK //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
									
										
										
										
											2015-12-17 02:38:46 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var path = require('path');
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var os = require('os');
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var Greenlock = require('greenlock');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								var greenlock = Greenlock.create({
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									version: 'draft-12',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									server: 'https://acme-v02.api.letsencrypt.org/directory',
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// Use the approveDomains callback to set per-domain config
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// (default: approve any domain that passes self-test of built-in challenges)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									approveDomains: approveDomains,
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 21:09:49 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// the default servername to use when the client doesn't specify
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									servername: 'example.com',
							 
						 
					
						
							
								
									
										
										
										
											2018-12-22 07:35:54 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// If you wish to replace the default account and domain key storage plugin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									store: require('le-store-fs').create({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										configDir: path.join(os.homedir(), 'acme/etc'),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										webrootPath: '/tmp/acme-challenges'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									})
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// APPROVE DOMAINS //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var http01 = require('le-challenge-fs').create({
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									webrootPath: '/tmp/acme-challenges'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								function approveDomains(opts, certs, cb) {
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// This is where you check your database and associated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// email addresses with domains and agreements and such
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// Opt-in to submit stats and get important updates
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									opts.communityMember = true;
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// If you wish to replace the default challenge plugin, you may do so here
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									opts.challenges = { 'http-01': http01 };
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// The domains being approved for the first time are listed in opts.domains
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// Certs being renewed are listed in certs.altnames
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// certs.domains;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// certs.altnames;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									opts.email = 'john.doe@example .com';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									opts.agreeTos = true;
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// NOTE: you can also change other options such as `challengeType`  and `challenge` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// opts.challengeType = 'http-01';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// opts.challenge = require('le-challenge-fs').create({});
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									cb(null, { options: opts, certs: certs });
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// CREATE SERVERS //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								var redir = require('redirect-https')();
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								require('http')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.createServer(greenlock.middleware(redir))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.listen(80);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								require('https')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.createServer(greenlock.tlsOptions, function(req, res) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										res.end('Hello, Secure World!');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.listen(443);
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Manual HTTPS
  
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Here's a taste of the API that you might use if building a commandline tool or API integration
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								that doesn't use node's SNICallback.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// SET USER PARAMS //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/////////////////////
							 
						 
					
						
							
								
									
										
										
										
											2015-12-17 02:38:46 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 19:05:04 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var opts = {
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  domains: [ 'example.com'        // CHANGE EMAIL AND DOMAINS
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								           , 'www.example.com' ]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, email: 'user@example .com'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, agreeTos: true                  // Accept Let's Encrypt v2 Agreement
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, communityMember: true           // Help make Greenlock better by submitting
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                  // stats and getting updates
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 19:05:04 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// INIT GREENLOCK //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								////////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								var greenlock = require('greenlock').create({
							 
						 
					
						
							
								
									
										
										
										
											2018-07-07 15:37:26 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  version: 'draft-12'
							 
						 
					
						
							
								
									
										
										
										
											2018-05-19 17:42:49 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, server: 'https://acme-v02.api.letsencrypt.org/directory'
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, configDir: '/tmp/acme/etc'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								///////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// GET TLS CERTS //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								///////////////////
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								greenlock.register(opts).then(function (certs) {
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 19:00:40 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  console.log(certs);
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 19:05:04 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  // privkey, cert, chain, expiresAt, issuedAt, subject, altnames
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 18:56:46 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}, function (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  console.error(err);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:20:19 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The domain key and ssl certificates you get back can be used in a webserver like this:
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var tlsOptions = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									key: certs.privkey,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									cert: certs.cert + '\r\n' + certs.chain
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								require('https')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.createServer(tlsOptions, function(req, res) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										res.end('Hello, Secure World!');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									.listen(443);
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:20:19 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Example with ALL OPTIONS
  
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:16:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The configuration consists of 3 components:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    Storage Backend (search npm for projects starting with 'le-store-') 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    ACME Challenge Handlers (search npm for projects starting with 'le-challenge-') 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    Letsencryt Config (this is all you) 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-12-13 01:04:44 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```javascript
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								'use strict';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var Greenlock = require('greenlock');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								var greenlock;
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 15:38:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// Storage Backend
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var leStore = require('greenlock-store-fs').create({
							 
						 
					
						
							
								
									
										
										
										
											2017-05-08 19:51:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  configDir: '~/acme/etc'                                 // or /etc/letsencrypt or wherever
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, debug: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// ACME Challenge Handlers
							 
						 
					
						
							
								
									
										
										
										
											2017-04-11 07:45:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								var leHttpChallenge = require('le-challenge-fs').create({
							 
						 
					
						
							
								
									
										
										
										
											2017-05-08 19:51:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  webrootPath: '~/acme/var/'                              // or template string such as
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, debug: false                                            // '/srv/www/:hostname/.well-known/acme-challenge'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function leAgree(opts, agreeCb) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // opts = { email, domains, tosUrl }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  agreeCb(null, opts.tosUrl);
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								greenlock = Greenlock.create({
							 
						 
					
						
							
								
									
										
										
										
											2018-07-07 15:37:26 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  version: 'draft-12'                                     // 'draft-12' or 'v01'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                                          // 'draft-12' is for Let's Encrypt v2 otherwise known as ACME draft 12
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                                          // 'v02' is an alias for 'draft-12'
							 
						 
					
						
							
								
									
										
										
										
											2018-04-16 01:28:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                                          // 'v01' is for the pre-spec Let's Encrypt v1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // staging API
							 
						 
					
						
							
								
									
										
										
										
											2018-05-19 17:42:49 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  //server: 'https://acme-staging-v02.api.letsencrypt.org/directory'
							 
						 
					
						
							
								
									
										
										
										
											2018-04-16 01:28:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  //
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  // production API
							 
						 
					
						
							
								
									
										
										
										
											2018-05-19 17:42:49 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  server: 'https://acme-v02.api.letsencrypt.org/directory'
							 
						 
					
						
							
								
									
										
										
										
											2018-04-16 01:28:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, store: leStore                                          // handles saving of config, accounts, and certificates
							 
						 
					
						
							
								
									
										
										
										
											2017-04-11 07:45:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, challenges: {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'http-01': leHttpChallenge                            // handles /.well-known/acme-challege keys and tokens
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2016-08-15 15:33:26 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, challengeType: 'http-01'                                // default to this challenge type
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, agreeToTerms: leAgree                                   // hook to allow user to view and accept LE TOS
							 
						 
					
						
							
								
									
										
										
										
											2016-08-15 15:39:21 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								//, sni: require('le-sni-auto').create({})                // handles sni callback
							 
						 
					
						
							
								
									
										
										
										
											2018-04-19 13:37:27 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                                          // renewals happen at a random time within this window
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, renewWithin: 14 * 24 *  60 * 60 *  1000                   // certificate renewal may begin at this time
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, renewBy:     10 * 24 *  60 * 60 *  1000                   // certificate renewal should happen by this time
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, debug: false
							 
						 
					
						
							
								
									
										
										
										
											2016-09-21 17:47:47 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								//, log: function (debug) {console.log.apply(console, args);} // handles debug outputs
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
									
										
										
										
											2015-12-13 01:04:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// If using express you should use the middleware
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// app.use('/', greenlock.middleware());
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								//
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 16:12:16 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// Otherwise you should see the test file for usage of this:
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// greenlock.challenges['http-01'].get(opts.domain, key, val, done)
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// Check in-memory cache of certificates for the named domain
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								greenlock.check({ domains: [ 'example.com' ] }).then(function (results) {
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  if (results) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // we already have certificates
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 18:21:10 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  // Register Certificate manually
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  greenlock.register({
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 18:21:10 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    domains: ['example.com']                                // CHANGE TO YOUR DOMAIN (list for SANS)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  , email: 'user@email .com'                                 // CHANGE TO YOUR EMAIL
							 
						 
					
						
							
								
									
										
										
										
											2016-08-06 01:34:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  , agreeTos: ''                                            // set to tosUrl string (or true) to pre-approve (and skip agreeToTerms)
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 18:21:10 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  , rsaKeySize: 2048                                        // 2048 or higher
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  , challengeType: 'http-01'                                // http-01, tls-sni-01, or dns-01
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }).then(function (results) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    console.log('success');
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }, function (err) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // Note: you must either use greenlock.middleware() with express,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // manually use greenlock.challenges['http-01'].get(opts, domain, key, val, done)
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 18:21:10 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // or have a webserver running and responding
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // to /.well-known/acme-challenge at `webrootPath` 
							 
						 
					
						
							
								
									
										
										
										
											2017-01-25 14:08:20 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    console.error('[Error]: node-greenlock/examples/standalone');
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 18:21:10 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    console.error(err.stack);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  });
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								});
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Here's what `results`  looks like:
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```javascript
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ privkey: ''     // PEM encoded private key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, cert: ''        // PEM encoded cert
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, chain: ''       // PEM encoded intermediate cert
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, issuedAt: 0     // notBefore date (in ms) parsed from cert
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, expiresAt: 0    // notAfter date (in ms) parsed from cert
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 19:05:04 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								, subject: ''     // example.com
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								, altnames: []    // example.com,www.example.com
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## API
  
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The full end-user API is exposed in the example above and includes all relevant options.
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-06 01:34:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2018-05-15 15:49:59 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								greenlock.register(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								greenlock.check(opts)
							 
						 
					
						
							
								
									
										
										
										
											2016-08-06 01:34:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Helper Functions
  
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								We do expose a few helper functions:
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    Greenlock.validDomain(hostname) // returns '' or the hostname string if it's a valid ascii or punycode domain name 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								TODO fetch domain tld list
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 04:13:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Template Strings
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The following variables will be tempalted in any strings passed to the options object:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    `~/`  replaced with `os.homedir()`  i.e. `/Users/aj`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    `:hostname`  replaced with the first domain in the list i.e. `example.com`  
						 
					
						
							
								
									
										
										
										
											2016-08-05 04:13:58 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-15 23:23:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Dangerous Options
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								By default SNI is made to lowercase and is automatically rejected if it contains invalid characters for a domain.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This behavior can be modified:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    `__dns_allow_dangerous_names`  allow SNI names like "Robert'); DROP TABLE Students;" 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    `__dns_preserve_case`  passes SNI names such as "ExAMpLE.coM" without converting to lower case 
						 
					
						
							
								
									
										
										
										
											2018-08-15 23:23:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Developer API
  
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If you are developing an `le-store-*`  or `le-challenge-*`  plugin you need to be aware of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								additional internal API expectations.
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								**IMPORTANT**:
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 22:06:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Use `v3.0.0`  as your initial version - NOT v0.1.0 and NOT v1.0.0 and NOT v2.0.0.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This is to indicate that your module is compatible with v3 (v2.7+) of node-greenlock.
							 
						 
					
						
							
								
									
										
										
										
											2015-12-13 05:03:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-01-25 14:08:20 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Since the public API for your module is defined by node-greenlock the major version
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								should be kept in sync.
							 
						 
					
						
							
								
									
										
										
										
											2015-12-13 05:03:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### store implementation
  
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-16 00:00:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								See [greenlock-store-test ](https://git.rootprojects.org/root/greenlock-store-test.js )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and [greenlock-store-fs ](https://git.rootprojects.org/root/greenlock-store-fs.js )
							 
						 
					
						
							
								
									
										
										
										
											2016-08-09 16:40:35 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    accounts. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    checkKeypair(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    check(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    setKeypair(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    set(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    certificates. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    checkKeypair(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    check(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    setKeypair(opts)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    set(opts)
							 
						 
					
						
							
								
									
										
										
										
											2016-08-05 03:03:27 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### challenge implementation
  
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-16 00:00:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								See [greenlock-challenge-test ](https://git.rootprojects.org/root/greenlock-challenge-test.js ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[acme-http-01-cli ](https://git.rootprojects.org/root/acme-http-01-cli.js ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and [acme-dns-01-cli ](https://git.rootprojects.org/root/acme-dns-01-cli.js )
							 
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-    `.set(opts);`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    `.get(opts);`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    `.remove(opts);`  
						 
					
						
							
								
									
										
										
										
											2015-12-12 13:11:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-17 00:43:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Change History
  
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.7 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    API: transitional for v3 API (Promies, async/await)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    Security: Zero external dependencies
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    Plugins: `greenlock-store-fs`  replaces `le-store-certbot`  as the default storage plugin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    Features: Full wildcard support
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    Licensing: Commercial licensing and support plans now available
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.6 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    better defaults, fewer explicit options
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    better pre-flight self-tests, explicit domains not required
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.5 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    bugfix JWK (update rsa-compat)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    eliminate all external non-optional dependencies
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.4 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.4.3 - add security updates (default true) independent of community updates (default false)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.2 - Let's Encrypt v2 Support 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.11 - documentation updates
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.10 - don't let SNICallback swallow approveDomains errors 6286883fc2a6ebfff711a540a2e4d92f3ac2907c
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.8 - communityMember option support
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.7 - bugfix for wildcard support
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.5 - node v6.x compat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.4 - don't promisify all of `dns` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.3 - `renewWithin`  default to 14 days
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.2 - replace git dependency with npm
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    v2.2.1 - April 2018 **Let's Encrypt v2**  support
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.1.17 - Nov 5th 2017 migrate back to personal repo 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.1.9 - Jan 18th 2017 renamed to greenlock 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.0.2 - Aug 9th 2016 update readme 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v2.0.1 - Aug 9th 2016 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    major refactor
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    simplified API
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    modular plugins
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -    knock out bugs
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v1.5.0 now using letiny-core v2.0.0 and rsa-compat 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v1.4.x I can't remember... but it's better! 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v1.1.0 Added letiny-core, removed node-letsencrypt-python 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v1.0.2 Works with node-letsencrypt-python 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-    v1.0.0 Thar be dragons 
						 
					
						
							
								
									
										
										
										
											2015-12-13 03:09:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Commercial Licensing
  
						 
					
						
							
								
									
										
										
										
											2019-08-24 12:54:23 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-04-17 04:42:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								As the number of businesses using Greenlock commercially has increased, we've become more aware of the need for quick-turnaround support and licenses that allow for local private modifications. Currently we offer LTS support and commercial licensing models for IoT, On-Prem, and Web Hosting. Please [contact us ](mailto:support@rootprojects.org?subject=Greenlock%20Commercial%20Support ) to learn more.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Our [trademark policy ](https://therootcompany.com/legal/#trademark ) is pretty much "attribute, but don't confuse". Your users should understand that your product _uses_  Greenlock and not be confused to think that it _is_  Greenlock.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Legal & Rules of the Road
  
						 
					
						
							
								
									
										
										
										
											2015-12-11 03:23:47 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:17:37 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Greenlock™  is a [trademark ](https://rootprojects.org/legal/#trademark ) of AJ ONeal
							 
						 
					
						
							
								
									
										
										
										
											2018-05-11 20:56:24 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The rule of thumb is "attribute, but don't confuse". For example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:17:37 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  Built with [Greenlock.js](https://git.rootprojects.org/root/greenlock.js) (a [Root](https://rootprojects.org) project).
  
						 
					
						
							
								
									
										
										
										
											2019-05-15 22:07:39 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Please [contact us ](mailto:aj@therootcompany.com ) if you have any questions in regards to our trademark,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								attribution, and/or visible source policies. We want to build great software and a great community.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Greenlock™ ](https://git.rootprojects.org/root/greenlock.js ) |
							 
						 
					
						
							
								
									
										
										
										
											2018-12-17 00:43:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								MPL-2.0 |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Terms of Use ](https://therootcompany.com/legal/#terms ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[Privacy Policy ](https://therootcompany.com/legal/#privacy )