You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
12 KiB
76 lines
12 KiB
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
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");
|
|
exports.VALID_IP = /(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}/;
|
|
exports.VALID_DOMAIN = /^(?:[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?\.?)+[a-z0-9][a-z0-9-]{0,61}[a-z0-9]$/i;
|
|
// 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);
|
|
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 withDomainSigningRequestConfig(domain, cb) {
|
|
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 });
|
|
fs_1.writeFileSync(tmpFile, eol_1.default.auto(result));
|
|
cb(tmpFile);
|
|
fs_1.unlinkSync(tmpFile);
|
|
}
|
|
exports.withDomainSigningRequestConfig = withDomainSigningRequestConfig;
|
|
function withDomainCertificateConfig(domain, cb) {
|
|
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({
|
|
domain,
|
|
serialFile: exports.opensslSerialFilePath,
|
|
databaseFile: exports.opensslDatabaseFilePath,
|
|
domainDir: exports.pathForDomain(domain)
|
|
});
|
|
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":"/Users/evanbacon/Documents/GitHub/devcert/","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 } from './utils';\n\nexport const VALID_IP = /(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}/;\nexport const VALID_DOMAIN = /^(?:[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?\\.?)+[a-z0-9][a-z0-9-]{0,61}[a-z0-9]$/i;\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\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\nexport function withDomainSigningRequestConfig(domain: string, cb: (filepath: string) => void) {\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 });\n  writeFile(tmpFile, eol.auto(result));\n  cb(tmpFile);\n  rm(tmpFile);\n}\n\nexport function withDomainCertificateConfig(domain: string, cb: (filepath: string) => void) {\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    domain,\n    serialFile: opensslSerialFilePath,\n    databaseFile: opensslDatabaseFilePath,\n    domainDir: pathForDomain(domain)\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"]}
|