Comparing version 1.0.0-beta.5 to 1.0.0-beta.6
@@ -0,2 +1,9 @@ | ||
/** | ||
* Generate a domain certificate signed by the devcert root CA. Domain | ||
* certificates are cached in their own directories under | ||
* CONFIG_ROOT/domains/<domain>, and reused on subsequent requests. Because the | ||
* individual domain certificates are signed by the devcert root CA (which was | ||
* added to the OS/browser trust stores), they are trusted. | ||
*/ | ||
export default function generateDomainCertificate(domain: string): Promise<void>; | ||
export declare function generateKey(filename: string): void; |
@@ -6,2 +6,3 @@ "use strict"; | ||
const createDebug = require("debug"); | ||
const mkdirp_1 = require("mkdirp"); | ||
const fs_1 = require("fs"); | ||
@@ -12,5 +13,12 @@ const constants_1 = require("./constants"); | ||
const debug = createDebug('devcert:certificates'); | ||
// Generate an app certificate signed by the devcert root CA | ||
/** | ||
* Generate a domain certificate signed by the devcert root CA. Domain | ||
* certificates are cached in their own directories under | ||
* CONFIG_ROOT/domains/<domain>, and reused on subsequent requests. Because the | ||
* individual domain certificates are signed by the devcert root CA (which was | ||
* added to the OS/browser trust stores), they are trusted. | ||
*/ | ||
function generateDomainCertificate(domain) { | ||
return tslib_1.__awaiter(this, void 0, void 0, function* () { | ||
mkdirp_1.sync(constants_1.pathForDomain(domain)); | ||
debug(`Generating private key for ${domain}`); | ||
@@ -38,2 +46,2 @@ let keyPath = constants_1.pathForDomain(domain, 'private-key.key'); | ||
exports.generateKey = generateKey; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VydGlmaWNhdGVzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjZXJ0aWZpY2F0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkJBQTZCO0FBQzdCLHFDQUFxQztBQUNyQywyQkFBMEQ7QUFDMUQsMkNBQTZEO0FBQzdELG1DQUFrQztBQUNsQyxtRUFBK0U7QUFFL0UsTUFBTSxLQUFLLEdBQUcsV0FBVyxDQUFDLHNCQUFzQixDQUFDLENBQUM7QUFFbEQsNERBQTREO0FBQzVELG1DQUF3RCxNQUFjOztRQUNwRSxLQUFLLENBQUMsOEJBQStCLE1BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEQsSUFBSSxPQUFPLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztRQUN2RCxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFckIsS0FBSyxDQUFDLDhDQUErQyxNQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ2hFLElBQUksT0FBTyxHQUFHLHlCQUFhLENBQUMsTUFBTSxFQUFFLEdBQUksTUFBTyxNQUFNLENBQUMsQ0FBQztRQUN2RCxlQUFPLENBQUMsZUFBZ0IsMkJBQWdCLGVBQWdCLE1BQU8sVUFBVyxPQUFRLFNBQVUsT0FBUSxPQUFPLENBQUMsQ0FBQztRQUU3RyxLQUFLLENBQUMsOEJBQStCLE1BQU8sZ0RBQWdELENBQUMsQ0FBQztRQUM5RixJQUFJLFFBQVEsR0FBRyx5QkFBYSxDQUFDLEdBQUksTUFBTyxNQUFNLENBQUMsQ0FBQztRQUNoRCxJQUFJLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxHQUFHLE1BQU0sNERBQW9DLEVBQUUsQ0FBQztRQUNqRixlQUFPLENBQUMsY0FBZSwyQkFBZ0IsUUFBUyxPQUFRLFNBQVUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUUsWUFBYSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBRSxhQUFjLFdBQVksVUFBVyxZQUFhLCtEQUErRCxDQUFDLENBQUE7UUFFaFAsZUFBRSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2hCLGVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNuQixDQUFDO0NBQUE7QUFoQkQsNENBZ0JDO0FBRUQsMkZBQTJGO0FBQzNGLHFCQUE0QixRQUFnQjtJQUMxQyxLQUFLLENBQUMsZ0JBQWlCLFFBQVMsRUFBRSxDQUFDLENBQUM7SUFDcEMsZUFBTyxDQUFDLGVBQWdCLFFBQVMsT0FBTyxDQUFDLENBQUM7SUFDMUMsY0FBSyxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsQ0FBQztBQUN2QixDQUFDO0FBSkQsa0NBSUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0ICogYXMgY3JlYXRlRGVidWcgZnJvbSAnZGVidWcnO1xuaW1wb3J0IHsgdW5saW5rU3luYyBhcyBybSwgY2htb2RTeW5jIGFzIGNobW9kIH0gZnJvbSAnZnMnO1xuaW1wb3J0IHsgcGF0aEZvckRvbWFpbiwgb3BlbnNzbENvbmZQYXRoIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgb3BlbnNzbCB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHsgZmV0Y2hDZXJ0aWZpY2F0ZUF1dGhvcml0eUNyZWRlbnRpYWxzIH0gZnJvbSAnLi9jZXJ0aWZpY2F0ZS1hdXRob3JpdHknO1xuXG5jb25zdCBkZWJ1ZyA9IGNyZWF0ZURlYnVnKCdkZXZjZXJ0OmNlcnRpZmljYXRlcycpO1xuXG4vLyBHZW5lcmF0ZSBhbiBhcHAgY2VydGlmaWNhdGUgc2lnbmVkIGJ5IHRoZSBkZXZjZXJ0IHJvb3QgQ0FcbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlRG9tYWluQ2VydGlmaWNhdGUoZG9tYWluOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgZGVidWcoYEdlbmVyYXRpbmcgcHJpdmF0ZSBrZXkgZm9yICR7IGRvbWFpbiB9YCk7XG4gIGxldCBrZXlQYXRoID0gcGF0aEZvckRvbWFpbihkb21haW4sICdwcml2YXRlLWtleS5rZXknKTtcbiAgZ2VuZXJhdGVLZXkoa2V5UGF0aCk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0IGZvciAkeyBkb21haW4gfWApO1xuICBsZXQgY3NyRmlsZSA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgJHsgZG9tYWluIH0uY3NyYCk7XG4gIG9wZW5zc2woYHJlcSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1zdWJqIFwiL0NOPSR7IGRvbWFpbiB9XCIgLWtleSAkeyBrZXlQYXRoIH0gLW91dCAkeyBjc3JGaWxlIH0gLW5ld2ApO1xuXG4gIGRlYnVnKGBHZW5lcmF0aW5nIGNlcnRpZmljYXRlIGZvciAkeyBkb21haW4gfSBmcm9tIHNpZ25pbmcgcmVxdWVzdCBhbmQgc2lnbmluZyB3aXRoIHJvb3QgQ0FgKTtcbiAgbGV0IGNlcnRQYXRoID0gcGF0aEZvckRvbWFpbihgJHsgZG9tYWluIH0uY3J0YCk7XG4gIGxldCB7IHJvb3RLZXlQYXRoLCByb290Q2VydFBhdGggfSA9IGF3YWl0IGZldGNoQ2VydGlmaWNhdGVBdXRob3JpdHlDcmVkZW50aWFscygpO1xuICBvcGVuc3NsKGBjYSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1pbiAkeyBjc3JGaWxlIH0gLW91dCAkeyBwYXRoLmJhc2VuYW1lKGNlcnRQYXRoKSB9IC1vdXRkaXIgJHsgcGF0aC5kaXJuYW1lKGNlcnRQYXRoKSB9IC1rZXlmaWxlICR7IHJvb3RLZXlQYXRoIH0gLWNlcnQgJHsgcm9vdENlcnRQYXRoIH0gLW5vdGV4dCAtbWQgc2hhMjU2IC1kYXlzIDcwMDAgLWJhdGNoIC1leHRlbnNpb25zIHNlcnZlcl9jZXJ0YClcblxuICBybShyb290S2V5UGF0aCk7XG4gIHJtKHJvb3RDZXJ0UGF0aCk7XG59XG5cbi8vIEdlbmVyYXRlIGEgY3J5cHRvZ3JhcGhpYyBrZXksIHVzZWQgdG8gc2lnbiBjZXJ0aWZpY2F0ZXMgb3IgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0cy5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUtleShmaWxlbmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIGRlYnVnKGBnZW5lcmF0ZUtleTogJHsgZmlsZW5hbWUgfWApO1xuICBvcGVuc3NsKGBnZW5yc2EgLW91dCAkeyBmaWxlbmFtZSB9IDIwNDhgKTtcbiAgY2htb2QoZmlsZW5hbWUsIDQwMCk7XG59Il19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VydGlmaWNhdGVzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjZXJ0aWZpY2F0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkJBQTZCO0FBQzdCLHFDQUFxQztBQUNyQyxtQ0FBd0M7QUFDeEMsMkJBQTBEO0FBQzFELDJDQUE2RDtBQUM3RCxtQ0FBa0M7QUFDbEMsbUVBQStFO0FBRS9FLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0FBRWxEOzs7Ozs7R0FNRztBQUNILG1DQUF3RCxNQUFjOztRQUNwRSxhQUFNLENBQUMseUJBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTlCLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxFQUFFLENBQUMsQ0FBQztRQUNoRCxJQUFJLE9BQU8sR0FBRyx5QkFBYSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3ZELFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVyQixLQUFLLENBQUMsOENBQStDLE1BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEUsSUFBSSxPQUFPLEdBQUcseUJBQWEsQ0FBQyxNQUFNLEVBQUUsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZELGVBQU8sQ0FBQyxlQUFnQiwyQkFBZ0IsZUFBZ0IsTUFBTyxVQUFXLE9BQVEsU0FBVSxPQUFRLE9BQU8sQ0FBQyxDQUFDO1FBRTdHLEtBQUssQ0FBQyw4QkFBK0IsTUFBTyxnREFBZ0QsQ0FBQyxDQUFDO1FBQzlGLElBQUksUUFBUSxHQUFHLHlCQUFhLENBQUMsR0FBSSxNQUFPLE1BQU0sQ0FBQyxDQUFDO1FBQ2hELElBQUksRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLEdBQUcsTUFBTSw0REFBb0MsRUFBRSxDQUFDO1FBQ2pGLGVBQU8sQ0FBQyxjQUFlLDJCQUFnQixRQUFTLE9BQVEsU0FBVSxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBRSxZQUFhLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFFLGFBQWMsV0FBWSxVQUFXLFlBQWEsK0RBQStELENBQUMsQ0FBQTtRQUVoUCxlQUFFLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDaEIsZUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ25CLENBQUM7Q0FBQTtBQWxCRCw0Q0FrQkM7QUFFRCwyRkFBMkY7QUFDM0YscUJBQTRCLFFBQWdCO0lBQzFDLEtBQUssQ0FBQyxnQkFBaUIsUUFBUyxFQUFFLENBQUMsQ0FBQztJQUNwQyxlQUFPLENBQUMsZUFBZ0IsUUFBUyxPQUFPLENBQUMsQ0FBQztJQUMxQyxjQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUM7QUFKRCxrQ0FJQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgKiBhcyBjcmVhdGVEZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgeyB1bmxpbmtTeW5jIGFzIHJtLCBjaG1vZFN5bmMgYXMgY2htb2QgfSBmcm9tICdmcyc7XG5pbXBvcnQgeyBwYXRoRm9yRG9tYWluLCBvcGVuc3NsQ29uZlBhdGggfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBvcGVuc3NsIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBmZXRjaENlcnRpZmljYXRlQXV0aG9yaXR5Q3JlZGVudGlhbHMgfSBmcm9tICcuL2NlcnRpZmljYXRlLWF1dGhvcml0eSc7XG5cbmNvbnN0IGRlYnVnID0gY3JlYXRlRGVidWcoJ2RldmNlcnQ6Y2VydGlmaWNhdGVzJyk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBkb21haW4gY2VydGlmaWNhdGUgc2lnbmVkIGJ5IHRoZSBkZXZjZXJ0IHJvb3QgQ0EuIERvbWFpblxuICogY2VydGlmaWNhdGVzIGFyZSBjYWNoZWQgaW4gdGhlaXIgb3duIGRpcmVjdG9yaWVzIHVuZGVyXG4gKiBDT05GSUdfUk9PVC9kb21haW5zLzxkb21haW4+LCBhbmQgcmV1c2VkIG9uIHN1YnNlcXVlbnQgcmVxdWVzdHMuIEJlY2F1c2UgdGhlXG4gKiBpbmRpdmlkdWFsIGRvbWFpbiBjZXJ0aWZpY2F0ZXMgYXJlIHNpZ25lZCBieSB0aGUgZGV2Y2VydCByb290IENBICh3aGljaCB3YXNcbiAqIGFkZGVkIHRvIHRoZSBPUy9icm93c2VyIHRydXN0IHN0b3JlcyksIHRoZXkgYXJlIHRydXN0ZWQuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlRG9tYWluQ2VydGlmaWNhdGUoZG9tYWluOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgbWtkaXJwKHBhdGhGb3JEb21haW4oZG9tYWluKSk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgcHJpdmF0ZSBrZXkgZm9yICR7IGRvbWFpbiB9YCk7XG4gIGxldCBrZXlQYXRoID0gcGF0aEZvckRvbWFpbihkb21haW4sICdwcml2YXRlLWtleS5rZXknKTtcbiAgZ2VuZXJhdGVLZXkoa2V5UGF0aCk7XG5cbiAgZGVidWcoYEdlbmVyYXRpbmcgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0IGZvciAkeyBkb21haW4gfWApO1xuICBsZXQgY3NyRmlsZSA9IHBhdGhGb3JEb21haW4oZG9tYWluLCBgJHsgZG9tYWluIH0uY3NyYCk7XG4gIG9wZW5zc2woYHJlcSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1zdWJqIFwiL0NOPSR7IGRvbWFpbiB9XCIgLWtleSAkeyBrZXlQYXRoIH0gLW91dCAkeyBjc3JGaWxlIH0gLW5ld2ApO1xuXG4gIGRlYnVnKGBHZW5lcmF0aW5nIGNlcnRpZmljYXRlIGZvciAkeyBkb21haW4gfSBmcm9tIHNpZ25pbmcgcmVxdWVzdCBhbmQgc2lnbmluZyB3aXRoIHJvb3QgQ0FgKTtcbiAgbGV0IGNlcnRQYXRoID0gcGF0aEZvckRvbWFpbihgJHsgZG9tYWluIH0uY3J0YCk7XG4gIGxldCB7IHJvb3RLZXlQYXRoLCByb290Q2VydFBhdGggfSA9IGF3YWl0IGZldGNoQ2VydGlmaWNhdGVBdXRob3JpdHlDcmVkZW50aWFscygpO1xuICBvcGVuc3NsKGBjYSAtY29uZmlnICR7IG9wZW5zc2xDb25mUGF0aCB9IC1pbiAkeyBjc3JGaWxlIH0gLW91dCAkeyBwYXRoLmJhc2VuYW1lKGNlcnRQYXRoKSB9IC1vdXRkaXIgJHsgcGF0aC5kaXJuYW1lKGNlcnRQYXRoKSB9IC1rZXlmaWxlICR7IHJvb3RLZXlQYXRoIH0gLWNlcnQgJHsgcm9vdENlcnRQYXRoIH0gLW5vdGV4dCAtbWQgc2hhMjU2IC1kYXlzIDcwMDAgLWJhdGNoIC1leHRlbnNpb25zIHNlcnZlcl9jZXJ0YClcblxuICBybShyb290S2V5UGF0aCk7XG4gIHJtKHJvb3RDZXJ0UGF0aCk7XG59XG5cbi8vIEdlbmVyYXRlIGEgY3J5cHRvZ3JhcGhpYyBrZXksIHVzZWQgdG8gc2lnbiBjZXJ0aWZpY2F0ZXMgb3IgY2VydGlmaWNhdGUgc2lnbmluZyByZXF1ZXN0cy5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUtleShmaWxlbmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIGRlYnVnKGBnZW5lcmF0ZUtleTogJHsgZmlsZW5hbWUgfWApO1xuICBvcGVuc3NsKGBnZW5yc2EgLW91dCAkeyBmaWxlbmFtZSB9IDIwNDhgKTtcbiAgY2htb2QoZmlsZW5hbWUsIDQwMCk7XG59Il19 |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const path = require("path"); | ||
const mkdirp = require("mkdirp"); | ||
const mkdirp_1 = require("mkdirp"); | ||
const applicationConfigPath = require("application-config-path"); | ||
@@ -18,4 +18,4 @@ // Platform shortcuts | ||
exports.rootCAInstalledFlagFilePath = exports.configPath('root-ca-installed'); | ||
mkdirp.sync(exports.configDir); | ||
mkdirp.sync(exports.domainsDir); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw2QkFBNkI7QUFDN0IsaUNBQWlDO0FBQ2pDLGlFQUFrRTtBQUVsRSxxQkFBcUI7QUFDUixRQUFBLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQztBQUN0QyxRQUFBLE9BQU8sR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUN2QyxRQUFBLFNBQVMsR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUV0RCxlQUFlO0FBQ0YsUUFBQSxTQUFTLEdBQUcscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDN0MsUUFBQSxVQUFVLEdBQTBDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxpQkFBUyxDQUFDLENBQUM7QUFFcEYsUUFBQSxVQUFVLEdBQUcsa0JBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUNuQyxRQUFBLGFBQWEsR0FBMEQsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGtCQUFVLENBQUMsQ0FBQTtBQUV2RyxRQUFBLG1CQUFtQixHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxjQUFjLENBQUMsQ0FBQztBQUNqRSxRQUFBLGVBQWUsR0FBRyxrQkFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBRTdDLFFBQUEsMkJBQTJCLEdBQUcsa0JBQVUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0FBRTNFLE1BQU0sQ0FBQyxJQUFJLENBQUMsaUJBQVMsQ0FBQyxDQUFDO0FBQ3ZCLE1BQU0sQ0FBQyxJQUFJLENBQUMsa0JBQVUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCAqIGFzIG1rZGlycCBmcm9tICdta2RpcnAnO1xuaW1wb3J0IGFwcGxpY2F0aW9uQ29uZmlnUGF0aCA9IHJlcXVpcmUoJ2FwcGxpY2F0aW9uLWNvbmZpZy1wYXRoJyk7XG5cbi8vIFBsYXRmb3JtIHNob3J0Y3V0c1xuZXhwb3J0IGNvbnN0IGlzTWFjID0gcHJvY2Vzcy5wbGF0Zm9ybSA9PT0gJ2Rhcndpbic7XG5leHBvcnQgY29uc3QgaXNMaW51eCA9IHByb2Nlc3MucGxhdGZvcm0gPT09ICdsaW51eCc7XG5leHBvcnQgY29uc3QgaXNXaW5kb3dzID0gcHJvY2Vzcy5wbGF0Zm9ybSA9PT0gJ3dpbjMyJztcblxuLy8gQ29tbW9uIHBhdGhzXG5leHBvcnQgY29uc3QgY29uZmlnRGlyID0gYXBwbGljYXRpb25Db25maWdQYXRoKCdkZXZjZXJ0Jyk7XG5leHBvcnQgY29uc3QgY29uZmlnUGF0aDogKC4uLnBhdGhTZWdtZW50czogc3RyaW5nW10pID0+IHN0cmluZyA9IHBhdGguam9pbi5iaW5kKHBhdGgsIGNvbmZpZ0Rpcik7XG5cbmV4cG9ydCBjb25zdCBkb21haW5zRGlyID0gY29uZmlnUGF0aCgnZG9tYWlucycpO1xuZXhwb3J0IGNvbnN0IHBhdGhGb3JEb21haW46IChkb21haW46IHN0cmluZywgLi4ucGF0aFNlZ21lbnRzOiBzdHJpbmdbXSkgPT4gc3RyaW5nID0gcGF0aC5qb2luLmJpbmQocGF0aCwgZG9tYWluc0RpcilcblxuZXhwb3J0IGNvbnN0IG9wZW5zc2xDb25mVGVtcGxhdGUgPSBwYXRoLmpvaW4oX19kaXJuYW1lLCAnLi4nLCAnb3BlbnNzbC5jb25mJyk7XG5leHBvcnQgY29uc3Qgb3BlbnNzbENvbmZQYXRoID0gY29uZmlnUGF0aCgnb3BlbnNzbC5jb25mJyk7XG5cbmV4cG9ydCBjb25zdCByb290Q0FJbnN0YWxsZWRGbGFnRmlsZVBhdGggPSBjb25maWdQYXRoKCdyb290LWNhLWluc3RhbGxlZCcpO1xuXG5ta2RpcnAuc3luYyhjb25maWdEaXIpO1xubWtkaXJwLnN5bmMoZG9tYWluc0Rpcik7XG4iXX0= | ||
mkdirp_1.sync(exports.configDir); | ||
mkdirp_1.sync(exports.domainsDir); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9kYXcvb3NzL2RldmNlcnQvIiwic291cmNlcyI6WyJjb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw2QkFBNkI7QUFDN0IsbUNBQXdDO0FBQ3hDLGlFQUFrRTtBQUVsRSxxQkFBcUI7QUFDUixRQUFBLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQztBQUN0QyxRQUFBLE9BQU8sR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUN2QyxRQUFBLFNBQVMsR0FBRyxPQUFPLENBQUMsUUFBUSxLQUFLLE9BQU8sQ0FBQztBQUV0RCxlQUFlO0FBQ0YsUUFBQSxTQUFTLEdBQUcscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDN0MsUUFBQSxVQUFVLEdBQTBDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxpQkFBUyxDQUFDLENBQUM7QUFFcEYsUUFBQSxVQUFVLEdBQUcsa0JBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUNuQyxRQUFBLGFBQWEsR0FBMEQsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGtCQUFVLENBQUMsQ0FBQTtBQUV2RyxRQUFBLG1CQUFtQixHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxjQUFjLENBQUMsQ0FBQztBQUNqRSxRQUFBLGVBQWUsR0FBRyxrQkFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBRTdDLFFBQUEsMkJBQTJCLEdBQUcsa0JBQVUsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0FBRTNFLGFBQU0sQ0FBQyxpQkFBUyxDQUFDLENBQUM7QUFDbEIsYUFBTSxDQUFDLGtCQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBzeW5jIGFzIG1rZGlycCB9IGZyb20gJ21rZGlycCc7XG5pbXBvcnQgYXBwbGljYXRpb25Db25maWdQYXRoID0gcmVxdWlyZSgnYXBwbGljYXRpb24tY29uZmlnLXBhdGgnKTtcblxuLy8gUGxhdGZvcm0gc2hvcnRjdXRzXG5leHBvcnQgY29uc3QgaXNNYWMgPSBwcm9jZXNzLnBsYXRmb3JtID09PSAnZGFyd2luJztcbmV4cG9ydCBjb25zdCBpc0xpbnV4ID0gcHJvY2Vzcy5wbGF0Zm9ybSA9PT0gJ2xpbnV4JztcbmV4cG9ydCBjb25zdCBpc1dpbmRvd3MgPSBwcm9jZXNzLnBsYXRmb3JtID09PSAnd2luMzInO1xuXG4vLyBDb21tb24gcGF0aHNcbmV4cG9ydCBjb25zdCBjb25maWdEaXIgPSBhcHBsaWNhdGlvbkNvbmZpZ1BhdGgoJ2RldmNlcnQnKTtcbmV4cG9ydCBjb25zdCBjb25maWdQYXRoOiAoLi4ucGF0aFNlZ21lbnRzOiBzdHJpbmdbXSkgPT4gc3RyaW5nID0gcGF0aC5qb2luLmJpbmQocGF0aCwgY29uZmlnRGlyKTtcblxuZXhwb3J0IGNvbnN0IGRvbWFpbnNEaXIgPSBjb25maWdQYXRoKCdkb21haW5zJyk7XG5leHBvcnQgY29uc3QgcGF0aEZvckRvbWFpbjogKGRvbWFpbjogc3RyaW5nLCAuLi5wYXRoU2VnbWVudHM6IHN0cmluZ1tdKSA9PiBzdHJpbmcgPSBwYXRoLmpvaW4uYmluZChwYXRoLCBkb21haW5zRGlyKVxuXG5leHBvcnQgY29uc3Qgb3BlbnNzbENvbmZUZW1wbGF0ZSA9IHBhdGguam9pbihfX2Rpcm5hbWUsICcuLicsICdvcGVuc3NsLmNvbmYnKTtcbmV4cG9ydCBjb25zdCBvcGVuc3NsQ29uZlBhdGggPSBjb25maWdQYXRoKCdvcGVuc3NsLmNvbmYnKTtcblxuZXhwb3J0IGNvbnN0IHJvb3RDQUluc3RhbGxlZEZsYWdGaWxlUGF0aCA9IGNvbmZpZ1BhdGgoJ3Jvb3QtY2EtaW5zdGFsbGVkJyk7XG5cbm1rZGlycChjb25maWdEaXIpO1xubWtkaXJwKGRvbWFpbnNEaXIpO1xuIl19 |
@@ -25,7 +25,7 @@ "use strict"; | ||
if (fs_1.existsSync(path.join(potentialNSSDBDir, 'cert8.db'))) { | ||
debug(`Found legacy NSS database in ${potentialNSSDBDir}, adding devcert ...`); | ||
debug(`Found legacy NSS database in ${potentialNSSDBDir}, adding certificate ...`); | ||
utils_1.run(`${certutilPath} -A -d "${potentialNSSDBDir}" -t 'C,,' -i ${certPath} -n devcert`); | ||
} | ||
else if (fs_1.existsSync(path.join(potentialNSSDBDir, 'cert9.db'))) { | ||
debug(`Found modern NSS database in ${potentialNSSDBDir}, adding devcert ...`); | ||
debug(`Found modern NSS database in ${potentialNSSDBDir}, adding certificate ...`); | ||
utils_1.run(`${certutilPath} -A -d "sql:${potentialNSSDBDir}" -t 'C,,' -i ${certPath} -n devcert`); | ||
@@ -135,2 +135,2 @@ } | ||
exports.openCertificateInFirefox = openCertificateInFirefox; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared.js","sourceRoot":"/Users/daw/oss/devcert/","sources":["platforms/shared.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as createDebug from 'debug';\nimport * as assert from 'assert';\nimport * as getPort from 'get-port';\nimport * as http from 'http';\nimport { sync as glob } from 'glob';\nimport { readFileSync as readFile, existsSync as exists } from 'fs';\nimport { run, waitForUser } from '../utils';\nimport { isMac, isLinux } from '../constants';\nimport { execSync as exec } from 'child_process';\n\nconst debug = createDebug('devcert:platforms:shared');\n\n/**\n *  Given a directory or glob pattern of directories, attempt to install the\n *  CA certificate to each directory containing an NSS database.\n */\nexport async function addCertificateToNSSCertDB(nssDirGlob: string, certPath: string, certutilPath: string): Promise<void> {\n  debug(`trying to install certificate into NSS databases in ${ nssDirGlob }`);\n  glob(nssDirGlob).forEach((potentialNSSDBDir) => {\n    debug(`checking to see if ${ potentialNSSDBDir } is a valid NSS database directory`);\n    if (exists(path.join(potentialNSSDBDir, 'cert8.db'))) {\n      debug(`Found legacy NSS database in ${ potentialNSSDBDir }, adding devcert ...`)\n      run(`${ certutilPath } -A -d \"${ potentialNSSDBDir }\" -t 'C,,' -i ${ certPath } -n devcert`);\n    } else if (exists(path.join(potentialNSSDBDir, 'cert9.db'))) {\n      debug(`Found modern NSS database in ${ potentialNSSDBDir }, adding devcert ...`)\n      run(`${ certutilPath } -A -d \"sql:${ potentialNSSDBDir }\" -t 'C,,' -i ${ certPath } -n devcert`);\n    } else {\n      debug(`${ potentialNSSDBDir } doesn't look like an NSS database directory, skipping ...`);\n    }\n  });\n  debug(`finished scanning & installing certificate in NSS databases in ${ nssDirGlob }`);\n}\n\n/**\n *  Check to see if Firefox is still running, and if so, ask the user to close\n *  it. Poll until it's closed, then return.\n *\n * This is needed because Firefox appears to load the NSS database in-memory on\n * startup, and overwrite on exit. So we have to ask the user to quite Firefox\n * first so our changes don't get overwritten.\n */\nexport async function closeFirefox(): Promise<void> {\n  if (isFirefoxOpen()) {\n    console.log('Please close Firefox before continuing');\n    // LEFT OFF: this appears to not be looping properly\n    while(isFirefoxOpen()) {\n      await sleep(50);\n    }\n  }\n}\n\n/**\n * Check if Firefox is currently open\n */\nfunction isFirefoxOpen() {\n  // NOTE: We use some Windows-unfriendly methods here (ps) because Windows\n  // never needs to check this, because it doesn't update the NSS DB\n  // automaticaly.\n  assert(isMac || isLinux, 'checkForOpenFirefox was invoked on a platform other than Mac or Linux');\n  return exec('ps aux').indexOf('firefox') > -1;\n}\n\nasync function sleep(ms: number) {\n  return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\n/**\n * Firefox manages it's own trust store for SSL certificates, which can be\n * managed via the certutil command (supplied by NSS tooling packages). In the\n * event that certutil is not already installed, and either can't be installed\n * (Windows) or the user doesn't want to install it (skipCertutilInstall:\n * true), it means that we can't programmatically tell Firefox to trust our\n * root CA certificate.\n *\n * There is a recourse though. When a Firefox tab is directed to a URL that\n * responds with a certificate, it will automatically prompt the user if they\n * want to add it to their trusted certificates. So if we can't automatically\n * install the certificate via certutil, we instead start a quick web server\n * and host our certificate file. Then we open the hosted cert URL in Firefox\n * to kick off the GUI flow.\n *\n * This method does all this, along with providing user prompts in the terminal\n * to walk them through this process.\n */\nexport async function openCertificateInFirefox(firefoxPath: string, certPath: string): Promise<void> {\n  debug('Adding devert to Firefox trust stores manually. Launching a webserver to host our certificate temporarily ...');\n  let port = await getPort();\n  let server = http.createServer((req, res) => {\n    res.writeHead(200, { 'Content-type': 'application/x-x509-ca-cert' });\n    res.write(readFile(certPath));\n    res.end();\n  }).listen(port);\n  debug('Certificate server is up. Printing instructions for user and launching Firefox with hosted certificate URL');\n  console.log(`\n    devcert was unable to automatically configure Firefox. You'll need to\n    complete this process manually. Don't worry though - Firefox will walk\n    you through it.\n\n    When you're ready, hit any key to continue. Firefox will launch and\n    display a wizard to walk you through how to trust the devcert\n    certificate. When you are finished, come back here and we'll finish up.\n\n    (If Firefox doesn't start, go ahead and start it and navigate to\n    http://localhost:${ port } in a new tab.)\n\n    If you are curious about why all this is necessary, check out\n    https://github.com/davewasmer/devcert#how-it-works\n\n    <Press any key to launch Firefox wizard>\n  `);\n  run(`${ firefoxPath } http://localhost:${ port }`);\n  console.log(`\n    Launching Firefox ...\n\n    Great! Once you've finished the Firefox wizard for adding the devcert\n    certificate, just hit any key here again and we'll wrap up.\n\n    <Press any key to continue>\n  `)\n  await waitForUser();\n  server.close();\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared.js","sourceRoot":"/Users/daw/oss/devcert/","sources":["platforms/shared.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as createDebug from 'debug';\nimport * as assert from 'assert';\nimport * as getPort from 'get-port';\nimport * as http from 'http';\nimport { sync as glob } from 'glob';\nimport { readFileSync as readFile, existsSync as exists } from 'fs';\nimport { run, waitForUser } from '../utils';\nimport { isMac, isLinux } from '../constants';\nimport { execSync as exec } from 'child_process';\n\nconst debug = createDebug('devcert:platforms:shared');\n\n/**\n *  Given a directory or glob pattern of directories, attempt to install the\n *  CA certificate to each directory containing an NSS database.\n */\nexport async function addCertificateToNSSCertDB(nssDirGlob: string, certPath: string, certutilPath: string): Promise<void> {\n  debug(`trying to install certificate into NSS databases in ${ nssDirGlob }`);\n  glob(nssDirGlob).forEach((potentialNSSDBDir) => {\n    debug(`checking to see if ${ potentialNSSDBDir } is a valid NSS database directory`);\n    if (exists(path.join(potentialNSSDBDir, 'cert8.db'))) {\n      debug(`Found legacy NSS database in ${ potentialNSSDBDir }, adding certificate ...`)\n      run(`${ certutilPath } -A -d \"${ potentialNSSDBDir }\" -t 'C,,' -i ${ certPath } -n devcert`);\n    } else if (exists(path.join(potentialNSSDBDir, 'cert9.db'))) {\n      debug(`Found modern NSS database in ${ potentialNSSDBDir }, adding certificate ...`)\n      run(`${ certutilPath } -A -d \"sql:${ potentialNSSDBDir }\" -t 'C,,' -i ${ certPath } -n devcert`);\n    } else {\n      debug(`${ potentialNSSDBDir } doesn't look like an NSS database directory, skipping ...`);\n    }\n  });\n  debug(`finished scanning & installing certificate in NSS databases in ${ nssDirGlob }`);\n}\n\n/**\n *  Check to see if Firefox is still running, and if so, ask the user to close\n *  it. Poll until it's closed, then return.\n *\n * This is needed because Firefox appears to load the NSS database in-memory on\n * startup, and overwrite on exit. So we have to ask the user to quite Firefox\n * first so our changes don't get overwritten.\n */\nexport async function closeFirefox(): Promise<void> {\n  if (isFirefoxOpen()) {\n    console.log('Please close Firefox before continuing');\n    // LEFT OFF: this appears to not be looping properly\n    while(isFirefoxOpen()) {\n      await sleep(50);\n    }\n  }\n}\n\n/**\n * Check if Firefox is currently open\n */\nfunction isFirefoxOpen() {\n  // NOTE: We use some Windows-unfriendly methods here (ps) because Windows\n  // never needs to check this, because it doesn't update the NSS DB\n  // automaticaly.\n  assert(isMac || isLinux, 'checkForOpenFirefox was invoked on a platform other than Mac or Linux');\n  return exec('ps aux').indexOf('firefox') > -1;\n}\n\nasync function sleep(ms: number) {\n  return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\n/**\n * Firefox manages it's own trust store for SSL certificates, which can be\n * managed via the certutil command (supplied by NSS tooling packages). In the\n * event that certutil is not already installed, and either can't be installed\n * (Windows) or the user doesn't want to install it (skipCertutilInstall:\n * true), it means that we can't programmatically tell Firefox to trust our\n * root CA certificate.\n *\n * There is a recourse though. When a Firefox tab is directed to a URL that\n * responds with a certificate, it will automatically prompt the user if they\n * want to add it to their trusted certificates. So if we can't automatically\n * install the certificate via certutil, we instead start a quick web server\n * and host our certificate file. Then we open the hosted cert URL in Firefox\n * to kick off the GUI flow.\n *\n * This method does all this, along with providing user prompts in the terminal\n * to walk them through this process.\n */\nexport async function openCertificateInFirefox(firefoxPath: string, certPath: string): Promise<void> {\n  debug('Adding devert to Firefox trust stores manually. Launching a webserver to host our certificate temporarily ...');\n  let port = await getPort();\n  let server = http.createServer((req, res) => {\n    res.writeHead(200, { 'Content-type': 'application/x-x509-ca-cert' });\n    res.write(readFile(certPath));\n    res.end();\n  }).listen(port);\n  debug('Certificate server is up. Printing instructions for user and launching Firefox with hosted certificate URL');\n  console.log(`\n    devcert was unable to automatically configure Firefox. You'll need to\n    complete this process manually. Don't worry though - Firefox will walk\n    you through it.\n\n    When you're ready, hit any key to continue. Firefox will launch and\n    display a wizard to walk you through how to trust the devcert\n    certificate. When you are finished, come back here and we'll finish up.\n\n    (If Firefox doesn't start, go ahead and start it and navigate to\n    http://localhost:${ port } in a new tab.)\n\n    If you are curious about why all this is necessary, check out\n    https://github.com/davewasmer/devcert#how-it-works\n\n    <Press any key to launch Firefox wizard>\n  `);\n  run(`${ firefoxPath } http://localhost:${ port }`);\n  console.log(`\n    Launching Firefox ...\n\n    Great! Once you've finished the Firefox wizard for adding the devcert\n    certificate, just hit any key here again and we'll wrap up.\n\n    <Press any key to continue>\n  `)\n  await waitForUser();\n  server.close();\n}\n"]} |
{ | ||
"name": "devcert", | ||
"version": "1.0.0-beta.5", | ||
"version": "1.0.0-beta.6", | ||
"description": "Generate trusted local SSL/TLS certificates for local SSL development", | ||
@@ -5,0 +5,0 @@ "main": "dist/index.js", |
import * as path from 'path'; | ||
import * as createDebug from 'debug'; | ||
import { sync as mkdirp } from 'mkdirp'; | ||
import { unlinkSync as rm, chmodSync as chmod } from 'fs'; | ||
@@ -10,4 +11,12 @@ import { pathForDomain, opensslConfPath } from './constants'; | ||
// Generate an app certificate signed by the devcert root CA | ||
/** | ||
* Generate a domain certificate signed by the devcert root CA. Domain | ||
* certificates are cached in their own directories under | ||
* CONFIG_ROOT/domains/<domain>, and reused on subsequent requests. Because the | ||
* individual domain certificates are signed by the devcert root CA (which was | ||
* added to the OS/browser trust stores), they are trusted. | ||
*/ | ||
export default async function generateDomainCertificate(domain: string): Promise<void> { | ||
mkdirp(pathForDomain(domain)); | ||
debug(`Generating private key for ${ domain }`); | ||
@@ -14,0 +23,0 @@ let keyPath = pathForDomain(domain, 'private-key.key'); |
import * as path from 'path'; | ||
import * as mkdirp from 'mkdirp'; | ||
import { sync as mkdirp } from 'mkdirp'; | ||
import applicationConfigPath = require('application-config-path'); | ||
@@ -22,3 +22,3 @@ | ||
mkdirp.sync(configDir); | ||
mkdirp.sync(domainsDir); | ||
mkdirp(configDir); | ||
mkdirp(domainsDir); |
@@ -23,6 +23,6 @@ import * as path from 'path'; | ||
if (exists(path.join(potentialNSSDBDir, 'cert8.db'))) { | ||
debug(`Found legacy NSS database in ${ potentialNSSDBDir }, adding devcert ...`) | ||
debug(`Found legacy NSS database in ${ potentialNSSDBDir }, adding certificate ...`) | ||
run(`${ certutilPath } -A -d "${ potentialNSSDBDir }" -t 'C,,' -i ${ certPath } -n devcert`); | ||
} else if (exists(path.join(potentialNSSDBDir, 'cert9.db'))) { | ||
debug(`Found modern NSS database in ${ potentialNSSDBDir }, adding devcert ...`) | ||
debug(`Found modern NSS database in ${ potentialNSSDBDir }, adding certificate ...`) | ||
run(`${ certutilPath } -A -d "sql:${ potentialNSSDBDir }" -t 'C,,' -i ${ certPath } -n devcert`); | ||
@@ -29,0 +29,0 @@ } else { |
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
204074
1388