mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-31 15:53:33 +00:00 
			
		
		
		
	request via cloudflare dns working
This commit is contained in:
		| @@ -146,7 +146,11 @@ const internalCertificate = { | |||||||
| 								.then(internalNginx.reload) | 								.then(internalNginx.reload) | ||||||
| 								.then(() => { | 								.then(() => { | ||||||
| 									// 4. Request cert | 									// 4. Request cert | ||||||
| 									return internalCertificate.requestLetsEncryptSsl(certificate); | 									if (data.meta.cloudflare_use) { | ||||||
|  | 										return internalCertificate.requestLetsEncryptCloudFlareDnsSsl(certificate, data.meta.cloudflare_token); | ||||||
|  | 									} else { | ||||||
|  | 										return internalCertificate.requestLetsEncryptSsl(certificate); | ||||||
|  | 									} | ||||||
| 								}) | 								}) | ||||||
| 								.then(() => { | 								.then(() => { | ||||||
| 									// 5. Remove LE config | 									// 5. Remove LE config | ||||||
| @@ -748,6 +752,40 @@ const internalCertificate = { | |||||||
| 			}); | 			}); | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param   {Object}  certificate   the certificate row | ||||||
|  | 	 * @param	{String} apiToken		the cloudflare api token | ||||||
|  | 	 * @returns {Promise} | ||||||
|  | 	 */ | ||||||
|  | 	requestLetsEncryptCloudFlareDnsSsl: (certificate, apiToken) => { | ||||||
|  | 		logger.info('Requesting Let\'sEncrypt certificates via Cloudflare DNS for Cert #' + certificate.id + ': ' + certificate.domain_names.join(', ')); | ||||||
|  |  | ||||||
|  | 		let tokenLoc = '~/cloudflare-token'; | ||||||
|  | 		let storeKey = 'echo "dns_cloudflare_api_token = ' + apiToken + '" > ' + tokenLoc;	 | ||||||
|  |  | ||||||
|  | 		let cmd = certbot_command + ' certonly --non-interactive ' + | ||||||
|  | 			'--cert-name "npm-' + certificate.id + '" ' + | ||||||
|  | 			'--agree-tos ' + | ||||||
|  | 			'--email "' + certificate.meta.letsencrypt_email + '" ' +			 | ||||||
|  | 			'--domains "' + certificate.domain_names.join(',') + '" ' + | ||||||
|  | 			'--dns-cloudflare --dns-cloudflare-credentials ' + tokenLoc + ' ' + | ||||||
|  | 			(le_staging ? '--staging' : ''); | ||||||
|  |  | ||||||
|  | 		if (debug_mode) { | ||||||
|  | 			logger.info('Command:', cmd); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return utils.exec(storeKey).then((result) => { | ||||||
|  | 			utils.exec(cmd).then((result) => { | ||||||
|  | 				utils.exec('rm ' + tokenLoc).then(result => { | ||||||
|  | 					logger.success(result); | ||||||
|  | 					return result; | ||||||
|  | 				});				 | ||||||
|  | 			}); | ||||||
|  | 		}); | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| 	 * @param   {Access}  access | 	 * @param   {Access}  access | ||||||
| 	 * @param   {Object}  data | 	 * @param   {Object}  data | ||||||
|   | |||||||
| @@ -41,6 +41,12 @@ | |||||||
|         }, |         }, | ||||||
|         "letsencrypt_agree": { |         "letsencrypt_agree": { | ||||||
|           "type": "boolean" |           "type": "boolean" | ||||||
|  |         }, | ||||||
|  |         "cloudflare_use": { | ||||||
|  |           "type": "boolean" | ||||||
|  |         }, | ||||||
|  |         "cloudflare_token": { | ||||||
|  |           "type": "string" | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ | |||||||
|                     <div class="col-sm-12 col-md-12"> |                     <div class="col-sm-12 col-md-12"> | ||||||
|                         <div class="form-group"> |                         <div class="form-group"> | ||||||
|                             <label class="custom-switch"> |                             <label class="custom-switch"> | ||||||
|                                 <input type="checkbox" class="custom-switch-input" name="use_cloudflare" value="1"> |                                 <input type="checkbox" class="custom-switch-input" name="meta[cloudflare_use]" value="1"> | ||||||
|                                 <span class="custom-switch-indicator"></span> |                                 <span class="custom-switch-indicator"></span> | ||||||
|                                 <span class="custom-switch-description"><%= i18n('ssl', 'use-cloudflare') %></span> |                                 <span class="custom-switch-description"><%= i18n('ssl', 'use-cloudflare') %></span> | ||||||
|                             </label> |                             </label> | ||||||
| @@ -34,7 +34,7 @@ | |||||||
|                     <div class="col-sm-12 col-md-12 cloudflare"> |                     <div class="col-sm-12 col-md-12 cloudflare"> | ||||||
|                         <div class="form-group"> |                         <div class="form-group"> | ||||||
|                             <label class="form-label">CloudFlare DNS API Token  <span class="form-required">*</span></label> |                             <label class="form-label">CloudFlare DNS API Token  <span class="form-required">*</span></label> | ||||||
|                             <input type="text" name="cloudflare_dns_api_token" class="form-control" id="input-domains" required>                             |                             <input type="text" name="meta[cloudflare_token]" class="form-control" id="cloudflare_token" required> | ||||||
|                         </div> |                         </div> | ||||||
|                     </div> |                     </div> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ module.exports = Mn.View.extend({ | |||||||
|         other_certificate:              '#other_certificate', |         other_certificate:              '#other_certificate', | ||||||
|         other_certificate_key:          '#other_certificate_key', |         other_certificate_key:          '#other_certificate_key', | ||||||
|         other_intermediate_certificate: '#other_intermediate_certificate', |         other_intermediate_certificate: '#other_intermediate_certificate', | ||||||
|         cloudflare_switch:              'input[name="use_cloudflare"]', |         cloudflare_switch:              'input[name="meta[cloudflare_use]"]', | ||||||
|         cloudflare:                     '.cloudflare' |         cloudflare:                     '.cloudflare' | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
| @@ -50,6 +50,9 @@ module.exports = Mn.View.extend({ | |||||||
|             if (typeof data.meta !== 'undefined' && typeof data.meta.letsencrypt_agree !== 'undefined') { |             if (typeof data.meta !== 'undefined' && typeof data.meta.letsencrypt_agree !== 'undefined') { | ||||||
|                 data.meta.letsencrypt_agree = !!data.meta.letsencrypt_agree; |                 data.meta.letsencrypt_agree = !!data.meta.letsencrypt_agree; | ||||||
|             } |             } | ||||||
|  |             if (typeof data.meta !== 'undefined' && typeof data.meta.cloudflare_use !== 'undefined') { | ||||||
|  |                 data.meta.cloudflare_use = !!data.meta.cloudflare_use; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             if (typeof data.domain_names === 'string' && data.domain_names) { |             if (typeof data.domain_names === 'string' && data.domain_names) { | ||||||
|                 data.domain_names = data.domain_names.split(','); |                 data.domain_names = data.domain_names.split(','); | ||||||
| @@ -140,6 +143,10 @@ module.exports = Mn.View.extend({ | |||||||
|  |  | ||||||
|         getLetsencryptAgree: function () { |         getLetsencryptAgree: function () { | ||||||
|             return typeof this.meta.letsencrypt_agree !== 'undefined' ? this.meta.letsencrypt_agree : false; |             return typeof this.meta.letsencrypt_agree !== 'undefined' ? this.meta.letsencrypt_agree : false; | ||||||
|  |         }, | ||||||
|  |  | ||||||
|  |         getCloudflareUse: function () { | ||||||
|  |             return typeof this.meta.cloudflare_use !== 'undefined' ? this.meta.cloudflare_use : false; | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user