2016-06-23 22:22:03 +02:00
|
|
|
"use strict";
|
2017-03-11 01:10:37 +01:00
|
|
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
|
|
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
|
|
});
|
|
|
|
};
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
2017-06-15 15:46:08 +02:00
|
|
|
const plugins = require("./mod.plugins");
|
2016-07-18 16:56:53 +02:00
|
|
|
let sshInstance;
|
2017-08-27 15:24:17 +02:00
|
|
|
exports.handleCli = (argvArg) => __awaiter(this, void 0, void 0, function* () {
|
|
|
|
if (argvArg._.length >= 2) {
|
|
|
|
let action = argvArg._[1];
|
|
|
|
switch (action) {
|
|
|
|
case 'prepare':
|
|
|
|
yield exports.prepare();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
plugins.beautylog.error(`action >>${action}<< not supported`);
|
2017-08-28 13:25:22 +02:00
|
|
|
process.exit(1);
|
2017-08-27 15:24:17 +02:00
|
|
|
}
|
|
|
|
}
|
2017-08-28 13:25:22 +02:00
|
|
|
else {
|
|
|
|
plugins.beautylog.error(`>>npmci ssh ...<< please specify an action!`);
|
|
|
|
process.exit(1);
|
|
|
|
}
|
2017-08-27 15:24:17 +02:00
|
|
|
});
|
2017-05-19 12:09:33 +02:00
|
|
|
/**
|
|
|
|
* checks if not undefined
|
|
|
|
*/
|
|
|
|
let notUndefined = (stringArg) => {
|
2018-04-04 22:25:13 +02:00
|
|
|
return stringArg && stringArg !== 'undefined' && stringArg !== '##';
|
2017-05-19 12:09:33 +02:00
|
|
|
};
|
2016-09-04 13:42:22 +02:00
|
|
|
/**
|
|
|
|
* checks for ENV vars in form of NPMCI_SSHKEY_* and deploys any found ones
|
|
|
|
*/
|
2017-08-27 15:24:17 +02:00
|
|
|
exports.prepare = () => __awaiter(this, void 0, void 0, function* () {
|
2016-09-04 13:42:22 +02:00
|
|
|
sshInstance = new plugins.smartssh.SshInstance(); // init ssh instance
|
2016-11-24 23:21:40 +01:00
|
|
|
plugins.smartparam.forEachMinimatch(process.env, 'NPMCI_SSHKEY_*', evaluateSshEnv);
|
2016-06-26 02:17:17 +02:00
|
|
|
if (!process.env.NPMTS_TEST) {
|
|
|
|
sshInstance.writeToDisk();
|
|
|
|
}
|
|
|
|
else {
|
2016-11-24 23:21:40 +01:00
|
|
|
plugins.beautylog.log('In test mode, so not storing SSH keys to disk!');
|
2016-06-26 02:17:17 +02:00
|
|
|
}
|
2017-03-11 01:10:37 +01:00
|
|
|
});
|
2016-09-04 13:42:22 +02:00
|
|
|
/**
|
|
|
|
* gets called for each found SSH ENV Var and deploys it
|
|
|
|
*/
|
2017-03-11 01:10:37 +01:00
|
|
|
let evaluateSshEnv = (sshkeyEnvVarArg) => __awaiter(this, void 0, void 0, function* () {
|
2017-08-27 15:24:17 +02:00
|
|
|
let sshEnvArray = sshkeyEnvVarArg.split('|');
|
2016-07-18 16:56:53 +02:00
|
|
|
let sshKey = new plugins.smartssh.SshKey();
|
2017-08-27 15:24:17 +02:00
|
|
|
plugins.beautylog.info('Found SSH identity for ' + sshEnvArray[1]);
|
|
|
|
if (notUndefined(sshEnvArray[0])) {
|
2016-11-24 23:21:40 +01:00
|
|
|
plugins.beautylog.log('---> host defined!');
|
2017-08-27 15:24:17 +02:00
|
|
|
sshKey.host = sshEnvArray[0];
|
2016-06-26 02:17:17 +02:00
|
|
|
}
|
2017-08-27 15:24:17 +02:00
|
|
|
if (notUndefined(sshEnvArray[1])) {
|
2016-11-24 23:21:40 +01:00
|
|
|
plugins.beautylog.log('---> privKey defined!');
|
2017-08-27 15:24:17 +02:00
|
|
|
sshKey.privKeyBase64 = sshEnvArray[1];
|
2016-06-26 02:17:17 +02:00
|
|
|
}
|
2017-08-27 15:24:17 +02:00
|
|
|
if (notUndefined(sshEnvArray[2])) {
|
2017-06-15 15:46:08 +02:00
|
|
|
plugins.beautylog.log('---> pubKey defined!');
|
2017-08-27 15:24:17 +02:00
|
|
|
sshKey.pubKeyBase64 = sshEnvArray[2];
|
2016-06-26 02:17:17 +02:00
|
|
|
}
|
2016-06-24 02:54:55 +02:00
|
|
|
sshInstance.addKey(sshKey);
|
2017-03-11 01:10:37 +01:00
|
|
|
return;
|
|
|
|
});
|
2018-04-04 22:25:13 +02:00
|
|
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90cy9tb2Rfc3NoL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQSx5Q0FBeUM7QUFDekMsSUFBSSxXQUF5QyxDQUFDO0FBRW5DLFFBQUEsU0FBUyxHQUFHLENBQU0sT0FBTyxFQUFDLEVBQUU7SUFDckMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxQixJQUFJLE1BQU0sR0FBVyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2xDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7WUFDZixLQUFLLFNBQVM7Z0JBQ1osTUFBTSxlQUFPLEVBQUUsQ0FBQztnQkFDaEIsS0FBSyxDQUFDO1lBQ1I7Z0JBQ0UsT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsWUFBWSxNQUFNLGtCQUFrQixDQUFDLENBQUM7Z0JBQzlELE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDcEIsQ0FBQztJQUNILENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNOLE9BQU8sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLDZDQUE2QyxDQUFDLENBQUM7UUFDdkUsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNsQixDQUFDO0FBQ0gsQ0FBQyxDQUFBLENBQUM7QUFFRjs7R0FFRztBQUNILElBQUksWUFBWSxHQUFHLENBQUMsU0FBaUIsRUFBRSxFQUFFO0lBQ3ZDLE1BQU0sQ0FBQyxTQUFTLElBQUksU0FBUyxLQUFLLFdBQVcsSUFBSSxTQUFTLEtBQUssSUFBSSxDQUFDO0FBQ3RFLENBQUMsQ0FBQztBQUVGOztHQUVHO0FBQ1EsUUFBQSxPQUFPLEdBQUcsR0FBUyxFQUFFO0lBQzlCLFdBQVcsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxvQkFBb0I7SUFDdEUsT0FBTyxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLGdCQUFnQixFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQ25GLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQzVCLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDTixPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0lBQzFFLENBQUM7QUFDSCxDQUFDLENBQUEsQ0FBQztBQUVGOztHQUVHO0FBQ0gsSUFBSSxjQUFjLEdBQUcsQ0FBTyxlQUF1QixFQUFFLEVBQUU7SUFDckQsSUFBSSxXQUFXLEdBQUcsZUFBZSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3QyxJQUFJLE1BQU0sR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDM0MsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMseUJBQXlCLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbkUsRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNqQyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBQzVDLE1BQU0sQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFDRCxFQUFFLENBQUMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pDLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDL0MsTUFBTSxDQUFDLGFBQWEsR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUNELEVBQUUsQ0FBQyxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDakMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsc0JBQXNCLENBQUMsQ0FBQztRQUM5QyxNQUFNLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsV0FBVyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMzQixNQUFNLENBQUM7QUFDVCxDQUFDLENBQUEsQ0FBQyJ9
|