thedesk/app/node_modules/electron-builder/out/cli/create-self-signed-cert.js

119 lines
3.5 KiB
JavaScript
Raw Normal View History

2019-09-13 00:38:13 +10:00
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.createSelfSignedCert = createSelfSignedCert;
function _builderUtil() {
const data = require("builder-util");
_builderUtil = function () {
return data;
};
return data;
}
function _fs() {
const data = require("builder-util/out/fs");
_fs = function () {
return data;
};
return data;
}
function _chalk() {
const data = _interopRequireDefault(require("chalk"));
_chalk = function () {
return data;
};
return data;
}
function _windowsCodeSign() {
const data = require("app-builder-lib/out/codeSign/windowsCodeSign");
_windowsCodeSign = function () {
return data;
};
return data;
}
function _fsExtra() {
const data = require("fs-extra");
_fsExtra = function () {
return data;
};
return data;
}
var path = _interopRequireWildcard(require("path"));
function _sanitizeFilename() {
const data = _interopRequireDefault(require("sanitize-filename"));
_sanitizeFilename = function () {
return data;
};
return data;
}
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/** @internal */
async function createSelfSignedCert(publisher) {
const tmpDir = new (_builderUtil().TmpDir)("create-self-signed-cert");
const targetDir = process.cwd();
const tempPrefix = path.join((await tmpDir.getTempDir({
prefix: "self-signed-cert-creator"
})), (0, _sanitizeFilename().default)(publisher));
const cer = `${tempPrefix}.cer`;
const pvk = `${tempPrefix}.pvk`;
_builderUtil().log.info(_chalk().default.bold('When asked to enter a password ("Create Private Key Password"), please select "None".'));
try {
await (0, _fsExtra().ensureDir)(path.dirname(tempPrefix));
const vendorPath = path.join((await (0, _windowsCodeSign().getSignVendorPath)()), "windows-10", process.arch);
await (0, _builderUtil().exec)(path.join(vendorPath, "makecert.exe"), ["-r", "-h", "0", "-n", `CN=${quoteString(publisher)}`, "-eku", "1.3.6.1.5.5.7.3.3", "-pe", "-sv", pvk, cer]);
const pfx = path.join(targetDir, `${(0, _sanitizeFilename().default)(publisher)}.pfx`);
await (0, _fs().unlinkIfExists)(pfx);
await (0, _builderUtil().exec)(path.join(vendorPath, "pvk2pfx.exe"), ["-pvk", pvk, "-spc", cer, "-pfx", pfx]);
_builderUtil().log.info({
file: pfx
}, `created. Please see https://electron.build/code-signing how to use it to sign.`);
const certLocation = "Cert:\\LocalMachine\\TrustedPeople";
_builderUtil().log.info({
file: pfx,
certLocation
}, `importing. Operation will be succeed only if runned from root. Otherwise import file manually.`);
await (0, _builderUtil().spawn)("powershell.exe", ["-NoProfile", "-NonInteractive", "-Command", "Import-PfxCertificate", "-FilePath", `"${pfx}"`, "-CertStoreLocation", ""]);
} finally {
await tmpDir.cleanup();
}
}
function quoteString(s) {
if (!s.includes(",") && !s.includes('"')) {
return s;
}
return `"${s.replace(/"/g, '\\"')}"`;
}
// __ts-babel@6.0.4
//# sourceMappingURL=create-self-signed-cert.js.map