Comparing version 1.0.0-beta.10 to 1.0.0-beta.11
@@ -91,2 +91,3 @@ "use strict"; | ||
return new Promise((resolve, reject) => { | ||
prompt.message = 'password'; | ||
prompt.start(); | ||
@@ -96,3 +97,3 @@ prompt.get({ | ||
password: { | ||
message: 'password:', | ||
message: '', | ||
hidden: true | ||
@@ -108,8 +109,8 @@ } | ||
let cipher = crypto.createCipher('aes256', key); | ||
return cipher.update(new Buffer(text)) + cipher.final('hex'); | ||
return cipher.update(text, 'utf8', 'hex') + cipher.final('hex'); | ||
} | ||
function decrypt(encrypted, key) { | ||
let decipher = crypto.createDecipher('aes256', key); | ||
return decipher.update(encrypted, 'hex') + decipher.final('utf8'); | ||
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":";;;AAAA,iCAAiC;AACjC,2BAA0E;AAC1E,qCAAqC;AACrC,2BAA2B;AAC3B,6BAAsC;AACtC,iCAAiC;AAEjC,2CAQqB;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,MAAM,mCAAmC,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QAErE,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;IAEH,CAAC;CAAA;AA1BD,8CA0BC;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,wDAAwD,CAAC,CAAC;QAChE,IAAI,kBAAkB,GAAG,cAAG,EAAE,CAAC,IAAI,CAAC;QACpC,IAAI,mBAAmB,GAAG,cAAG,EAAE,CAAC,IAAI,CAAC;QACrC,IAAI,cAAc,GAAG,iBAAQ,CAAC,yBAAa,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,eAAe,GAAG,iBAAQ,CAAC,0BAAc,EAAE,OAAO,CAAC,CAAC;QACxD,IAAI,aAAa,GAAG,MAAM,mBAAmB,EAAE,CAAC;QAChD,kBAAS,CAAC,kBAAkB,EAAG,OAAO,CAAC,cAAc,EAAE,aAAa,CAAC,CAAC,CAAC;QACvE,kBAAS,CAAC,mBAAmB,EAAG,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC,CAAC;QACzE,MAAM,CAAC,EAAE,kBAAkB,EAAG,mBAAmB,EAAG,CAAC;IACvD,CAAC;CAAA;AAVD,oFAUC;AAED,6CAAmD,OAAe,EAAE,QAAgB;;QAClF,KAAK,CAAC,wDAAwD,CAAC,CAAC;QAChE,IAAI,GAAG,GAAG,iBAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACrC,IAAI,IAAI,GAAG,iBAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACvC,IAAI,aAAa,GAAG,MAAM,mBAAmB,EAAE,CAAC;QAChD,kBAAS,CAAC,yBAAa,EAAE,OAAO,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC;QACtD,kBAAS,CAAC,0BAAc,EAAE,OAAO,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC;IAC1D,CAAC;CAAA;AAED;IACE,MAAM,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,CAAC,GAAG,CAAC;YACT,UAAU,EAAE;gBACV,QAAQ,EAAE;oBACR,OAAO,EAAE,WAAW;oBACpB,MAAM,EAAE,IAAI;iBACb;aACF;SACF,EAAE,CAAC,GAAU,EAAE,EAAE,QAAQ,EAAwB,EAAE,EAAE;YACpD,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,iBAAiB,IAAY,EAAE,GAAW;IACxC,IAAI,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAChD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC/D,CAAC;AAED,iBAAiB,SAAiB,EAAE,GAAW;IAC7C,IAAI,QAAQ,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IACpD,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,KAAK,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AACpE,CAAC","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  await 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(`Decrypting devcert's certificate authority credentials`);\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(`Encrypting devcert's certificate authority credentials`);\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          message: 'password:',\n          hidden: true\n        }\n      }\n    }, (err: Error, { password }: { password: string }) => {\n      err ? reject(err) : resolve(password);\n    });\n  });\n}\n\nfunction encrypt(text: string, key: string) {\n  let cipher = crypto.createCipher('aes256', key);\n  return cipher.update(new Buffer(text)) + cipher.final('hex');\n}\n\nfunction decrypt(encrypted: string, key: string) {\n  let decipher = crypto.createDecipher('aes256', key);\n  return decipher.update(encrypted, 'hex') + decipher.final('utf8');\n}"]} | ||
//# 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  await 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(`Decrypting devcert's certificate authority credentials`);\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(`Encrypting devcert's certificate authority credentials`);\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.message = 'password';\n    prompt.start();\n    prompt.get({\n      properties: {\n        password: {\n          message: '',\n          hidden: true\n        }\n      }\n    }, (err: Error, { password }: { password: string }) => {\n      err ? reject(err) : resolve(password);\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}"]} |
@@ -26,6 +26,6 @@ "use strict"; | ||
debug(`Generating certificate signing request for ${domain}`); | ||
let csrFile = constants_1.pathForDomain(domain, `${domain}.csr`); | ||
let csrFile = constants_1.pathForDomain(domain, `certificate-signing-request.csr`); | ||
utils_1.openssl(`req -config ${constants_1.opensslConfPath} -subj "/CN=${domain}" -key ${keyPath} -out ${csrFile} -new`); | ||
debug(`Generating certificate for ${domain} from signing request and signing with root CA`); | ||
let certPath = constants_1.pathForDomain(`${domain}.crt`); | ||
let certPath = constants_1.pathForDomain(domain, `certificate.crt`); | ||
let { decryptedCAKeyPath, decryptedCACertPath } = yield certificate_authority_1.fetchCertificateAuthorityCredentials(); | ||
@@ -45,2 +45,2 @@ 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`); | ||
exports.generateKey = generateKey; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VydGlmaWNhdGVzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjZXJ0aWZpY2F0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkJBQTZCO0FBQzdCLHFDQUFxQztBQUNyQyxtQ0FBd0M7QUFDeEMsMkJBQTBEO0FBQzFELDJDQUE2RDtBQUM3RCxtQ0FBa0M7QUFDbEMsbUVBQStFO0FBRS9FLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBRWxEOzs7Ozs7R0FNRztBQUNILG1DQUF3RCxNQUFjOztRQUNwRSxhQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTlCLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLE9BQU8sR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3ZELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVyQixLQUFLLENBQUMsOENBQStDLE1BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxPQUFPLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZELGVBQU8sQ0FBQyxlQUFnQiwyQkFBZ0IsZUFBZ0IsTUFBTyxVQUFXLE9BQVEsU0FBVSxPQUFRLE9BQU8sQ0FBQyxDQUFDO1FBRTdHLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxnREFBZ0QsQ0FBQyxDQUFDO1FBQzlGLElBQUksUUFBUSxHQUFHLHlCQUFhLENBQUMsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ2hELElBQUksRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxHQUFHLE1BQU0sNERBQW9DLEVBQUUsQ0FBQztRQUMvRixlQUFPLENBQUMsY0FBZSwyQkFBZ0IsUUFBUyxPQUFRLFNBQVUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUUsWUFBYSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBRSxhQUFjLGtCQUFtQixVQUFXLG1CQUFvQiwrREFBK0QsQ0FBQyxDQUFBO1FBRTlQLGVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3ZCLGVBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBQzFCLENBQUM7Q0FBQTtBQWxCRCw0Q0FrQkM7QUFFRCwyRkFBMkY7QUFDM0YscUJBQTRCLFFBQWdCO0lBQzFDLEtBQUssQ0FBQyxnQkFBaUIsUUFBUyxFQUFFLENBQUMsQ0FBQztJQUNwQyxlQUFPLENBQUMsZUFBZ0IsUUFBUyxPQUFPLENBQUMsQ0FBQztJQUMxQyxjQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUM7QUFKRCxrQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgKiBhcyBjcmVhdGVEZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgeyB1bmxpbmtTeW5jIGFzIHJtLCBjaG1vZFN5bmMgYXMgY2htb2QgfSBmcm9tICdmcyc7XG5pbXBvcnQgeyBwYXRoRm9yRG9tYWluLCBvcGVuc3NsQ29uZlBhdGggfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBvcGVuc3NsIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBmZXRjaENlcnRpZmljYXRlQXV0aG9yaXR5Q3JlZGVudGlhbHMgfSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQ6Y2VydGlmaWNhdGVzJyk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBkb21haW4gY2VydGlmaWNhdGUgc2lnbmVkIGJ5IHRoZSBkZXZjZXJ0IHJvb3QgQ0EuIERvbWFpblxuICogY2VydGlmaWNhdGVzIGFyZSBjYWNoZWQgaW4gdGhlaXIgb3duIGRpcmVjdG9yaWVzIHVuZGVyXG4gKiBDT05GSUdfUk9PVC9kb21haW5zLzxkb21haW4+LCBhbmQgcmV1c2VkIG9uIHN1YnNlcXVlbnQgcmVxdWVzdHMuIEJlY2F1c2UgdGhlXG4gKiBpbmRpdmlkdWFsIGRvbWFpbiBjZXJ0aWZpY2F0ZXMgYXJlIHNpZ25lZCBieSB0aGUgZGV2Y2VydCByb290IENBICh3aGljaCB3YXNcbiAqIGFkZGVkIHRvIHRoZSBPUy9icm93c2VyIHRydXN0IHN0b3JlcyksIHRoZXkgYXJlIHRydXN0ZWQuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlRG9tYWluQ2VydGlmaWNhdGUoZG9tYWluOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbWtkaXJwKHBhdGhGb3JEb21haW4oZG9tYWluKSk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgcHJpdmF0ZSBrZXkgZm9yICR7IGRvbWFpbiB9YCk7XG4gIGxldCBrZXlQYXRoID0gcGF0aEZvckRvbWFpbihkb21haW4sICdwcml2YXRlLWtleS5rZXknKTtcbiAgZ2VuZXJhdGVLZXkoa2V5UGF0aCk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0IGZvciAkeyBkb21haW4gfWApO1xuICBsZXQgY3NyRmlsZSA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgJHsgZG9tYWluIH0uY3NyYCk7XG4gIG9wZW5zc2woYHJlcSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1zdWJqIFwiL0NOPSR7IGRvbWFpbiB9XCIgLWtleSAkeyBrZXlQYXRoIH0gLW91dCAkeyBjc3JGaWxlIH0gLW5ld2ApO1xuXG4gIGRlYnVnKGBHZW5lcmF0aW5nIGNlcnRpZmljYXRlIGZvciAkeyBkb21haW4gfSBmcm9tIHNpZ25pbmcgcmVxdWVzdCBhbmQgc2lnbmluZyB3aXRoIHJvb3QgQ0FgKTtcbiAgbGV0IGNlcnRQYXRoID0gcGF0aEZvckRvbWFpbihgJHsgZG9tYWluIH0uY3J0YCk7XG4gIGxldCB7IGRlY3J5cHRlZENBS2V5UGF0aCwgZGVjcnlwdGVkQ0FDZXJ0UGF0aCB9ID0gYXdhaXQgZmV0Y2hDZXJ0aWZpY2F0ZUF1dGhvcml0eUNyZWRlbnRpYWxzKCk7XG4gIG9wZW5zc2woYGNhIC1jb25maWcgJHsgb3BlbnNzbENvbmZQYXRoIH0gLWluICR7IGNzckZpbGUgfSAtb3V0ICR7IHBhdGguYmFzZW5hbWUoY2VydFBhdGgpIH0gLW91dGRpciAkeyBwYXRoLmRpcm5hbWUoY2VydFBhdGgpIH0gLWtleWZpbGUgJHsgZGVjcnlwdGVkQ0FLZXlQYXRoIH0gLWNlcnQgJHsgZGVjcnlwdGVkQ0FDZXJ0UGF0aCB9IC1ub3RleHQgLW1kIHNoYTI1NiAtZGF5cyA3MDAwIC1iYXRjaCAtZXh0ZW5zaW9ucyBzZXJ2ZXJfY2VydGApXG5cbiAgcm0oZGVjcnlwdGVkQ0FLZXlQYXRoKTtcbiAgcm0oZGVjcnlwdGVkQ0FDZXJ0UGF0aCk7XG59XG5cbi8vIEdlbmVyYXRlIGEgY3J5cHRvZ3JhcGhpYyBrZXksIHVzZWQgdG8gc2lnbiBjZXJ0aWZpY2F0ZXMgb3IgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0cy5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUtleShmaWxlbmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIGRlYnVnKGBnZW5lcmF0ZUtleTogJHsgZmlsZW5hbWUgfWApO1xuICBvcGVuc3NsKGBnZW5yc2EgLW91dCAkeyBmaWxlbmFtZSB9IDIwNDhgKTtcbiAgY2htb2QoZmlsZW5hbWUsIDQwMCk7XG59Il19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VydGlmaWNhdGVzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjZXJ0aWZpY2F0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkJBQTZCO0FBQzdCLHFDQUFxQztBQUNyQyxtQ0FBd0M7QUFDeEMsMkJBQTBEO0FBQzFELDJDQUE2RDtBQUM3RCxtQ0FBa0M7QUFDbEMsbUVBQStFO0FBRS9FLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBRWxEOzs7Ozs7R0FNRztBQUNILG1DQUF3RCxNQUFjOztRQUNwRSxhQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTlCLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLE9BQU8sR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3ZELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVyQixLQUFLLENBQUMsOENBQStDLE1BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxPQUFPLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsaUNBQWlDLENBQUMsQ0FBQztRQUN2RSxlQUFPLENBQUMsZUFBZ0IsMkJBQWdCLGVBQWdCLE1BQU8sVUFBVyxPQUFRLFNBQVUsT0FBUSxPQUFPLENBQUMsQ0FBQztRQUU3RyxLQUFLLENBQUMsOEJBQStCLE1BQU8sZ0RBQWdELENBQUMsQ0FBQztRQUM5RixJQUFJLFFBQVEsR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3hELElBQUksRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxHQUFHLE1BQU0sNERBQW9DLEVBQUUsQ0FBQztRQUMvRixlQUFPLENBQUMsY0FBZSwyQkFBZ0IsUUFBUyxPQUFRLFNBQVUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUUsWUFBYSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBRSxhQUFjLGtCQUFtQixVQUFXLG1CQUFvQiwrREFBK0QsQ0FBQyxDQUFBO1FBRTlQLGVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3ZCLGVBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBQzFCLENBQUM7Q0FBQTtBQWxCRCw0Q0FrQkM7QUFFRCwyRkFBMkY7QUFDM0YscUJBQTRCLFFBQWdCO0lBQzFDLEtBQUssQ0FBQyxnQkFBaUIsUUFBUyxFQUFFLENBQUMsQ0FBQztJQUNwQyxlQUFPLENBQUMsZUFBZ0IsUUFBUyxPQUFPLENBQUMsQ0FBQztJQUMxQyxjQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUM7QUFKRCxrQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgKiBhcyBjcmVhdGVEZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgeyB1bmxpbmtTeW5jIGFzIHJtLCBjaG1vZFN5bmMgYXMgY2htb2QgfSBmcm9tICdmcyc7XG5pbXBvcnQgeyBwYXRoRm9yRG9tYWluLCBvcGVuc3NsQ29uZlBhdGggfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBvcGVuc3NsIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBmZXRjaENlcnRpZmljYXRlQXV0aG9yaXR5Q3JlZGVudGlhbHMgfSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQ6Y2VydGlmaWNhdGVzJyk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBkb21haW4gY2VydGlmaWNhdGUgc2lnbmVkIGJ5IHRoZSBkZXZjZXJ0IHJvb3QgQ0EuIERvbWFpblxuICogY2VydGlmaWNhdGVzIGFyZSBjYWNoZWQgaW4gdGhlaXIgb3duIGRpcmVjdG9yaWVzIHVuZGVyXG4gKiBDT05GSUdfUk9PVC9kb21haW5zLzxkb21haW4+LCBhbmQgcmV1c2VkIG9uIHN1YnNlcXVlbnQgcmVxdWVzdHMuIEJlY2F1c2UgdGhlXG4gKiBpbmRpdmlkdWFsIGRvbWFpbiBjZXJ0aWZpY2F0ZXMgYXJlIHNpZ25lZCBieSB0aGUgZGV2Y2VydCByb290IENBICh3aGljaCB3YXNcbiAqIGFkZGVkIHRvIHRoZSBPUy9icm93c2VyIHRydXN0IHN0b3JlcyksIHRoZXkgYXJlIHRydXN0ZWQuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlRG9tYWluQ2VydGlmaWNhdGUoZG9tYWluOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbWtkaXJwKHBhdGhGb3JEb21haW4oZG9tYWluKSk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgcHJpdmF0ZSBrZXkgZm9yICR7IGRvbWFpbiB9YCk7XG4gIGxldCBrZXlQYXRoID0gcGF0aEZvckRvbWFpbihkb21haW4sICdwcml2YXRlLWtleS5rZXknKTtcbiAgZ2VuZXJhdGVLZXkoa2V5UGF0aCk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0IGZvciAkeyBkb21haW4gfWApO1xuICBsZXQgY3NyRmlsZSA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgY2VydGlmaWNhdGUtc2lnbmluZy1yZXF1ZXN0LmNzcmApO1xuICBvcGVuc3NsKGByZXEgLWNvbmZpZyAkeyBvcGVuc3NsQ29uZlBhdGggfSAtc3ViaiBcIi9DTj0keyBkb21haW4gfVwiIC1rZXkgJHsga2V5UGF0aCB9IC1vdXQgJHsgY3NyRmlsZSB9IC1uZXdgKTtcblxuICBkZWJ1ZyhgR2VuZXJhdGluZyBjZXJ0aWZpY2F0ZSBmb3IgJHsgZG9tYWluIH0gZnJvbSBzaWduaW5nIHJlcXVlc3QgYW5kIHNpZ25pbmcgd2l0aCByb290IENBYCk7XG4gIGxldCBjZXJ0UGF0aCA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgY2VydGlmaWNhdGUuY3J0YCk7XG4gIGxldCB7IGRlY3J5cHRlZENBS2V5UGF0aCwgZGVjcnlwdGVkQ0FDZXJ0UGF0aCB9ID0gYXdhaXQgZmV0Y2hDZXJ0aWZpY2F0ZUF1dGhvcml0eUNyZWRlbnRpYWxzKCk7XG4gIG9wZW5zc2woYGNhIC1jb25maWcgJHsgb3BlbnNzbENvbmZQYXRoIH0gLWluICR7IGNzckZpbGUgfSAtb3V0ICR7IHBhdGguYmFzZW5hbWUoY2VydFBhdGgpIH0gLW91dGRpciAkeyBwYXRoLmRpcm5hbWUoY2VydFBhdGgpIH0gLWtleWZpbGUgJHsgZGVjcnlwdGVkQ0FLZXlQYXRoIH0gLWNlcnQgJHsgZGVjcnlwdGVkQ0FDZXJ0UGF0aCB9IC1ub3RleHQgLW1kIHNoYTI1NiAtZGF5cyA3MDAwIC1iYXRjaCAtZXh0ZW5zaW9ucyBzZXJ2ZXJfY2VydGApXG5cbiAgcm0oZGVjcnlwdGVkQ0FLZXlQYXRoKTtcbiAgcm0oZGVjcnlwdGVkQ0FDZXJ0UGF0aCk7XG59XG5cbi8vIEdlbmVyYXRlIGEgY3J5cHRvZ3JhcGhpYyBrZXksIHVzZWQgdG8gc2lnbiBjZXJ0aWZpY2F0ZXMgb3IgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0cy5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUtleShmaWxlbmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIGRlYnVnKGBnZW5lcmF0ZUtleTogJHsgZmlsZW5hbWUgfWApO1xuICBvcGVuc3NsKGBnZW5yc2EgLW91dCAkeyBmaWxlbmFtZSB9IDIwNDhgKTtcbiAgY2htb2QoZmlsZW5hbWUsIDQwMCk7XG59Il19 |
{ | ||
"name": "devcert", | ||
"version": "1.0.0-beta.10", | ||
"version": "1.0.0-beta.11", | ||
"description": "Generate trusted local SSL/TLS certificates for local SSL development", | ||
@@ -5,0 +5,0 @@ "main": "dist/index.js", |
@@ -84,4 +84,4 @@ import * as crypto from 'crypto'; | ||
let encryptionKey = await getPasswordFromUser(); | ||
writeFile(decryptedCAKeyPath , decrypt(encryptedCAKey, encryptionKey)); | ||
writeFile(decryptedCACertPath , decrypt(encryptedCACert, encryptionKey)); | ||
writeFile(decryptedCAKeyPath, decrypt(encryptedCAKey, encryptionKey)); | ||
writeFile(decryptedCACertPath, decrypt(encryptedCACert, encryptionKey)); | ||
return { decryptedCAKeyPath , decryptedCACertPath }; | ||
@@ -101,2 +101,3 @@ } | ||
return new Promise((resolve, reject) => { | ||
prompt.message = 'password'; | ||
prompt.start(); | ||
@@ -106,3 +107,3 @@ prompt.get({ | ||
password: { | ||
message: 'password:', | ||
message: '', | ||
hidden: true | ||
@@ -119,3 +120,3 @@ } | ||
let cipher = crypto.createCipher('aes256', key); | ||
return cipher.update(new Buffer(text)) + cipher.final('hex'); | ||
return cipher.update(text, 'utf8', 'hex') + cipher.final('hex'); | ||
} | ||
@@ -125,3 +126,3 @@ | ||
let decipher = crypto.createDecipher('aes256', key); | ||
return decipher.update(encrypted, 'hex') + decipher.final('utf8'); | ||
return decipher.update(encrypted, 'hex', 'utf8') + decipher.final('utf8'); | ||
} |
@@ -26,7 +26,7 @@ import * as path from 'path'; | ||
debug(`Generating certificate signing request for ${ domain }`); | ||
let csrFile = pathForDomain(domain, `${ domain }.csr`); | ||
let csrFile = pathForDomain(domain, `certificate-signing-request.csr`); | ||
openssl(`req -config ${ opensslConfPath } -subj "/CN=${ domain }" -key ${ keyPath } -out ${ csrFile } -new`); | ||
debug(`Generating certificate for ${ domain } from signing request and signing with root CA`); | ||
let certPath = pathForDomain(`${ domain }.crt`); | ||
let certPath = pathForDomain(domain, `certificate.crt`); | ||
let { decryptedCAKeyPath, decryptedCACertPath } = await fetchCertificateAuthorityCredentials(); | ||
@@ -33,0 +33,0 @@ 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`) |
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
211739
1446