mirror of
https://github.com/jc21/nginx-proxy-manager.git
synced 2024-08-30 18:22:48 +00:00
request via cloudflare dns working
This commit is contained in:
parent
b9a95840e0
commit
ff1770204c
@ -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;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user