|  | @@ -788,7 +788,7 @@ const internalCertificate = {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		logger.info(`Requesting Let'sEncrypt certificates via ${dns_plugin.display_name} for Cert #${certificate.id}: ${certificate.domain_names.join(', ')}`);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		const credentials_loc = '/etc/letsencrypt/credentials-' + certificate.id;
 | 
	
		
			
				|  |  | +		const credentials_loc = '/etc/letsencrypt/credentials/credentials-' + certificate.id;
 | 
	
		
			
				|  |  |  		const credentials_cmd = 'echo \'' + certificate.meta.dns_provider_credentials.replace('\'', '\\\'') + '\' > \'' + credentials_loc + '\' && chmod 600 \'' + credentials_loc + '\'';
 | 
	
		
			
				|  |  |  		const prepare_cmd     = 'pip3 install ' + dns_plugin.package_name + '==' + dns_plugin.package_version;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -818,11 +818,9 @@ const internalCertificate = {
 | 
	
		
			
				|  |  |  		if (certificate.meta.dns_provider === 'route53') {
 | 
	
		
			
				|  |  |  			main_cmd = 'AWS_CONFIG_FILE=\'' + credentials_loc + '\' ' + main_cmd;
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  | -		
 | 
	
		
			
				|  |  | -		const teardown_cmd = `rm '${credentials_loc}'`;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		if (debug_mode) {
 | 
	
		
			
				|  |  | -			logger.info('Command:', `${credentials_cmd} && ${prepare_cmd} && ${main_cmd} && ${teardown_cmd}`);
 | 
	
		
			
				|  |  | +			logger.info('Command:', `${credentials_cmd} && ${prepare_cmd} && ${main_cmd}`);
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		return utils.exec(credentials_cmd)
 | 
	
	
		
			
				|  | @@ -831,11 +829,15 @@ const internalCertificate = {
 | 
	
		
			
				|  |  |  					.then(() => {
 | 
	
		
			
				|  |  |  						return utils.exec(main_cmd)
 | 
	
		
			
				|  |  |  							.then(async (result) => {
 | 
	
		
			
				|  |  | -								await utils.exec(teardown_cmd);
 | 
	
		
			
				|  |  |  								logger.info(result);
 | 
	
		
			
				|  |  |  								return result;
 | 
	
		
			
				|  |  |  							});
 | 
	
		
			
				|  |  |  					});
 | 
	
		
			
				|  |  | +			}).catch(async (err) => {
 | 
	
		
			
				|  |  | +				// Don't fail if file does not exist
 | 
	
		
			
				|  |  | +				const delete_credentials_cmd = `rm -f '${credentials_loc}' || true`;
 | 
	
		
			
				|  |  | +				await utils.exec(delete_credentials_cmd);
 | 
	
		
			
				|  |  | +				throw err;
 | 
	
		
			
				|  |  |  			});
 | 
	
		
			
				|  |  |  	},
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -922,10 +924,6 @@ const internalCertificate = {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		logger.info(`Renewing Let'sEncrypt certificates via ${dns_plugin.display_name} for Cert #${certificate.id}: ${certificate.domain_names.join(', ')}`);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		const credentials_loc = '/etc/letsencrypt/credentials-' + certificate.id;
 | 
	
		
			
				|  |  | -		const credentials_cmd = 'echo \'' + certificate.meta.dns_provider_credentials.replace('\'', '\\\'') + '\' > \'' + credentials_loc + '\' && chmod 600 \'' + credentials_loc + '\'';
 | 
	
		
			
				|  |  | -		const prepare_cmd     = 'pip3 install ' + dns_plugin.package_name + '==' + dns_plugin.package_version;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  		let main_cmd = 
 | 
	
		
			
				|  |  |  			certbot_command + ' renew --non-interactive ' +
 | 
	
		
			
				|  |  |  			'--cert-name "npm-' + certificate.id + '" ' +
 | 
	
	
		
			
				|  | @@ -937,23 +935,14 @@ const internalCertificate = {
 | 
	
		
			
				|  |  |  			main_cmd = 'AWS_CONFIG_FILE=\'' + credentials_loc + '\' ' + main_cmd;
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		const teardown_cmd = `rm '${credentials_loc}'`;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  		if (debug_mode) {
 | 
	
		
			
				|  |  | -			logger.info('Command:', `${credentials_cmd} && ${prepare_cmd} && ${main_cmd} && ${teardown_cmd}`);
 | 
	
		
			
				|  |  | +			logger.info('Command:', main_cmd);
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		return utils.exec(credentials_cmd)
 | 
	
		
			
				|  |  | -			.then(() => {
 | 
	
		
			
				|  |  | -				return utils.exec(prepare_cmd)
 | 
	
		
			
				|  |  | -					.then(() => {
 | 
	
		
			
				|  |  | -						return utils.exec(main_cmd)
 | 
	
		
			
				|  |  | -							.then(async (result) => {
 | 
	
		
			
				|  |  | -								await utils.exec(teardown_cmd);
 | 
	
		
			
				|  |  | -								logger.info(result);
 | 
	
		
			
				|  |  | -								return result;
 | 
	
		
			
				|  |  | -							});
 | 
	
		
			
				|  |  | -					});
 | 
	
		
			
				|  |  | +		return utils.exec(main_cmd)
 | 
	
		
			
				|  |  | +			.then(async (result) => {
 | 
	
		
			
				|  |  | +				logger.info(result);
 | 
	
		
			
				|  |  | +				return result;
 | 
	
		
			
				|  |  |  			});
 | 
	
		
			
				|  |  |  	},
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -965,20 +954,21 @@ const internalCertificate = {
 | 
	
		
			
				|  |  |  	revokeLetsEncryptSsl: (certificate, throw_errors) => {
 | 
	
		
			
				|  |  |  		logger.info('Revoking Let\'sEncrypt certificates for Cert #' + certificate.id + ': ' + certificate.domain_names.join(', '));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		let cmd = certbot_command + ' revoke --non-interactive ' +
 | 
	
		
			
				|  |  | +		const main_cmd = certbot_command + ' revoke --non-interactive ' +
 | 
	
		
			
				|  |  |  			'--cert-path "/etc/letsencrypt/live/npm-' + certificate.id + '/fullchain.pem" ' +
 | 
	
		
			
				|  |  |  			'--delete-after-revoke ' +
 | 
	
		
			
				|  |  |  			(le_staging ? '--staging' : '');
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +		// Don't fail command if file does not exist
 | 
	
		
			
				|  |  | +		const delete_credentials_cmd = `rm -f '/etc/letsencrypt/credentials/credentials-${certificate.id}' || true`;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  		if (debug_mode) {
 | 
	
		
			
				|  |  | -			logger.info('Command:', cmd);
 | 
	
		
			
				|  |  | +			logger.info('Command:', main_cmd + '; ' + delete_credentials_cmd);
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		return utils.exec(cmd)
 | 
	
		
			
				|  |  | -			.then((result) => {
 | 
	
		
			
				|  |  | -				if (debug_mode) {
 | 
	
		
			
				|  |  | -					logger.info('Command:', cmd);
 | 
	
		
			
				|  |  | -				}
 | 
	
		
			
				|  |  | +		return utils.exec(main_cmd)
 | 
	
		
			
				|  |  | +			.then(async (result) => {
 | 
	
		
			
				|  |  | +				await utils.exec(delete_credentials_cmd);
 | 
	
		
			
				|  |  |  				logger.info(result);
 | 
	
		
			
				|  |  |  				return result;
 | 
	
		
			
				|  |  |  			})
 |