npmci/ts/npmci.ssh.ts

51 lines
1.5 KiB
TypeScript
Raw Permalink Normal View History

2016-11-24 23:21:40 +01:00
import * as plugins from './npmci.plugins'
2016-06-23 22:22:03 +02:00
2016-06-25 18:53:35 +02:00
let sshRegex = /^(.*)\|(.*)\|(.*)/
2016-11-24 23:21:40 +01:00
let sshInstance: plugins.smartssh.SshInstance
2016-06-24 02:54:55 +02:00
/**
* checks for ENV vars in form of NPMCI_SSHKEY_* and deploys any found ones
*/
2016-06-23 22:22:03 +02:00
export let ssh = () => {
2016-11-24 23:21:40 +01:00
let done = plugins.q.defer()
sshInstance = new plugins.smartssh.SshInstance() // init ssh instance
plugins.smartparam.forEachMinimatch(process.env,'NPMCI_SSHKEY_*',evaluateSshEnv)
if (!process.env.NPMTS_TEST) {
sshInstance.writeToDisk()
2016-06-26 02:17:17 +02:00
} 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
};
2016-11-24 23:21:40 +01:00
done.resolve()
return done.promise
}
2016-06-23 22:22:03 +02:00
/**
* gets called for each found SSH ENV Var and deploys it
*/
2016-06-25 16:29:06 +02:00
let evaluateSshEnv = (sshkeyEnvVarArg) => {
2016-11-24 23:21:40 +01:00
let resultArray = sshRegex.exec(sshkeyEnvVarArg)
let sshKey = new plugins.smartssh.SshKey()
plugins.beautylog.info('Found SSH identity for ' + resultArray[1])
if (notUndefined(resultArray[1])) {
plugins.beautylog.log('---> host defined!')
sshKey.host = resultArray[1]
2016-06-26 02:17:17 +02:00
}
2016-11-24 23:21:40 +01:00
if (notUndefined(resultArray[2])) {
plugins.beautylog.log('---> privKey defined!')
sshKey.privKeyBase64 = resultArray[2]
2016-06-26 02:17:17 +02:00
};
2016-11-24 23:21:40 +01:00
if (notUndefined(resultArray[3])) {
'---> pubKey defined!'
sshKey.pubKeyBase64 = resultArray[3]
2016-06-26 02:17:17 +02:00
};
2016-11-24 23:21:40 +01:00
sshInstance.addKey(sshKey)
}
2016-06-25 18:53:35 +02:00
/**
* checks if not undefined
*/
2016-11-24 23:21:40 +01:00
let notUndefined = (stringArg: string) => {
return (stringArg && stringArg !== 'undefined' && stringArg !== '##')
}