"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ensureConfigDirs = exports.getLegacyConfigDir = exports.rootCACertPath = exports.rootCAKeyPath = exports.rootCADir = exports.withDomainCertificateConfig = exports.withDomainSigningRequestConfig = exports.caSelfSignConfig = exports.opensslDatabaseFilePath = exports.opensslSerialFilePath = exports.caVersionFile = exports.pathForDomain = exports.domainsDir = exports.getStableDomainPath = exports.configPath = exports.configDir = exports.isWindows = exports.isLinux = exports.isMac = void 0; const tslib_1 = require("tslib"); const path_1 = tslib_1.__importDefault(require("path")); const fs_1 = require("fs"); const mkdirp_1 = require("mkdirp"); const lodash_1 = require("lodash"); const applicationConfigPath = require("application-config-path"); const eol_1 = tslib_1.__importDefault(require("eol")); const utils_1 = require("./utils"); // Platform shortcuts exports.isMac = process.platform === 'darwin'; exports.isLinux = process.platform === 'linux'; exports.isWindows = process.platform === 'win32'; // Common paths exports.configDir = applicationConfigPath('devcert'); exports.configPath = path_1.default.join.bind(path_1.default, exports.configDir); const getFilteredDomains = (domains) => Array.from(domains .sort((a, b) => b.length - a.length) .reduce((filteredList, domain) => Array.from(filteredList) .reduce((matches, item) => { if (item.indexOf(domain) > -1) { matches.add(domain); } else if (domain.indexOf(item) === -1 && item.indexOf(domain) === -1) { matches.add(item); matches.add(domain); } else { matches.add(item); } return matches; }, new Set()), new Set([domains[0]]))).sort(); const getStableDomainPath = (domains) => domains.length === 1 ? domains[0] : 'san-' + utils_1.numericHash(getFilteredDomains(domains).join('')); exports.getStableDomainPath = getStableDomainPath; exports.domainsDir = exports.configPath('domains'); exports.pathForDomain = path_1.default.join.bind(path_1.default, exports.domainsDir); exports.caVersionFile = exports.configPath('devcert-ca-version'); exports.opensslSerialFilePath = exports.configPath('certificate-authority', 'serial'); exports.opensslDatabaseFilePath = exports.configPath('certificate-authority', 'index.txt'); exports.caSelfSignConfig = path_1.default.join(__dirname, '../openssl-configurations/certificate-authority-self-signing.conf'); function generateSubjectAltNames(domains) { return domains .reduce((dnsEntries, domain) => dnsEntries.concat([ `DNS.${dnsEntries.length + 1} = ${domain}`, `DNS.${dnsEntries.length + 2} = *.${domain}`, ]), []) .join("\r\n"); } function withDomainSigningRequestConfig(domains, cb) { const domain = domains[0]; const subjectAltNames = generateSubjectAltNames(domains); let tmpFile = utils_1.mktmp(); let source = fs_1.readFileSync(path_1.default.join(__dirname, '../openssl-configurations/domain-certificate-signing-requests.conf'), 'utf-8'); let template = lodash_1.template(source); let result = template({ domain, subjectAltNames }); fs_1.writeFileSync(tmpFile, eol_1.default.auto(result)); cb(tmpFile); fs_1.unlinkSync(tmpFile); } exports.withDomainSigningRequestConfig = withDomainSigningRequestConfig; function withDomainCertificateConfig(domains, cb) { const domainPath = exports.getStableDomainPath(domains); const subjectAltNames = generateSubjectAltNames(domains); let tmpFile = utils_1.mktmp(); let source = fs_1.readFileSync(path_1.default.join(__dirname, '../openssl-configurations/domain-certificates.conf'), 'utf-8'); let template = lodash_1.template(source); let result = template({ subjectAltNames, serialFile: exports.opensslSerialFilePath, databaseFile: exports.opensslDatabaseFilePath, domainDir: exports.pathForDomain(domainPath) }); fs_1.writeFileSync(tmpFile, eol_1.default.auto(result)); cb(tmpFile); fs_1.unlinkSync(tmpFile); } exports.withDomainCertificateConfig = withDomainCertificateConfig; // confTemplate = confTemplate.replace(/DATABASE_PATH/, configPath('index.txt').replace(/\\/g, '\\\\')); // confTemplate = confTemplate.replace(/SERIAL_PATH/, configPath('serial').replace(/\\/g, '\\\\')); // confTemplate = eol.auto(confTemplate); exports.rootCADir = exports.configPath('certificate-authority'); exports.rootCAKeyPath = exports.configPath('certificate-authority', 'private-key.key'); exports.rootCACertPath = exports.configPath('certificate-authority', 'certificate.cert'); // Exposed for uninstallation purposes. function getLegacyConfigDir() { if (exports.isWindows && process.env.LOCALAPPDATA) { return path_1.default.join(process.env.LOCALAPPDATA, 'devcert', 'config'); } else { let uid = process.getuid && process.getuid(); let userHome = (exports.isLinux && uid === 0) ? path_1.default.resolve('/usr/local/share') : require('os').homedir(); return path_1.default.join(userHome, '.config', 'devcert'); } } exports.getLegacyConfigDir = getLegacyConfigDir; function ensureConfigDirs() { mkdirp_1.sync(exports.configDir); mkdirp_1.sync(exports.domainsDir); mkdirp_1.sync(exports.rootCADir); } exports.ensureConfigDirs = ensureConfigDirs; ensureConfigDirs(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"./","sources":["constants.ts"],"names":[],"mappings":"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","sourcesContent":["import path from 'path';\nimport { unlinkSync as rm, writeFileSync as writeFile, readFileSync as readFile } from 'fs';\nimport { sync as mkdirp } from 'mkdirp';\nimport { template as makeTemplate } from 'lodash';\nimport applicationConfigPath = require('application-config-path');\nimport eol from 'eol';\nimport {mktmp, numericHash} from './utils';\n\n// Platform shortcuts\nexport const isMac = process.platform === 'darwin';\nexport const isLinux = process.platform === 'linux';\nexport const isWindows = process.platform === 'win32';\n\n// Common paths\nexport const configDir = applicationConfigPath('devcert');\nexport const configPath: (...pathSegments: string[]) => string = path.join.bind(path, configDir);\n\nconst getFilteredDomains = (domains: string[]) =>\n  Array.from(\n    domains\n      .sort((a, b) => b.length - a.length)\n      .reduce((filteredList, domain) =>\n        Array.from(filteredList)\n          .reduce((matches, item) => {\n            if (item.indexOf(domain) > -1) {\n              matches.add(domain);\n            } else if (domain.indexOf(item) === -1 && item.indexOf(domain) === -1) {\n              matches.add(item);\n              matches.add(domain);\n            } else {\n              matches.add(item);\n            }\n\n            return matches;\n          }, new Set()\n          ), new Set([domains[0]])\n      )\n  ).sort();\n\nexport const getStableDomainPath = (domains: string[]) =>\n  domains.length === 1 ?\n    domains[0] :\n    'san-' + numericHash(getFilteredDomains(domains).join(''));\nexport const domainsDir = configPath('domains');\nexport const pathForDomain: (domain: string, ...pathSegments: string[]) => string = path.join.bind(path, domainsDir)\n\nexport const caVersionFile = configPath('devcert-ca-version');\nexport const opensslSerialFilePath = configPath('certificate-authority', 'serial');\nexport const opensslDatabaseFilePath = configPath('certificate-authority', 'index.txt');\nexport const caSelfSignConfig = path.join(__dirname, '../openssl-configurations/certificate-authority-self-signing.conf');\n\nfunction generateSubjectAltNames(domains: string[]): string {\n  return domains\n    .reduce((dnsEntries, domain) =>\n      dnsEntries.concat([\n        `DNS.${dnsEntries.length + 1} = ${domain}`,\n        `DNS.${dnsEntries.length + 2} = *.${domain}`,\n      ]), [] as string[])\n    .join(\"\\r\\n\");\n}\n\nexport function withDomainSigningRequestConfig(domains: string[], cb: (filepath: string) => void) {\n  const domain = domains[0];\n  const subjectAltNames = generateSubjectAltNames(domains);\n  let tmpFile = mktmp();\n  let source = readFile(path.join(__dirname, '../openssl-configurations/domain-certificate-signing-requests.conf'), 'utf-8');\n  let template = makeTemplate(source);\n  let result = template({domain, subjectAltNames});\n  writeFile(tmpFile, eol.auto(result));\n  cb(tmpFile);\n  rm(tmpFile);\n}\n\nexport function withDomainCertificateConfig(domains: string[], cb: (filepath: string) => void) {\n  const domainPath = getStableDomainPath(domains);\n  const subjectAltNames = generateSubjectAltNames(domains);\n  let tmpFile = mktmp();\n  let source = readFile(path.join(__dirname, '../openssl-configurations/domain-certificates.conf'), 'utf-8');\n  let template = makeTemplate(source);\n  let result = template({\n    subjectAltNames,\n    serialFile: opensslSerialFilePath,\n    databaseFile: opensslDatabaseFilePath,\n    domainDir: pathForDomain(domainPath)\n  });\n  writeFile(tmpFile, eol.auto(result));\n  cb(tmpFile);\n  rm(tmpFile);\n}\n\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\nexport const rootCADir = configPath('certificate-authority');\nexport const rootCAKeyPath = configPath('certificate-authority', 'private-key.key');\nexport const rootCACertPath = configPath('certificate-authority', 'certificate.cert');\n\n\n\n// Exposed for uninstallation purposes.\nexport function getLegacyConfigDir(): string {\n  if (isWindows && process.env.LOCALAPPDATA) {\n    return path.join(process.env.LOCALAPPDATA, 'devcert', 'config');\n  } else {\n    let uid = process.getuid && process.getuid();\n    let userHome = (isLinux && uid === 0) ? path.resolve('/usr/local/share') : require('os').homedir();\n    return path.join(userHome, '.config', 'devcert');\n  }\n}\n\nexport function ensureConfigDirs() {\n  mkdirp(configDir);\n  mkdirp(domainsDir);\n  mkdirp(rootCADir);\n}\n\nensureConfigDirs();\n"]}