Comparing version 1.0.0-beta.7 to 1.0.0-beta.8
@@ -8,4 +8,4 @@ import { Options } from './index'; | ||
export declare function fetchCertificateAuthorityCredentials(): Promise<{ | ||
rootKeyPath: string; | ||
rootCertPath: string; | ||
decryptedCAKeyPath: string; | ||
decryptedCACertPath: string; | ||
}>; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const tslib_1 = require("tslib"); | ||
const crypto = require("crypto"); | ||
const fs_1 = require("fs"); | ||
@@ -8,3 +9,3 @@ const createDebug = require("debug"); | ||
const tmp_1 = require("tmp"); | ||
const keychain = require("keytar"); | ||
const prompt = require("prompt"); | ||
const constants_1 = require("./constants"); | ||
@@ -33,3 +34,3 @@ const macos_1 = require("./platforms/macos"); | ||
debug('Saving certificate authority credentials to system keychain'); | ||
addCertificateAuthorityToSystemKeychain(rootKeyPath, rootCertPath); | ||
saveCertificateAuthorityCredentials(rootKeyPath, rootCertPath); | ||
debug(`Adding the root certificate authority to trust stores`); | ||
@@ -45,7 +46,2 @@ if (constants_1.isMac) { | ||
} | ||
debug('Certificate authority added to trust stores, removing temporary files'); | ||
fs_1.unlinkSync(rootKeyPath); | ||
fs_1.unlinkSync(rootCertPath); | ||
debug('Adding flag indicating root certificate authority install'); | ||
fs_1.writeFileSync(constants_1.rootCAInstalledFlagFilePath, ''); | ||
}); | ||
@@ -75,13 +71,14 @@ } | ||
debug(`Fetching devcert's certificate authority credentials from the system keychain`); | ||
let rootKeyPath = tmp_1.fileSync().name; | ||
let rootCertPath = tmp_1.fileSync().name; | ||
let key = yield keychain.getPassword('devcert', 'certificate-authority-key'); | ||
let cert = yield keychain.getPassword('devcert', 'certificate-authority-certificate'); | ||
fs_1.writeFileSync(rootKeyPath, key); | ||
fs_1.writeFileSync(rootCertPath, cert); | ||
return { rootKeyPath, rootCertPath }; | ||
let decryptedCAKeyPath = tmp_1.fileSync().name; | ||
let decryptedCACertPath = tmp_1.fileSync().name; | ||
let encryptedCAKey = fs_1.readFileSync(constants_1.rootCAKeyPath, 'utf-8'); | ||
let encryptedCACert = fs_1.readFileSync(constants_1.rootCACertPath, 'utf-8'); | ||
let encryptionKey = yield getPasswordFromUser(); | ||
fs_1.writeFileSync(decryptedCAKeyPath, decrypt(encryptedCAKey, encryptionKey)); | ||
fs_1.writeFileSync(decryptedCACertPath, decrypt(encryptedCACert, encryptionKey)); | ||
return { decryptedCAKeyPath, decryptedCACertPath }; | ||
}); | ||
} | ||
exports.fetchCertificateAuthorityCredentials = fetchCertificateAuthorityCredentials; | ||
function addCertificateAuthorityToSystemKeychain(keypath, certpath) { | ||
function saveCertificateAuthorityCredentials(keypath, certpath) { | ||
return tslib_1.__awaiter(this, void 0, void 0, function* () { | ||
@@ -91,6 +88,30 @@ debug(`Adding devcert's certificate authority credentials to the system keychain`); | ||
let cert = fs_1.readFileSync(certpath, 'utf-8'); | ||
yield keychain.setPassword('devcert', 'certificate-authority-key', key); | ||
yield keychain.setPassword('devcert', 'certificate-authority-certificate', cert); | ||
let encryptionKey = yield getPasswordFromUser(); | ||
fs_1.writeFileSync(constants_1.rootCAKeyPath, encrypt(key, encryptionKey)); | ||
fs_1.writeFileSync(constants_1.rootCACertPath, encrypt(cert, encryptionKey)); | ||
}); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"certificate-authority.js","sourceRoot":"/Users/daw/oss/devcert/","sources":["certificate-authority.ts"],"names":[],"mappings":";;;AAAA,2BAA4F;AAC5F,qCAAqC;AACrC,2BAA2B;AAC3B,6BAAsC;AACtC,mCAAmC;AAEnC,2CAOqB;AACrB,6CAAoD;AACpD,6CAAsD;AACtD,iDAA0D;AAC1D,mCAAkC;AAClC,iDAA6C;AAG7C,MAAM,KAAK,GAAG,WAAW,CAAC,+BAA+B,CAAC,CAAC;AAE3D;;;GAGG;AACH,qCAA0D,UAAmB,EAAE;;QAC7E,KAAK,CAAC,yCAAyC,CAAC,CAAC;QACjD,IAAI,WAAW,GAAG,cAAG,EAAE,CAAC,IAAI,CAAC;QAC7B,IAAI,YAAY,GAAG,cAAG,EAAE,CAAC,IAAI,CAAC;QAE9B,KAAK,CAAC,gFAAgF,CAAC,CAAC;QACxF,wBAAwB,EAAE,CAAC;QAE3B,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAClC,0BAAW,CAAC,WAAW,CAAC,CAAC;QAEzB,KAAK,CAAC,6BAA6B,CAAC,CAAC;QACrC,eAAO,CAAC,eAAgB,2BAAgB,SAAU,WAAY,SAAU,YAAa,8DAA8D,CAAC,CAAC;QAErJ,KAAK,CAAC,6DAA6D,CAAC,CAAC;QACrE,uCAAuC,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QAEnE,KAAK,CAAC,uDAAuD,CAAC,CAAC;QAC/D,EAAE,CAAC,CAAC,iBAAK,CAAC,CAAC,CAAC;YACV,MAAM,eAAmB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QACnD,CAAC;QAAC,IAAI,CAAC,EAAE,CAAC,CAAC,mBAAO,CAAC,CAAC,CAAC;YACnB,MAAM,eAAqB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QACrD,CAAC;QAAC,IAAI,CAAC,CAAC;YACN,MAAM,iBAAuB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QACvD,CAAC;QAED,KAAK,CAAC,uEAAuE,CAAC,CAAC;QAC/E,eAAE,CAAC,WAAW,CAAC,CAAC;QAChB,eAAE,CAAC,YAAY,CAAC,CAAC;QAEjB,KAAK,CAAC,2DAA2D,CAAC,CAAC;QACnE,kBAAS,CAAC,uCAA2B,EAAE,EAAE,CAAC,CAAC;IAC7C,CAAC;CAAA;AAhCD,8CAgCC;AAED;;;;GAIG;AACH;IACE,IAAI,YAAY,GAAG,iBAAQ,CAAC,+BAAmB,EAAE,OAAO,CAAC,CAAC;IAC1D,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,eAAe,EAAE,sBAAU,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;IACrG,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,aAAa,EAAE,sBAAU,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;IAChG,YAAY,GAAG,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACtC,kBAAS,CAAC,2BAAe,EAAE,YAAY,CAAC,CAAC;IACzC,kBAAS,CAAC,sBAAU,CAAC,WAAW,CAAC,EAAE,EAAE,CAAC,CAAC;IACvC,kBAAS,CAAC,sBAAU,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAC;IACtC,+FAA+F;IAC/F,6FAA6F;IAC7F,qDAAqD;IACrD,kBAAS,CAAC,sBAAU,CAAC,oBAAoB,CAAC,EAAE,GAAG,CAAC,CAAC;AACnD,CAAC;AAED;;QACE,KAAK,CAAC,+EAA+E,CAAC,CAAC;QACvF,IAAI,WAAW,GAAG,cAAG,EAAE,CAAC,IAAI,CAAC;QAC7B,IAAI,YAAY,GAAG,cAAG,EAAE,CAAC,IAAI,CAAC;QAC9B,IAAI,GAAG,GAAG,MAAM,QAAQ,CAAC,WAAW,CAAC,SAAS,EAAE,2BAA2B,CAAC,CAAC;QAC7E,IAAI,IAAI,GAAG,MAAM,QAAQ,CAAC,WAAW,CAAC,SAAS,EAAE,mCAAmC,CAAC,CAAC;QACtF,kBAAS,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;QAC5B,kBAAS,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAC9B,MAAM,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,CAAC;IACvC,CAAC;CAAA;AATD,oFASC;AAED,iDAAuD,OAAe,EAAE,QAAgB;;QACtF,KAAK,CAAC,2EAA2E,CAAC,CAAC;QACnF,IAAI,GAAG,GAAG,iBAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACrC,IAAI,IAAI,GAAG,iBAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACvC,MAAM,QAAQ,CAAC,WAAW,CAAC,SAAS,EAAE,2BAA2B,EAAE,GAAG,CAAC,CAAC;QACxE,MAAM,QAAQ,CAAC,WAAW,CAAC,SAAS,EAAE,mCAAmC,EAAE,IAAI,CAAC,CAAC;IACnF,CAAC;CAAA","sourcesContent":["import { unlinkSync as rm, readFileSync as readFile, writeFileSync as writeFile } from 'fs';\nimport * as createDebug from 'debug';\nimport * as eol from 'eol';\nimport { fileSync as tmp } from 'tmp';\nimport * as keychain from 'keytar';\n\nimport {\n  isMac,\n  isLinux,\n  configPath,\n  opensslConfPath,\n  opensslConfTemplate,\n  rootCAInstalledFlagFilePath\n} from './constants';\nimport addToMacTrustStores from './platforms/macos';\nimport addToLinuxTrustStores from './platforms/linux';\nimport addToWindowsTrustStores from './platforms/windows';\nimport { openssl } from './utils';\nimport { generateKey } from './certificates';\nimport { Options } from './index';\n\nconst debug = createDebug('devcert:certificate-authority');\n\n/**\n * Install the once-per-machine trusted root CA. We'll use this CA to sign\n * per-app certs.\n */\nexport default async function installCertificateAuthority(options: Options = {}): Promise<void> {\n  debug(`Generating a root certificate authority`);\n  let rootKeyPath = tmp().name;\n  let rootCertPath = tmp().name;\n\n  debug(`Generating the OpenSSL configuration needed to setup the certificate authority`);\n  generateOpenSSLConfFiles();\n\n  debug(`Generating a private key`);\n  generateKey(rootKeyPath);\n\n  debug(`Generating a CA certificate`);\n  openssl(`req -config ${ opensslConfPath } -key ${ rootKeyPath } -out ${ rootCertPath } -new -subj \"/CN=devcert\" -x509 -days 7000 -extensions v3_ca`);\n\n  debug('Saving certificate authority credentials to system keychain');\n  addCertificateAuthorityToSystemKeychain(rootKeyPath, rootCertPath);\n\n  debug(`Adding the root certificate authority to trust stores`);\n  if (isMac) {\n    await addToMacTrustStores(rootCertPath, options);\n  } else if (isLinux) {\n    await addToLinuxTrustStores(rootCertPath, options);\n  } else {\n    await addToWindowsTrustStores(rootCertPath, options);\n  }\n\n  debug('Certificate authority added to trust stores, removing temporary files');\n  rm(rootKeyPath);\n  rm(rootCertPath);\n\n  debug('Adding flag indicating root certificate authority install');\n  writeFile(rootCAInstalledFlagFilePath, '');\n}\n\n/**\n * Copy our OpenSSL conf template to the local devcert config folder, and\n * update the paths inside that config file to be OS specific. Also initializes\n * the files OpenSSL needs to sign certificates as a certificate authority\n */\nfunction generateOpenSSLConfFiles() {\n  let confTemplate = readFile(opensslConfTemplate, 'utf-8');\n  confTemplate = confTemplate.replace(/DATABASE_PATH/, configPath('index.txt').replace(/\\\\/g, '\\\\\\\\'));\n  confTemplate = confTemplate.replace(/SERIAL_PATH/, configPath('serial').replace(/\\\\/g, '\\\\\\\\'));\n  confTemplate = eol.auto(confTemplate);\n  writeFile(opensslConfPath, confTemplate);\n  writeFile(configPath('index.txt'), '');\n  writeFile(configPath('serial'), '01');\n  // This version number lets us write code in the future that intelligently upgrades an existing\n  // devcert installation. This \"ca-version\" is independent of the devcert package version, and\n  // tracks changes to the root certificate setup only.\n  writeFile(configPath('devcert-ca-version'), '1');\n}\n\nexport async function fetchCertificateAuthorityCredentials() {\n  debug(`Fetching devcert's certificate authority credentials from the system keychain`);\n  let rootKeyPath = tmp().name;\n  let rootCertPath = tmp().name;\n  let key = await keychain.getPassword('devcert', 'certificate-authority-key');\n  let cert = await keychain.getPassword('devcert', 'certificate-authority-certificate');\n  writeFile(rootKeyPath, key);\n  writeFile(rootCertPath, cert);\n  return { rootKeyPath, rootCertPath };\n}\n\nasync function addCertificateAuthorityToSystemKeychain(keypath: string, certpath: string) {\n  debug(`Adding devcert's certificate authority credentials to the system keychain`);\n  let key = readFile(keypath, 'utf-8');\n  let cert = readFile(certpath, 'utf-8');\n  await keychain.setPassword('devcert', 'certificate-authority-key', key);\n  await keychain.setPassword('devcert', 'certificate-authority-certificate', cert);\n}"]} | ||
function getPasswordFromUser() { | ||
return new Promise((resolve, reject) => { | ||
prompt.start(); | ||
prompt.get({ | ||
properties: { | ||
password: { | ||
description: 'Password:', | ||
hidden: true | ||
} | ||
} | ||
}, (err, result) => { | ||
err ? reject(err) : resolve(result); | ||
}); | ||
}); | ||
} | ||
function encrypt(text, key) { | ||
let cipher = crypto.createCipher('aes256', key); | ||
return cipher.update(text, 'utf8', 'hex') + cipher.final('hex'); | ||
} | ||
function decrypt(encrypted, key) { | ||
let decipher = crypto.createDecipher('aes256', key); | ||
return decipher.update(encrypted, 'hex', 'utf8') + decipher.final('utf8'); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"certificate-authority.js","sourceRoot":"/Users/daw/oss/devcert/","sources":["certificate-authority.ts"],"names":[],"mappings":"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","sourcesContent":["import * as crypto from 'crypto';\nimport { readFileSync as readFile, writeFileSync as writeFile } from 'fs';\nimport * as createDebug from 'debug';\nimport * as eol from 'eol';\nimport { fileSync as tmp } from 'tmp';\nimport * as prompt from 'prompt';\n\nimport {\n  isMac,\n  isLinux,\n  configPath,\n  opensslConfPath,\n  opensslConfTemplate,\n  rootCAKeyPath,\n  rootCACertPath,\n} from './constants';\nimport addToMacTrustStores from './platforms/macos';\nimport addToLinuxTrustStores from './platforms/linux';\nimport addToWindowsTrustStores from './platforms/windows';\nimport { openssl } from './utils';\nimport { generateKey } from './certificates';\nimport { Options } from './index';\n\nconst debug = createDebug('devcert:certificate-authority');\n\n/**\n * Install the once-per-machine trusted root CA. We'll use this CA to sign\n * per-app certs.\n */\nexport default async function installCertificateAuthority(options: Options = {}): Promise<void> {\n  debug(`Generating a root certificate authority`);\n  let rootKeyPath = tmp().name;\n  let rootCertPath = tmp().name;\n\n  debug(`Generating the OpenSSL configuration needed to setup the certificate authority`);\n  generateOpenSSLConfFiles();\n\n  debug(`Generating a private key`);\n  generateKey(rootKeyPath);\n\n  debug(`Generating a CA certificate`);\n  openssl(`req -config ${ opensslConfPath } -key ${ rootKeyPath } -out ${ rootCertPath } -new -subj \"/CN=devcert\" -x509 -days 7000 -extensions v3_ca`);\n\n  debug('Saving certificate authority credentials to system keychain');\n  saveCertificateAuthorityCredentials(rootKeyPath, rootCertPath);\n\n  debug(`Adding the root certificate authority to trust stores`);\n  if (isMac) {\n    await addToMacTrustStores(rootCertPath, options);\n  } else if (isLinux) {\n    await addToLinuxTrustStores(rootCertPath, options);\n  } else {\n    await addToWindowsTrustStores(rootCertPath, options);\n  }\n\n}\n\n/**\n * Copy our OpenSSL conf template to the local devcert config folder, and\n * update the paths inside that config file to be OS specific. Also initializes\n * the files OpenSSL needs to sign certificates as a certificate authority\n */\nfunction generateOpenSSLConfFiles() {\n  let confTemplate = readFile(opensslConfTemplate, 'utf-8');\n  confTemplate = confTemplate.replace(/DATABASE_PATH/, configPath('index.txt').replace(/\\\\/g, '\\\\\\\\'));\n  confTemplate = confTemplate.replace(/SERIAL_PATH/, configPath('serial').replace(/\\\\/g, '\\\\\\\\'));\n  confTemplate = eol.auto(confTemplate);\n  writeFile(opensslConfPath, confTemplate);\n  writeFile(configPath('index.txt'), '');\n  writeFile(configPath('serial'), '01');\n  // This version number lets us write code in the future that intelligently upgrades an existing\n  // devcert installation. This \"ca-version\" is independent of the devcert package version, and\n  // tracks changes to the root certificate setup only.\n  writeFile(configPath('devcert-ca-version'), '1');\n}\n\nexport async function fetchCertificateAuthorityCredentials() {\n  debug(`Fetching devcert's certificate authority credentials from the system keychain`);\n  let decryptedCAKeyPath = tmp().name;\n  let decryptedCACertPath = tmp().name;\n  let encryptedCAKey = readFile(rootCAKeyPath, 'utf-8');\n  let encryptedCACert = readFile(rootCACertPath, 'utf-8');\n  let encryptionKey = await getPasswordFromUser();\n  writeFile(decryptedCAKeyPath , decrypt(encryptedCAKey, encryptionKey));\n  writeFile(decryptedCACertPath , decrypt(encryptedCACert, encryptionKey));\n  return { decryptedCAKeyPath , decryptedCACertPath  };\n}\n\nasync function saveCertificateAuthorityCredentials(keypath: string, certpath: string) {\n  debug(`Adding devcert's certificate authority credentials to the system keychain`);\n  let key = readFile(keypath, 'utf-8');\n  let cert = readFile(certpath, 'utf-8');\n  let encryptionKey = await getPasswordFromUser();\n  writeFile(rootCAKeyPath, encrypt(key, encryptionKey));\n  writeFile(rootCACertPath, encrypt(cert, encryptionKey));\n}\n\nfunction getPasswordFromUser(): Promise<string> {\n  return new Promise((resolve, reject) => {\n    prompt.start();\n    prompt.get({\n      properties: {\n        password: {\n          description: 'Password:',\n          hidden: true\n        }\n      }\n    }, (err: Error, result: string) => {\n      err ? reject(err) : resolve(result);\n    });\n  });\n}\n\nfunction encrypt(text: string, key: string) {\n  let cipher = crypto.createCipher('aes256', key);\n  return cipher.update(text, 'utf8', 'hex') + cipher.final('hex');\n}\n\nfunction decrypt(encrypted: string, key: string) {\n  let decipher = crypto.createDecipher('aes256', key);\n  return decipher.update(encrypted, 'hex', 'utf8') + decipher.final('utf8');\n}"]} |
@@ -30,6 +30,6 @@ "use strict"; | ||
let certPath = constants_1.pathForDomain(`${domain}.crt`); | ||
let { rootKeyPath, rootCertPath } = yield certificate_authority_1.fetchCertificateAuthorityCredentials(); | ||
utils_1.openssl(`ca -config ${constants_1.opensslConfPath} -in ${csrFile} -out ${path.basename(certPath)} -outdir ${path.dirname(certPath)} -keyfile ${rootKeyPath} -cert ${rootCertPath} -notext -md sha256 -days 7000 -batch -extensions server_cert`); | ||
fs_1.unlinkSync(rootKeyPath); | ||
fs_1.unlinkSync(rootCertPath); | ||
let { decryptedCAKeyPath, decryptedCACertPath } = yield certificate_authority_1.fetchCertificateAuthorityCredentials(); | ||
utils_1.openssl(`ca -config ${constants_1.opensslConfPath} -in ${csrFile} -out ${path.basename(certPath)} -outdir ${path.dirname(certPath)} -keyfile ${decryptedCAKeyPath} -cert ${decryptedCACertPath} -notext -md sha256 -days 7000 -batch -extensions server_cert`); | ||
fs_1.unlinkSync(decryptedCAKeyPath); | ||
fs_1.unlinkSync(decryptedCACertPath); | ||
}); | ||
@@ -45,2 +45,2 @@ } | ||
exports.generateKey = generateKey; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VydGlmaWNhdGVzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjZXJ0aWZpY2F0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkJBQTZCO0FBQzdCLHFDQUFxQztBQUNyQyxtQ0FBd0M7QUFDeEMsMkJBQTBEO0FBQzFELDJDQUE2RDtBQUM3RCxtQ0FBa0M7QUFDbEMsbUVBQStFO0FBRS9FLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBRWxEOzs7Ozs7R0FNRztBQUNILG1DQUF3RCxNQUFjOztRQUNwRSxhQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTlCLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLE9BQU8sR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3ZELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVyQixLQUFLLENBQUMsOENBQStDLE1BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxPQUFPLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZELGVBQU8sQ0FBQyxlQUFnQiwyQkFBZ0IsZUFBZ0IsTUFBTyxVQUFXLE9BQVEsU0FBVSxPQUFRLE9BQU8sQ0FBQyxDQUFDO1FBRTdHLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxnREFBZ0QsQ0FBQyxDQUFDO1FBQzlGLElBQUksUUFBUSxHQUFHLHlCQUFhLENBQUMsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ2hELElBQUksRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLEdBQUcsTUFBTSw0REFBb0MsRUFBRSxDQUFDO1FBQ2pGLGVBQU8sQ0FBQyxjQUFlLDJCQUFnQixRQUFTLE9BQVEsU0FBVSxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBRSxZQUFhLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFFLGFBQWMsV0FBWSxVQUFXLFlBQWEsK0RBQStELENBQUMsQ0FBQTtRQUVoUCxlQUFFLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDaEIsZUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ25CLENBQUM7Q0FBQTtBQWxCRCw0Q0FrQkM7QUFFRCwyRkFBMkY7QUFDM0YscUJBQTRCLFFBQWdCO0lBQzFDLEtBQUssQ0FBQyxnQkFBaUIsUUFBUyxFQUFFLENBQUMsQ0FBQztJQUNwQyxlQUFPLENBQUMsZUFBZ0IsUUFBUyxPQUFPLENBQUMsQ0FBQztJQUMxQyxjQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUM7QUFKRCxrQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgKiBhcyBjcmVhdGVEZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgeyB1bmxpbmtTeW5jIGFzIHJtLCBjaG1vZFN5bmMgYXMgY2htb2QgfSBmcm9tICdmcyc7XG5pbXBvcnQgeyBwYXRoRm9yRG9tYWluLCBvcGVuc3NsQ29uZlBhdGggfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBvcGVuc3NsIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBmZXRjaENlcnRpZmljYXRlQXV0aG9yaXR5Q3JlZGVudGlhbHMgfSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQ6Y2VydGlmaWNhdGVzJyk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBkb21haW4gY2VydGlmaWNhdGUgc2lnbmVkIGJ5IHRoZSBkZXZjZXJ0IHJvb3QgQ0EuIERvbWFpblxuICogY2VydGlmaWNhdGVzIGFyZSBjYWNoZWQgaW4gdGhlaXIgb3duIGRpcmVjdG9yaWVzIHVuZGVyXG4gKiBDT05GSUdfUk9PVC9kb21haW5zLzxkb21haW4+LCBhbmQgcmV1c2VkIG9uIHN1YnNlcXVlbnQgcmVxdWVzdHMuIEJlY2F1c2UgdGhlXG4gKiBpbmRpdmlkdWFsIGRvbWFpbiBjZXJ0aWZpY2F0ZXMgYXJlIHNpZ25lZCBieSB0aGUgZGV2Y2VydCByb290IENBICh3aGljaCB3YXNcbiAqIGFkZGVkIHRvIHRoZSBPUy9icm93c2VyIHRydXN0IHN0b3JlcyksIHRoZXkgYXJlIHRydXN0ZWQuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlRG9tYWluQ2VydGlmaWNhdGUoZG9tYWluOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbWtkaXJwKHBhdGhGb3JEb21haW4oZG9tYWluKSk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgcHJpdmF0ZSBrZXkgZm9yICR7IGRvbWFpbiB9YCk7XG4gIGxldCBrZXlQYXRoID0gcGF0aEZvckRvbWFpbihkb21haW4sICdwcml2YXRlLWtleS5rZXknKTtcbiAgZ2VuZXJhdGVLZXkoa2V5UGF0aCk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0IGZvciAkeyBkb21haW4gfWApO1xuICBsZXQgY3NyRmlsZSA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgJHsgZG9tYWluIH0uY3NyYCk7XG4gIG9wZW5zc2woYHJlcSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1zdWJqIFwiL0NOPSR7IGRvbWFpbiB9XCIgLWtleSAkeyBrZXlQYXRoIH0gLW91dCAkeyBjc3JGaWxlIH0gLW5ld2ApO1xuXG4gIGRlYnVnKGBHZW5lcmF0aW5nIGNlcnRpZmljYXRlIGZvciAkeyBkb21haW4gfSBmcm9tIHNpZ25pbmcgcmVxdWVzdCBhbmQgc2lnbmluZyB3aXRoIHJvb3QgQ0FgKTtcbiAgbGV0IGNlcnRQYXRoID0gcGF0aEZvckRvbWFpbihgJHsgZG9tYWluIH0uY3J0YCk7XG4gIGxldCB7IHJvb3RLZXlQYXRoLCByb290Q2VydFBhdGggfSA9IGF3YWl0IGZldGNoQ2VydGlmaWNhdGVBdXRob3JpdHlDcmVkZW50aWFscygpO1xuICBvcGVuc3NsKGBjYSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1pbiAkeyBjc3JGaWxlIH0gLW91dCAkeyBwYXRoLmJhc2VuYW1lKGNlcnRQYXRoKSB9IC1vdXRkaXIgJHsgcGF0aC5kaXJuYW1lKGNlcnRQYXRoKSB9IC1rZXlmaWxlICR7IHJvb3RLZXlQYXRoIH0gLWNlcnQgJHsgcm9vdENlcnRQYXRoIH0gLW5vdGV4dCAtbWQgc2hhMjU2IC1kYXlzIDcwMDAgLWJhdGNoIC1leHRlbnNpb25zIHNlcnZlcl9jZXJ0YClcblxuICBybShyb290S2V5UGF0aCk7XG4gIHJtKHJvb3RDZXJ0UGF0aCk7XG59XG5cbi8vIEdlbmVyYXRlIGEgY3J5cHRvZ3JhcGhpYyBrZXksIHVzZWQgdG8gc2lnbiBjZXJ0aWZpY2F0ZXMgb3IgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0cy5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUtleShmaWxlbmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIGRlYnVnKGBnZW5lcmF0ZUtleTogJHsgZmlsZW5hbWUgfWApO1xuICBvcGVuc3NsKGBnZW5yc2EgLW91dCAkeyBmaWxlbmFtZSB9IDIwNDhgKTtcbiAgY2htb2QoZmlsZW5hbWUsIDQwMCk7XG59Il19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VydGlmaWNhdGVzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjZXJ0aWZpY2F0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkJBQTZCO0FBQzdCLHFDQUFxQztBQUNyQyxtQ0FBd0M7QUFDeEMsMkJBQTBEO0FBQzFELDJDQUE2RDtBQUM3RCxtQ0FBa0M7QUFDbEMsbUVBQStFO0FBRS9FLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBRWxEOzs7Ozs7R0FNRztBQUNILG1DQUF3RCxNQUFjOztRQUNwRSxhQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTlCLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLE9BQU8sR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3ZELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVyQixLQUFLLENBQUMsOENBQStDLE1BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxPQUFPLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZELGVBQU8sQ0FBQyxlQUFnQiwyQkFBZ0IsZUFBZ0IsTUFBTyxVQUFXLE9BQVEsU0FBVSxPQUFRLE9BQU8sQ0FBQyxDQUFDO1FBRTdHLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxnREFBZ0QsQ0FBQyxDQUFDO1FBQzlGLElBQUksUUFBUSxHQUFHLHlCQUFhLENBQUMsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ2hELElBQUksRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxHQUFHLE1BQU0sNERBQW9DLEVBQUUsQ0FBQztRQUMvRixlQUFPLENBQUMsY0FBZSwyQkFBZ0IsUUFBUyxPQUFRLFNBQVUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUUsWUFBYSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBRSxhQUFjLGtCQUFtQixVQUFXLG1CQUFvQiwrREFBK0QsQ0FBQyxDQUFBO1FBRTlQLGVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3ZCLGVBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBQzFCLENBQUM7Q0FBQTtBQWxCRCw0Q0FrQkM7QUFFRCwyRkFBMkY7QUFDM0YscUJBQTRCLFFBQWdCO0lBQzFDLEtBQUssQ0FBQyxnQkFBaUIsUUFBUyxFQUFFLENBQUMsQ0FBQztJQUNwQyxlQUFPLENBQUMsZUFBZ0IsUUFBUyxPQUFPLENBQUMsQ0FBQztJQUMxQyxjQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUM7QUFKRCxrQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgKiBhcyBjcmVhdGVEZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgeyB1bmxpbmtTeW5jIGFzIHJtLCBjaG1vZFN5bmMgYXMgY2htb2QgfSBmcm9tICdmcyc7XG5pbXBvcnQgeyBwYXRoRm9yRG9tYWluLCBvcGVuc3NsQ29uZlBhdGggfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBvcGVuc3NsIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBmZXRjaENlcnRpZmljYXRlQXV0aG9yaXR5Q3JlZGVudGlhbHMgfSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQ6Y2VydGlmaWNhdGVzJyk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBkb21haW4gY2VydGlmaWNhdGUgc2lnbmVkIGJ5IHRoZSBkZXZjZXJ0IHJvb3QgQ0EuIERvbWFpblxuICogY2VydGlmaWNhdGVzIGFyZSBjYWNoZWQgaW4gdGhlaXIgb3duIGRpcmVjdG9yaWVzIHVuZGVyXG4gKiBDT05GSUdfUk9PVC9kb21haW5zLzxkb21haW4+LCBhbmQgcmV1c2VkIG9uIHN1YnNlcXVlbnQgcmVxdWVzdHMuIEJlY2F1c2UgdGhlXG4gKiBpbmRpdmlkdWFsIGRvbWFpbiBjZXJ0aWZpY2F0ZXMgYXJlIHNpZ25lZCBieSB0aGUgZGV2Y2VydCByb290IENBICh3aGljaCB3YXNcbiAqIGFkZGVkIHRvIHRoZSBPUy9icm93c2VyIHRydXN0IHN0b3JlcyksIHRoZXkgYXJlIHRydXN0ZWQuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlRG9tYWluQ2VydGlmaWNhdGUoZG9tYWluOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbWtkaXJwKHBhdGhGb3JEb21haW4oZG9tYWluKSk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgcHJpdmF0ZSBrZXkgZm9yICR7IGRvbWFpbiB9YCk7XG4gIGxldCBrZXlQYXRoID0gcGF0aEZvckRvbWFpbihkb21haW4sICdwcml2YXRlLWtleS5rZXknKTtcbiAgZ2VuZXJhdGVLZXkoa2V5UGF0aCk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0IGZvciAkeyBkb21haW4gfWApO1xuICBsZXQgY3NyRmlsZSA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgJHsgZG9tYWluIH0uY3NyYCk7XG4gIG9wZW5zc2woYHJlcSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1zdWJqIFwiL0NOPSR7IGRvbWFpbiB9XCIgLWtleSAkeyBrZXlQYXRoIH0gLW91dCAkeyBjc3JGaWxlIH0gLW5ld2ApO1xuXG4gIGRlYnVnKGBHZW5lcmF0aW5nIGNlcnRpZmljYXRlIGZvciAkeyBkb21haW4gfSBmcm9tIHNpZ25pbmcgcmVxdWVzdCBhbmQgc2lnbmluZyB3aXRoIHJvb3QgQ0FgKTtcbiAgbGV0IGNlcnRQYXRoID0gcGF0aEZvckRvbWFpbihgJHsgZG9tYWluIH0uY3J0YCk7XG4gIGxldCB7IGRlY3J5cHRlZENBS2V5UGF0aCwgZGVjcnlwdGVkQ0FDZXJ0UGF0aCB9ID0gYXdhaXQgZmV0Y2hDZXJ0aWZpY2F0ZUF1dGhvcml0eUNyZWRlbnRpYWxzKCk7XG4gIG9wZW5zc2woYGNhIC1jb25maWcgJHsgb3BlbnNzbENvbmZQYXRoIH0gLWluICR7IGNzckZpbGUgfSAtb3V0ICR7IHBhdGguYmFzZW5hbWUoY2VydFBhdGgpIH0gLW91dGRpciAkeyBwYXRoLmRpcm5hbWUoY2VydFBhdGgpIH0gLWtleWZpbGUgJHsgZGVjcnlwdGVkQ0FLZXlQYXRoIH0gLWNlcnQgJHsgZGVjcnlwdGVkQ0FDZXJ0UGF0aCB9IC1ub3RleHQgLW1kIHNoYTI1NiAtZGF5cyA3MDAwIC1iYXRjaCAtZXh0ZW5zaW9ucyBzZXJ2ZXJfY2VydGApXG5cbiAgcm0oZGVjcnlwdGVkQ0FLZXlQYXRoKTtcbiAgcm0oZGVjcnlwdGVkQ0FDZXJ0UGF0aCk7XG59XG5cbi8vIEdlbmVyYXRlIGEgY3J5cHRvZ3JhcGhpYyBrZXksIHVzZWQgdG8gc2lnbiBjZXJ0aWZpY2F0ZXMgb3IgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0cy5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUtleShmaWxlbmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIGRlYnVnKGBnZW5lcmF0ZUtleTogJHsgZmlsZW5hbWUgfWApO1xuICBvcGVuc3NsKGBnZW5yc2EgLW91dCAkeyBmaWxlbmFtZSB9IDIwNDhgKTtcbiAgY2htb2QoZmlsZW5hbWUsIDQwMCk7XG59Il19 |
@@ -10,2 +10,4 @@ export declare const isMac: boolean; | ||
export declare const opensslConfPath: string; | ||
export declare const rootCAInstalledFlagFilePath: string; | ||
export declare const rootCADir: string; | ||
export declare const rootCAKeyPath: string; | ||
export declare const rootCACertPath: string; |
@@ -17,5 +17,7 @@ "use strict"; | ||
exports.opensslConfPath = exports.configPath('openssl.conf'); | ||
exports.rootCAInstalledFlagFilePath = exports.configPath('root-ca-installed'); | ||
exports.rootCADir = exports.configPath('certificate-authority'); | ||
exports.rootCAKeyPath = exports.configPath('certificate-authority', 'private-key.key'); | ||
exports.rootCACertPath = exports.configPath('certificate-authority', 'certificate.cert'); | ||
mkdirp_1.sync(exports.configDir); | ||
mkdirp_1.sync(exports.domainsDir); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw2QkFBNkI7QUFDN0IsbUNBQXdDO0FBQ3hDLGlFQUFrRTtBQUVsRSxxQkFBcUI7QUFDUixRQUFBLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQztBQUN0QyxRQUFBLE9BQU8sR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUN2QyxRQUFBLFNBQVMsR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUV0RCxlQUFlO0FBQ0YsUUFBQSxTQUFTLEdBQUcscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDN0MsUUFBQSxVQUFVLEdBQTBDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxpQkFBUyxDQUFDLENBQUM7QUFFcEYsUUFBQSxVQUFVLEdBQUcsa0JBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUNuQyxRQUFBLGFBQWEsR0FBMEQsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGtCQUFVLENBQUMsQ0FBQTtBQUV2RyxRQUFBLG1CQUFtQixHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxjQUFjLENBQUMsQ0FBQztBQUNqRSxRQUFBLGVBQWUsR0FBRyxrQkFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBRTdDLFFBQUEsMkJBQTJCLEdBQUcsa0JBQVUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0FBRTNFLGFBQU0sQ0FBQyxpQkFBUyxDQUFDLENBQUM7QUFDbEIsYUFBTSxDQUFDLGtCQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgYXBwbGljYXRpb25Db25maWdQYXRoID0gcmVxdWlyZSgnYXBwbGljYXRpb24tY29uZmlnLXBhdGgnKTtcblxuLy8gUGxhdGZvcm0gc2hvcnRjdXRzXG5leHBvcnQgY29uc3QgaXNNYWMgPSBwcm9jZXNzLnBsYXRmb3JtID09PSAnZGFyd2luJztcbmV4cG9ydCBjb25zdCBpc0xpbnV4ID0gcHJvY2Vzcy5wbGF0Zm9ybSA9PT0gJ2xpbnV4JztcbmV4cG9ydCBjb25zdCBpc1dpbmRvd3MgPSBwcm9jZXNzLnBsYXRmb3JtID09PSAnd2luMzInO1xuXG4vLyBDb21tb24gcGF0aHNcbmV4cG9ydCBjb25zdCBjb25maWdEaXIgPSBhcHBsaWNhdGlvbkNvbmZpZ1BhdGgoJ2RldmNlcnQnKTtcbmV4cG9ydCBjb25zdCBjb25maWdQYXRoOiAoLi4ucGF0aFNlZ21lbnRzOiBzdHJpbmdbXSkgPT4gc3RyaW5nID0gcGF0aC5qb2luLmJpbmQocGF0aCwgY29uZmlnRGlyKTtcblxuZXhwb3J0IGNvbnN0IGRvbWFpbnNEaXIgPSBjb25maWdQYXRoKCdkb21haW5zJyk7XG5leHBvcnQgY29uc3QgcGF0aEZvckRvbWFpbjogKGRvbWFpbjogc3RyaW5nLCAuLi5wYXRoU2VnbWVudHM6IHN0cmluZ1tdKSA9PiBzdHJpbmcgPSBwYXRoLmpvaW4uYmluZChwYXRoLCBkb21haW5zRGlyKVxuXG5leHBvcnQgY29uc3Qgb3BlbnNzbENvbmZUZW1wbGF0ZSA9IHBhdGguam9pbihfX2Rpcm5hbWUsICcuLicsICdvcGVuc3NsLmNvbmYnKTtcbmV4cG9ydCBjb25zdCBvcGVuc3NsQ29uZlBhdGggPSBjb25maWdQYXRoKCdvcGVuc3NsLmNvbmYnKTtcblxuZXhwb3J0IGNvbnN0IHJvb3RDQUluc3RhbGxlZEZsYWdGaWxlUGF0aCA9IGNvbmZpZ1BhdGgoJ3Jvb3QtY2EtaW5zdGFsbGVkJyk7XG5cbm1rZGlycChjb25maWdEaXIpO1xubWtkaXJwKGRvbWFpbnNEaXIpO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw2QkFBNkI7QUFDN0IsbUNBQXdDO0FBQ3hDLGlFQUFrRTtBQUVsRSxxQkFBcUI7QUFDUixRQUFBLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQztBQUN0QyxRQUFBLE9BQU8sR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUN2QyxRQUFBLFNBQVMsR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUV0RCxlQUFlO0FBQ0YsUUFBQSxTQUFTLEdBQUcscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDN0MsUUFBQSxVQUFVLEdBQTBDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxpQkFBUyxDQUFDLENBQUM7QUFFcEYsUUFBQSxVQUFVLEdBQUcsa0JBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUNuQyxRQUFBLGFBQWEsR0FBMEQsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGtCQUFVLENBQUMsQ0FBQTtBQUV2RyxRQUFBLG1CQUFtQixHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxjQUFjLENBQUMsQ0FBQztBQUNqRSxRQUFBLGVBQWUsR0FBRyxrQkFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBRTdDLFFBQUEsU0FBUyxHQUFHLGtCQUFVLENBQUMsdUJBQXVCLENBQUMsQ0FBQztBQUNoRCxRQUFBLGFBQWEsR0FBRyxrQkFBVSxDQUFDLHVCQUF1QixFQUFFLGlCQUFpQixDQUFDLENBQUM7QUFDdkUsUUFBQSxjQUFjLEdBQUcsa0JBQVUsQ0FBQyx1QkFBdUIsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO0FBRXRGLGFBQU0sQ0FBQyxpQkFBUyxDQUFDLENBQUM7QUFDbEIsYUFBTSxDQUFDLGtCQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgYXBwbGljYXRpb25Db25maWdQYXRoID0gcmVxdWlyZSgnYXBwbGljYXRpb24tY29uZmlnLXBhdGgnKTtcblxuLy8gUGxhdGZvcm0gc2hvcnRjdXRzXG5leHBvcnQgY29uc3QgaXNNYWMgPSBwcm9jZXNzLnBsYXRmb3JtID09PSAnZGFyd2luJztcbmV4cG9ydCBjb25zdCBpc0xpbnV4ID0gcHJvY2Vzcy5wbGF0Zm9ybSA9PT0gJ2xpbnV4JztcbmV4cG9ydCBjb25zdCBpc1dpbmRvd3MgPSBwcm9jZXNzLnBsYXRmb3JtID09PSAnd2luMzInO1xuXG4vLyBDb21tb24gcGF0aHNcbmV4cG9ydCBjb25zdCBjb25maWdEaXIgPSBhcHBsaWNhdGlvbkNvbmZpZ1BhdGgoJ2RldmNlcnQnKTtcbmV4cG9ydCBjb25zdCBjb25maWdQYXRoOiAoLi4ucGF0aFNlZ21lbnRzOiBzdHJpbmdbXSkgPT4gc3RyaW5nID0gcGF0aC5qb2luLmJpbmQocGF0aCwgY29uZmlnRGlyKTtcblxuZXhwb3J0IGNvbnN0IGRvbWFpbnNEaXIgPSBjb25maWdQYXRoKCdkb21haW5zJyk7XG5leHBvcnQgY29uc3QgcGF0aEZvckRvbWFpbjogKGRvbWFpbjogc3RyaW5nLCAuLi5wYXRoU2VnbWVudHM6IHN0cmluZ1tdKSA9PiBzdHJpbmcgPSBwYXRoLmpvaW4uYmluZChwYXRoLCBkb21haW5zRGlyKVxuXG5leHBvcnQgY29uc3Qgb3BlbnNzbENvbmZUZW1wbGF0ZSA9IHBhdGguam9pbihfX2Rpcm5hbWUsICcuLicsICdvcGVuc3NsLmNvbmYnKTtcbmV4cG9ydCBjb25zdCBvcGVuc3NsQ29uZlBhdGggPSBjb25maWdQYXRoKCdvcGVuc3NsLmNvbmYnKTtcblxuZXhwb3J0IGNvbnN0IHJvb3RDQURpciA9IGNvbmZpZ1BhdGgoJ2NlcnRpZmljYXRlLWF1dGhvcml0eScpO1xuZXhwb3J0IGNvbnN0IHJvb3RDQUtleVBhdGggPSBjb25maWdQYXRoKCdjZXJ0aWZpY2F0ZS1hdXRob3JpdHknLCAncHJpdmF0ZS1rZXkua2V5Jyk7XG5leHBvcnQgY29uc3Qgcm9vdENBQ2VydFBhdGggPSBjb25maWdQYXRoKCdjZXJ0aWZpY2F0ZS1hdXRob3JpdHknLCAnY2VydGlmaWNhdGUuY2VydCcpO1xuXG5ta2RpcnAoY29uZmlnRGlyKTtcbm1rZGlycChkb21haW5zRGlyKTtcbiJdfQ== |
@@ -35,3 +35,3 @@ "use strict"; | ||
let domainCertPath = constants_1.pathForDomain(domain, `certificate.crt`); | ||
if (!fs_1.existsSync(constants_1.rootCAInstalledFlagFilePath)) { | ||
if (!fs_1.existsSync(constants_1.rootCAKeyPath)) { | ||
debug('Root CA is not installed yet, so it must be our first run. Installing root CA ...'); | ||
@@ -64,2 +64,2 @@ yield certificate_authority_1.default(options); | ||
exports.removeDomain = removeDomain; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL2Rhdy9vc3MvZGV2Y2VydC8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDJCQUE0RjtBQUM1RixxQ0FBcUM7QUFDckMsbURBQXVEO0FBQ3ZELGlDQUFpQztBQUNqQywyQ0FPcUI7QUFDckIsbUVBQWtFO0FBQ2xFLGlEQUF1RDtBQUV2RCxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUM7QUFPckM7Ozs7Ozs7Ozs7O0dBV0c7QUFDSCx3QkFBcUMsTUFBYyxFQUFFLFVBQW1CLEVBQUU7O1FBQ3hFLEtBQUssQ0FBQyw2QkFBOEIsTUFBTyxnQ0FBaUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBRSwwQkFBMkIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUUsRUFBRSxDQUFDLENBQUM7UUFFL0ssRUFBRSxDQUFDLENBQUMsQ0FBQyxpQkFBSyxJQUFJLENBQUMsbUJBQU8sSUFBSSxDQUFDLHFCQUFTLENBQUMsQ0FBQyxDQUFDO1lBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTZCLE9BQU8sQ0FBQyxRQUFTLEdBQUcsQ0FBQyxDQUFDO1FBQ3JFLENBQUM7UUFFRCxFQUFFLENBQUMsQ0FBQyxDQUFDLHFCQUFhLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzlCLE1BQU0sSUFBSSxLQUFLLENBQUMsNEhBQTRILENBQUMsQ0FBQztRQUNoSixDQUFDO1FBRUQsSUFBSSxhQUFhLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztRQUM3RCxJQUFJLGNBQWMsR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBRTlELEVBQUUsQ0FBQyxDQUFDLENBQUMsZUFBTSxDQUFDLHVDQUEyQixDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3pDLEtBQUssQ0FBQyxtRkFBbUYsQ0FBQyxDQUFDO1lBQzNGLE1BQU0sK0JBQTJCLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDN0MsQ0FBQztRQUVELEVBQUUsQ0FBQyxDQUFDLENBQUMsZUFBTSxDQUFDLHlCQUFhLENBQUMsTUFBTSxFQUFFLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEQsS0FBSyxDQUFDLG1DQUFvQyxNQUFPLHlDQUEwQyxNQUFPLDhCQUE4QixDQUFDLENBQUM7WUFDbEksTUFBTSxzQkFBeUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMxQyxDQUFDO1FBRUQsS0FBSyxDQUFDLDhCQUE4QixDQUFDLENBQUM7UUFDdEMsTUFBTSxDQUFDO1lBQ0wsR0FBRyxFQUFFLGlCQUFRLENBQUMsYUFBYSxDQUFDO1lBQzVCLElBQUksRUFBRSxpQkFBUSxDQUFDLGNBQWMsQ0FBQztTQUMvQixDQUFDO0lBQ0osQ0FBQztDQUFBO0FBN0JELHdDQTZCQztBQUVELDJCQUFrQyxNQUFjO0lBQzlDLE1BQU0sQ0FBQyxlQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDO0FBQzFELENBQUM7QUFGRCw4Q0FFQztBQUVEO0lBQ0UsTUFBTSxDQUFDLGdCQUFPLENBQUMsc0JBQVUsQ0FBQyxDQUFDO0FBQzdCLENBQUM7QUFGRCw4Q0FFQztBQUVELHNCQUE2QixNQUFjO0lBQ3pDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLHlCQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztBQUM1QyxDQUFDO0FBRkQsb0NBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByZWFkRmlsZVN5bmMgYXMgcmVhZEZpbGUsIHJlYWRkaXJTeW5jIGFzIHJlYWRkaXIsIGV4aXN0c1N5bmMgYXMgZXhpc3RzIH0gZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgY3JlYXRlRGVidWcgZnJvbSAnZGVidWcnO1xuaW1wb3J0IHsgc3luYyBhcyBjb21tYW5kRXhpc3RzIH0gZnJvbSAnY29tbWFuZC1leGlzdHMnO1xuaW1wb3J0ICogYXMgcmltcmFmIGZyb20gJ3JpbXJhZic7XG5pbXBvcnQge1xuICBpc01hYyxcbiAgaXNMaW51eCxcbiAgaXNXaW5kb3dzLFxuICBwYXRoRm9yRG9tYWluLFxuICBkb21haW5zRGlyLFxuICByb290Q0FJbnN0YWxsZWRGbGFnRmlsZVBhdGhcbn0gZnJvbSAnLi9jb25zdGFudHMnO1xuaW1wb3J0IGluc3RhbGxDZXJ0aWZpY2F0ZUF1dGhvcml0eSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5pbXBvcnQgZ2VuZXJhdGVEb21haW5DZXJ0aWZpY2F0ZSBmcm9tICcuL2NlcnRpZmljYXRlcyc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQnKTtcblxuZXhwb3J0IGludGVyZmFjZSBPcHRpb25zIHtcbiAgc2tpcENlcnR1dGlsSW5zdGFsbD86IHRydWUsXG4gIHNraXBIb3N0c0ZpbGU/OiB0cnVlXG59XG5cbi8qKlxuICogUmVxdWVzdCBhbiBTU0wgY2VydGlmaWNhdGUgZm9yIHRoZSBnaXZlbiBhcHAgbmFtZSBzaWduZWQgYnkgdGhlIGRldmNlcnQgcm9vdFxuICogY2VydGlmaWNhdGUgYXV0aG9yaXR5LiBJZiBkZXZjZXJ0IGhhcyBwcmV2aW91c2x5IGdlbmVyYXRlZCBhIGNlcnRpZmljYXRlIGZvclxuICogdGhhdCBhcHAgbmFtZSBvbiB0aGlzIG1hY2hpbmUsIGl0IHdpbGwgcmV1c2UgdGhhdCBjZXJ0aWZpY2F0ZS5cbiAqXG4gKiBJZiB0aGlzIGlzIHRoZSBmaXJzdCB0aW1lIGRldmNlcnQgaXMgYmVpbmcgcnVuIG9uIHRoaXMgbWFjaGluZSwgaXQgd2lsbFxuICogZ2VuZXJhdGUgYW5kIGF0dGVtcHQgdG8gaW5zdGFsbCBhIHJvb3QgY2VydGlmaWNhdGUgYXV0aG9yaXR5LlxuICpcbiAqIFJldHVybnMgYSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB7IGtleSwgY2VydCB9LCB3aGVyZSBga2V5YCBhbmQgYGNlcnRgXG4gKiBhcmUgQnVmZmVycyB3aXRoIHRoZSBjb250ZW50cyBvZiB0aGUgY2VydGlmaWNhdGUgcHJpdmF0ZSBrZXkgYW5kIGNlcnRpZmljYXRlXG4gKiBmaWxlLCByZXNwZWN0aXZlbHlcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGNlcnRpZmljYXRlRm9yKGRvbWFpbjogc3RyaW5nLCBvcHRpb25zOiBPcHRpb25zID0ge30pIHtcbiAgZGVidWcoYENlcnRpZmljYXRlIHJlcXVlc3RlZCBmb3IgJHsgZG9tYWluIH0uIFNraXBwaW5nIGNlcnR1dGlsIGluc3RhbGw6ICR7IEJvb2xlYW4ob3B0aW9ucy5za2lwQ2VydHV0aWxJbnN0YWxsKSB9LiBTa2lwcGluZyBob3N0cyBmaWxlOiAkeyBCb29sZWFuKG9wdGlvbnMuc2tpcEhvc3RzRmlsZSkgfWApO1xuXG4gIGlmICghaXNNYWMgJiYgIWlzTGludXggJiYgIWlzV2luZG93cykge1xuICAgIHRocm93IG5ldyBFcnJvcihgUGxhdGZvcm0gbm90IHN1cHBvcnRlZDogXCIkeyBwcm9jZXNzLnBsYXRmb3JtIH1cImApO1xuICB9XG5cbiAgaWYgKCFjb21tYW5kRXhpc3RzKCdvcGVuc3NsJykpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ09wZW5TU0wgbm90IGZvdW5kLiBPcGVuU1NMIGlzIHJlcXVpcmVkIHRvIGdlbmVyYXRlIFNTTCBjZXJ0aWZpY2F0ZXMgLSBtYWtlIHN1cmUgaXQgaXMgaW5zdGFsbGVkIGFuZCBhdmFpbGFibGUgaW4geW91ciBQQVRIJyk7XG4gIH1cblxuICBsZXQgZG9tYWluS2V5UGF0aCA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgcHJpdmF0ZS1rZXkua2V5YCk7XG4gIGxldCBkb21haW5DZXJ0UGF0aCA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgY2VydGlmaWNhdGUuY3J0YCk7XG5cbiAgaWYgKCFleGlzdHMocm9vdENBSW5zdGFsbGVkRmxhZ0ZpbGVQYXRoKSkge1xuICAgIGRlYnVnKCdSb290IENBIGlzIG5vdCBpbnN0YWxsZWQgeWV0LCBzbyBpdCBtdXN0IGJlIG91ciBmaXJzdCBydW4uIEluc3RhbGxpbmcgcm9vdCBDQSAuLi4nKTtcbiAgICBhd2FpdCBpbnN0YWxsQ2VydGlmaWNhdGVBdXRob3JpdHkob3B0aW9ucyk7XG4gIH1cblxuICBpZiAoIWV4aXN0cyhwYXRoRm9yRG9tYWluKGRvbWFpbiwgYGNlcnRpZmljYXRlLmNydGApKSkge1xuICAgIGRlYnVnKGBDYW4ndCBmaW5kIGNlcnRpZmljYXRlIGZpbGUgZm9yICR7IGRvbWFpbiB9LCBzbyBpdCBtdXN0IGJlIHRoZSBmaXJzdCByZXF1ZXN0IGZvciAkeyBkb21haW4gfS4gR2VuZXJhdGluZyBhbmQgY2FjaGluZyAuLi5gKTtcbiAgICBhd2FpdCBnZW5lcmF0ZURvbWFpbkNlcnRpZmljYXRlKGRvbWFpbik7XG4gIH1cblxuICBkZWJ1ZyhgUmV0dXJuaW5nIGRvbWFpbiBjZXJ0aWZpY2F0ZWApO1xuICByZXR1cm4ge1xuICAgIGtleTogcmVhZEZpbGUoZG9tYWluS2V5UGF0aCksXG4gICAgY2VydDogcmVhZEZpbGUoZG9tYWluQ2VydFBhdGgpXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBoYXNDZXJ0aWZpY2F0ZUZvcihkb21haW46IHN0cmluZykge1xuICByZXR1cm4gZXhpc3RzKHBhdGhGb3JEb21haW4oZG9tYWluLCBgY2VydGlmaWNhdGUuY3J0YCkpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY29uZmlndXJlZERvbWFpbnMoKSB7XG4gIHJldHVybiByZWFkZGlyKGRvbWFpbnNEaXIpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlRG9tYWluKGRvbWFpbjogc3RyaW5nKSB7XG4gIHJldHVybiByaW1yYWYuc3luYyhwYXRoRm9yRG9tYWluKGRvbWFpbikpO1xufSJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL2Rhdy9vc3MvZGV2Y2VydC8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDJCQUE0RjtBQUM1RixxQ0FBcUM7QUFDckMsbURBQXVEO0FBQ3ZELGlDQUFpQztBQUNqQywyQ0FPcUI7QUFDckIsbUVBQWtFO0FBQ2xFLGlEQUF1RDtBQUV2RCxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUM7QUFPckM7Ozs7Ozs7Ozs7O0dBV0c7QUFDSCx3QkFBcUMsTUFBYyxFQUFFLFVBQW1CLEVBQUU7O1FBQ3hFLEtBQUssQ0FBQyw2QkFBOEIsTUFBTyxnQ0FBaUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBRSwwQkFBMkIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUUsRUFBRSxDQUFDLENBQUM7UUFFL0ssRUFBRSxDQUFDLENBQUMsQ0FBQyxpQkFBSyxJQUFJLENBQUMsbUJBQU8sSUFBSSxDQUFDLHFCQUFTLENBQUMsQ0FBQyxDQUFDO1lBQ3JDLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTZCLE9BQU8sQ0FBQyxRQUFTLEdBQUcsQ0FBQyxDQUFDO1FBQ3JFLENBQUM7UUFFRCxFQUFFLENBQUMsQ0FBQyxDQUFDLHFCQUFhLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzlCLE1BQU0sSUFBSSxLQUFLLENBQUMsNEhBQTRILENBQUMsQ0FBQztRQUNoSixDQUFDO1FBRUQsSUFBSSxhQUFhLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztRQUM3RCxJQUFJLGNBQWMsR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBRTlELEVBQUUsQ0FBQyxDQUFDLENBQUMsZUFBTSxDQUFDLHlCQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDM0IsS0FBSyxDQUFDLG1GQUFtRixDQUFDLENBQUM7WUFDM0YsTUFBTSwrQkFBMkIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QyxDQUFDO1FBRUQsRUFBRSxDQUFDLENBQUMsQ0FBQyxlQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0RCxLQUFLLENBQUMsbUNBQW9DLE1BQU8seUNBQTBDLE1BQU8sOEJBQThCLENBQUMsQ0FBQztZQUNsSSxNQUFNLHNCQUF5QixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzFDLENBQUM7UUFFRCxLQUFLLENBQUMsOEJBQThCLENBQUMsQ0FBQztRQUN0QyxNQUFNLENBQUM7WUFDTCxHQUFHLEVBQUUsaUJBQVEsQ0FBQyxhQUFhLENBQUM7WUFDNUIsSUFBSSxFQUFFLGlCQUFRLENBQUMsY0FBYyxDQUFDO1NBQy9CLENBQUM7SUFDSixDQUFDO0NBQUE7QUE3QkQsd0NBNkJDO0FBRUQsMkJBQWtDLE1BQWM7SUFDOUMsTUFBTSxDQUFDLGVBQU0sQ0FBQyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7QUFDMUQsQ0FBQztBQUZELDhDQUVDO0FBRUQ7SUFDRSxNQUFNLENBQUMsZ0JBQU8sQ0FBQyxzQkFBVSxDQUFDLENBQUM7QUFDN0IsQ0FBQztBQUZELDhDQUVDO0FBRUQsc0JBQTZCLE1BQWM7SUFDekMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMseUJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0FBQzVDLENBQUM7QUFGRCxvQ0FFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlYWRGaWxlU3luYyBhcyByZWFkRmlsZSwgcmVhZGRpclN5bmMgYXMgcmVhZGRpciwgZXhpc3RzU3luYyBhcyBleGlzdHMgfSBmcm9tICdmcyc7XG5pbXBvcnQgKiBhcyBjcmVhdGVEZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyBzeW5jIGFzIGNvbW1hbmRFeGlzdHMgfSBmcm9tICdjb21tYW5kLWV4aXN0cyc7XG5pbXBvcnQgKiBhcyByaW1yYWYgZnJvbSAncmltcmFmJztcbmltcG9ydCB7XG4gIGlzTWFjLFxuICBpc0xpbnV4LFxuICBpc1dpbmRvd3MsXG4gIHBhdGhGb3JEb21haW4sXG4gIGRvbWFpbnNEaXIsXG4gIHJvb3RDQUtleVBhdGhcbn0gZnJvbSAnLi9jb25zdGFudHMnO1xuaW1wb3J0IGluc3RhbGxDZXJ0aWZpY2F0ZUF1dGhvcml0eSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5pbXBvcnQgZ2VuZXJhdGVEb21haW5DZXJ0aWZpY2F0ZSBmcm9tICcuL2NlcnRpZmljYXRlcyc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQnKTtcblxuZXhwb3J0IGludGVyZmFjZSBPcHRpb25zIHtcbiAgc2tpcENlcnR1dGlsSW5zdGFsbD86IHRydWUsXG4gIHNraXBIb3N0c0ZpbGU/OiB0cnVlXG59XG5cbi8qKlxuICogUmVxdWVzdCBhbiBTU0wgY2VydGlmaWNhdGUgZm9yIHRoZSBnaXZlbiBhcHAgbmFtZSBzaWduZWQgYnkgdGhlIGRldmNlcnQgcm9vdFxuICogY2VydGlmaWNhdGUgYXV0aG9yaXR5LiBJZiBkZXZjZXJ0IGhhcyBwcmV2aW91c2x5IGdlbmVyYXRlZCBhIGNlcnRpZmljYXRlIGZvclxuICogdGhhdCBhcHAgbmFtZSBvbiB0aGlzIG1hY2hpbmUsIGl0IHdpbGwgcmV1c2UgdGhhdCBjZXJ0aWZpY2F0ZS5cbiAqXG4gKiBJZiB0aGlzIGlzIHRoZSBmaXJzdCB0aW1lIGRldmNlcnQgaXMgYmVpbmcgcnVuIG9uIHRoaXMgbWFjaGluZSwgaXQgd2lsbFxuICogZ2VuZXJhdGUgYW5kIGF0dGVtcHQgdG8gaW5zdGFsbCBhIHJvb3QgY2VydGlmaWNhdGUgYXV0aG9yaXR5LlxuICpcbiAqIFJldHVybnMgYSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB7IGtleSwgY2VydCB9LCB3aGVyZSBga2V5YCBhbmQgYGNlcnRgXG4gKiBhcmUgQnVmZmVycyB3aXRoIHRoZSBjb250ZW50cyBvZiB0aGUgY2VydGlmaWNhdGUgcHJpdmF0ZSBrZXkgYW5kIGNlcnRpZmljYXRlXG4gKiBmaWxlLCByZXNwZWN0aXZlbHlcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGNlcnRpZmljYXRlRm9yKGRvbWFpbjogc3RyaW5nLCBvcHRpb25zOiBPcHRpb25zID0ge30pIHtcbiAgZGVidWcoYENlcnRpZmljYXRlIHJlcXVlc3RlZCBmb3IgJHsgZG9tYWluIH0uIFNraXBwaW5nIGNlcnR1dGlsIGluc3RhbGw6ICR7IEJvb2xlYW4ob3B0aW9ucy5za2lwQ2VydHV0aWxJbnN0YWxsKSB9LiBTa2lwcGluZyBob3N0cyBmaWxlOiAkeyBCb29sZWFuKG9wdGlvbnMuc2tpcEhvc3RzRmlsZSkgfWApO1xuXG4gIGlmICghaXNNYWMgJiYgIWlzTGludXggJiYgIWlzV2luZG93cykge1xuICAgIHRocm93IG5ldyBFcnJvcihgUGxhdGZvcm0gbm90IHN1cHBvcnRlZDogXCIkeyBwcm9jZXNzLnBsYXRmb3JtIH1cImApO1xuICB9XG5cbiAgaWYgKCFjb21tYW5kRXhpc3RzKCdvcGVuc3NsJykpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ09wZW5TU0wgbm90IGZvdW5kLiBPcGVuU1NMIGlzIHJlcXVpcmVkIHRvIGdlbmVyYXRlIFNTTCBjZXJ0aWZpY2F0ZXMgLSBtYWtlIHN1cmUgaXQgaXMgaW5zdGFsbGVkIGFuZCBhdmFpbGFibGUgaW4geW91ciBQQVRIJyk7XG4gIH1cblxuICBsZXQgZG9tYWluS2V5UGF0aCA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgcHJpdmF0ZS1rZXkua2V5YCk7XG4gIGxldCBkb21haW5DZXJ0UGF0aCA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgY2VydGlmaWNhdGUuY3J0YCk7XG5cbiAgaWYgKCFleGlzdHMocm9vdENBS2V5UGF0aCkpIHtcbiAgICBkZWJ1ZygnUm9vdCBDQSBpcyBub3QgaW5zdGFsbGVkIHlldCwgc28gaXQgbXVzdCBiZSBvdXIgZmlyc3QgcnVuLiBJbnN0YWxsaW5nIHJvb3QgQ0EgLi4uJyk7XG4gICAgYXdhaXQgaW5zdGFsbENlcnRpZmljYXRlQXV0aG9yaXR5KG9wdGlvbnMpO1xuICB9XG5cbiAgaWYgKCFleGlzdHMocGF0aEZvckRvbWFpbihkb21haW4sIGBjZXJ0aWZpY2F0ZS5jcnRgKSkpIHtcbiAgICBkZWJ1ZyhgQ2FuJ3QgZmluZCBjZXJ0aWZpY2F0ZSBmaWxlIGZvciAkeyBkb21haW4gfSwgc28gaXQgbXVzdCBiZSB0aGUgZmlyc3QgcmVxdWVzdCBmb3IgJHsgZG9tYWluIH0uIEdlbmVyYXRpbmcgYW5kIGNhY2hpbmcgLi4uYCk7XG4gICAgYXdhaXQgZ2VuZXJhdGVEb21haW5DZXJ0aWZpY2F0ZShkb21haW4pO1xuICB9XG5cbiAgZGVidWcoYFJldHVybmluZyBkb21haW4gY2VydGlmaWNhdGVgKTtcbiAgcmV0dXJuIHtcbiAgICBrZXk6IHJlYWRGaWxlKGRvbWFpbktleVBhdGgpLFxuICAgIGNlcnQ6IHJlYWRGaWxlKGRvbWFpbkNlcnRQYXRoKVxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzQ2VydGlmaWNhdGVGb3IoZG9tYWluOiBzdHJpbmcpIHtcbiAgcmV0dXJuIGV4aXN0cyhwYXRoRm9yRG9tYWluKGRvbWFpbiwgYGNlcnRpZmljYXRlLmNydGApKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNvbmZpZ3VyZWREb21haW5zKCkge1xuICByZXR1cm4gcmVhZGRpcihkb21haW5zRGlyKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlbW92ZURvbWFpbihkb21haW46IHN0cmluZykge1xuICByZXR1cm4gcmltcmFmLnN5bmMocGF0aEZvckRvbWFpbihkb21haW4pKTtcbn0iXX0= |
{ | ||
"name": "devcert", | ||
"version": "1.0.0-beta.7", | ||
"version": "1.0.0-beta.8", | ||
"description": "Generate trusted local SSL/TLS certificates for local SSL development", | ||
@@ -36,3 +36,2 @@ "main": "dist/index.js", | ||
"@types/glob": "^5.0.34", | ||
"@types/keytar": "^4.0.1", | ||
"@types/mkdirp": "^0.5.2", | ||
@@ -49,4 +48,4 @@ "@types/node": "^8.5.7", | ||
"glob": "^7.1.2", | ||
"keytar": "^4.1.0", | ||
"mkdirp": "^0.5.1", | ||
"prompt": "^1.0.0", | ||
"rimraf": "^2.6.2", | ||
@@ -53,0 +52,0 @@ "tmp": "^0.0.33", |
@@ -1,6 +0,7 @@ | ||
import { unlinkSync as rm, readFileSync as readFile, writeFileSync as writeFile } from 'fs'; | ||
import * as crypto from 'crypto'; | ||
import { readFileSync as readFile, writeFileSync as writeFile } from 'fs'; | ||
import * as createDebug from 'debug'; | ||
import * as eol from 'eol'; | ||
import { fileSync as tmp } from 'tmp'; | ||
import * as keychain from 'keytar'; | ||
import * as prompt from 'prompt'; | ||
@@ -13,3 +14,4 @@ import { | ||
opensslConfTemplate, | ||
rootCAInstalledFlagFilePath | ||
rootCAKeyPath, | ||
rootCACertPath, | ||
} from './constants'; | ||
@@ -44,3 +46,3 @@ import addToMacTrustStores from './platforms/macos'; | ||
debug('Saving certificate authority credentials to system keychain'); | ||
addCertificateAuthorityToSystemKeychain(rootKeyPath, rootCertPath); | ||
saveCertificateAuthorityCredentials(rootKeyPath, rootCertPath); | ||
@@ -56,8 +58,2 @@ debug(`Adding the root certificate authority to trust stores`); | ||
debug('Certificate authority added to trust stores, removing temporary files'); | ||
rm(rootKeyPath); | ||
rm(rootCertPath); | ||
debug('Adding flag indicating root certificate authority install'); | ||
writeFile(rootCAInstalledFlagFilePath, ''); | ||
} | ||
@@ -86,17 +82,45 @@ | ||
debug(`Fetching devcert's certificate authority credentials from the system keychain`); | ||
let rootKeyPath = tmp().name; | ||
let rootCertPath = tmp().name; | ||
let key = await keychain.getPassword('devcert', 'certificate-authority-key'); | ||
let cert = await keychain.getPassword('devcert', 'certificate-authority-certificate'); | ||
writeFile(rootKeyPath, key); | ||
writeFile(rootCertPath, cert); | ||
return { rootKeyPath, rootCertPath }; | ||
let decryptedCAKeyPath = tmp().name; | ||
let decryptedCACertPath = tmp().name; | ||
let encryptedCAKey = readFile(rootCAKeyPath, 'utf-8'); | ||
let encryptedCACert = readFile(rootCACertPath, 'utf-8'); | ||
let encryptionKey = await getPasswordFromUser(); | ||
writeFile(decryptedCAKeyPath , decrypt(encryptedCAKey, encryptionKey)); | ||
writeFile(decryptedCACertPath , decrypt(encryptedCACert, encryptionKey)); | ||
return { decryptedCAKeyPath , decryptedCACertPath }; | ||
} | ||
async function addCertificateAuthorityToSystemKeychain(keypath: string, certpath: string) { | ||
async function saveCertificateAuthorityCredentials(keypath: string, certpath: string) { | ||
debug(`Adding devcert's certificate authority credentials to the system keychain`); | ||
let key = readFile(keypath, 'utf-8'); | ||
let cert = readFile(certpath, 'utf-8'); | ||
await keychain.setPassword('devcert', 'certificate-authority-key', key); | ||
await keychain.setPassword('devcert', 'certificate-authority-certificate', cert); | ||
let encryptionKey = await getPasswordFromUser(); | ||
writeFile(rootCAKeyPath, encrypt(key, encryptionKey)); | ||
writeFile(rootCACertPath, encrypt(cert, encryptionKey)); | ||
} | ||
function getPasswordFromUser(): Promise<string> { | ||
return new Promise((resolve, reject) => { | ||
prompt.start(); | ||
prompt.get({ | ||
properties: { | ||
password: { | ||
description: 'Password:', | ||
hidden: true | ||
} | ||
} | ||
}, (err: Error, result: string) => { | ||
err ? reject(err) : resolve(result); | ||
}); | ||
}); | ||
} | ||
function encrypt(text: string, key: string) { | ||
let cipher = crypto.createCipher('aes256', key); | ||
return cipher.update(text, 'utf8', 'hex') + cipher.final('hex'); | ||
} | ||
function decrypt(encrypted: string, key: string) { | ||
let decipher = crypto.createDecipher('aes256', key); | ||
return decipher.update(encrypted, 'hex', 'utf8') + decipher.final('utf8'); | ||
} |
@@ -31,7 +31,7 @@ import * as path from 'path'; | ||
let certPath = pathForDomain(`${ domain }.crt`); | ||
let { rootKeyPath, rootCertPath } = await fetchCertificateAuthorityCredentials(); | ||
openssl(`ca -config ${ opensslConfPath } -in ${ csrFile } -out ${ path.basename(certPath) } -outdir ${ path.dirname(certPath) } -keyfile ${ rootKeyPath } -cert ${ rootCertPath } -notext -md sha256 -days 7000 -batch -extensions server_cert`) | ||
let { decryptedCAKeyPath, decryptedCACertPath } = await fetchCertificateAuthorityCredentials(); | ||
openssl(`ca -config ${ opensslConfPath } -in ${ csrFile } -out ${ path.basename(certPath) } -outdir ${ path.dirname(certPath) } -keyfile ${ decryptedCAKeyPath } -cert ${ decryptedCACertPath } -notext -md sha256 -days 7000 -batch -extensions server_cert`) | ||
rm(rootKeyPath); | ||
rm(rootCertPath); | ||
rm(decryptedCAKeyPath); | ||
rm(decryptedCACertPath); | ||
} | ||
@@ -38,0 +38,0 @@ |
@@ -20,5 +20,7 @@ import * as path from 'path'; | ||
export const rootCAInstalledFlagFilePath = configPath('root-ca-installed'); | ||
export const rootCADir = configPath('certificate-authority'); | ||
export const rootCAKeyPath = configPath('certificate-authority', 'private-key.key'); | ||
export const rootCACertPath = configPath('certificate-authority', 'certificate.cert'); | ||
mkdirp(configDir); | ||
mkdirp(domainsDir); |
@@ -11,3 +11,3 @@ import { readFileSync as readFile, readdirSync as readdir, existsSync as exists } from 'fs'; | ||
domainsDir, | ||
rootCAInstalledFlagFilePath | ||
rootCAKeyPath | ||
} from './constants'; | ||
@@ -50,3 +50,3 @@ import installCertificateAuthority from './certificate-authority'; | ||
if (!exists(rootCAInstalledFlagFilePath)) { | ||
if (!exists(rootCAKeyPath)) { | ||
debug('Root CA is not installed yet, so it must be our first run. Installing root CA ...'); | ||
@@ -53,0 +53,0 @@ await installCertificateAuthority(options); |
declare module "command-exists"; | ||
declare module "eol"; | ||
declare module "prompt"; | ||
declare module "application-config-path" { | ||
export = (appName: string) => string; | ||
} |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
211469
20
1442
+ Addedprompt@^1.0.0
+ Added@colors/colors@1.5.0(transitive)
+ Addedasync@2.6.43.2.3(transitive)
+ Addedcolors@1.0.3(transitive)
+ Addedcycle@1.0.3(transitive)
+ Addedeyes@0.1.8(transitive)
+ Addedisstream@0.1.2(transitive)
+ Addedlodash@4.17.21(transitive)
+ Addedmute-stream@0.0.8(transitive)
+ Addedprompt@1.3.0(transitive)
+ Addedread@1.0.7(transitive)
+ Addedrevalidator@0.1.8(transitive)
+ Addedstack-trace@0.0.10(transitive)
+ Addedwinston@2.4.7(transitive)
- Removed@types/keytar@^4.0.1
- Removedkeytar@^4.1.0
- Removed@types/keytar@4.4.2(transitive)
- Removedansi-regex@2.1.1(transitive)
- Removedaproba@1.2.0(transitive)
- Removedare-we-there-yet@1.1.7(transitive)
- Removedbl@1.2.3(transitive)
- Removedbuffer-alloc@1.2.0(transitive)
- Removedbuffer-alloc-unsafe@1.1.0(transitive)
- Removedbuffer-fill@1.0.0(transitive)
- Removedchownr@1.1.4(transitive)
- Removedcode-point-at@1.1.0(transitive)
- Removedconsole-control-strings@1.1.0(transitive)
- Removedcore-util-is@1.0.3(transitive)
- Removeddecompress-response@3.3.0(transitive)
- Removeddeep-extend@0.6.0(transitive)
- Removeddelegates@1.0.0(transitive)
- Removeddetect-libc@1.0.3(transitive)
- Removedend-of-stream@1.4.4(transitive)
- Removedexpand-template@2.0.3(transitive)
- Removedfs-constants@1.0.0(transitive)
- Removedgauge@2.7.4(transitive)
- Removedgithub-from-package@0.0.0(transitive)
- Removedhas-unicode@2.0.1(transitive)
- Removedini@1.3.8(transitive)
- Removedis-fullwidth-code-point@1.0.0(transitive)
- Removedisarray@1.0.0(transitive)
- Removedkeytar@4.13.0(transitive)
- Removedmimic-response@1.0.1(transitive)
- Removednan@2.14.0(transitive)
- Removednapi-build-utils@1.0.2(transitive)
- Removednode-abi@2.30.1(transitive)
- Removednoop-logger@0.1.1(transitive)
- Removednpmlog@4.1.2(transitive)
- Removednumber-is-nan@1.0.1(transitive)
- Removedobject-assign@4.1.1(transitive)
- Removedos-homedir@1.0.2(transitive)
- Removedprebuild-install@5.3.0(transitive)
- Removedprocess-nextick-args@2.0.1(transitive)
- Removedpump@1.0.32.0.1(transitive)
- Removedrc@1.2.8(transitive)
- Removedreadable-stream@2.3.8(transitive)
- Removedsafe-buffer@5.1.2(transitive)
- Removedsemver@5.7.2(transitive)
- Removedset-blocking@2.0.0(transitive)
- Removedsimple-concat@1.0.1(transitive)
- Removedsimple-get@2.8.2(transitive)
- Removedstring-width@1.0.2(transitive)
- Removedstring_decoder@1.1.1(transitive)
- Removedstrip-ansi@3.0.1(transitive)
- Removedstrip-json-comments@2.0.1(transitive)
- Removedtar-fs@1.16.3(transitive)
- Removedtar-stream@1.6.2(transitive)
- Removedto-buffer@1.1.1(transitive)
- Removedtunnel-agent@0.6.0(transitive)
- Removedutil-deprecate@1.0.2(transitive)
- Removedwhich-pm-runs@1.1.0(transitive)
- Removedwide-align@1.1.5(transitive)
- Removedxtend@4.0.2(transitive)