From 4de1c69b6a8e428b493306f129b4c9d1d5e9550b Mon Sep 17 00:00:00 2001 From: Jarmo Isotalo Date: Fri, 2 Dec 2016 15:27:13 +0200 Subject: [PATCH] Improve error handling when issuing cert fails (#154) Fix `now certs ls` error when showing expiration date Improve logging for when alias creation fails --- bin/now-certs.js | 6 +++++- lib/alias.js | 6 +++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/bin/now-certs.js b/bin/now-certs.js index 4a7e69c..8571ab7 100755 --- a/bin/now-certs.js +++ b/bin/now-certs.js @@ -108,7 +108,7 @@ if (argv.help || !subcommand) { function formatExpirationDate(date) { const diff = date - Date.now() - return diff < 0 ? chalk.gray(ms(new Date(-diff)) + ' ago') : chalk.gray('in ' + ms(new Date(diff))) + return diff < 0 ? chalk.gray(ms(-diff) + ' ago') : chalk.gray('in ' + ms(diff)) } async function run(token) { @@ -172,6 +172,10 @@ async function run(token) { } else { // Issue a standard certificate cert = await certs.create(cn) } + if (!cert) { + // Cert is undefined and "Cert is alread issued" has been printed to stdout + return exit(1) + } const elapsed = ms(new Date() - start) console.log(`${chalk.cyan('> Success!')} Certificate entry ${chalk.bold(cn)} ${chalk.gray(`(${cert.uid})`)} created ${chalk.gray(`[${elapsed}]`)}`) } else if (subcommand === 'renew') { diff --git a/lib/alias.js b/lib/alias.js index fd3236f..66f72fb 100644 --- a/lib/alias.js +++ b/lib/alias.js @@ -196,7 +196,11 @@ export default class Alias extends Now { this._agent.close() this._agent._initAgent() - const {created, uid} = await this.createAlias(depl, alias) + const newAlias = await this.createAlias(depl, alias) + if (!newAlias || !newAlias.created) { + throw new Error(`Unexpected error occurred while setting up alias: ${JSON.stringify(newAlias)}`) + } + const {created, uid} = newAlias if (created) { console.log(`${chalk.cyan('> Success!')} Alias created ${chalk.dim(`(${uid})`)}: ${chalk.bold(chalk.underline(`https://${alias}`))} now points to ${chalk.bold(`https://${depl.url}`)} ${chalk.dim(`(${depl.uid})`)}`) } else {