npmci/ts/npmci.cli.ts

124 lines
2.5 KiB
TypeScript
Raw Normal View History

2018-04-04 20:25:13 +00:00
import * as plugins from './npmci.plugins';
import * as paths from './npmci.paths';
import * as npmciMonitor from './npmci.monitor';
npmciMonitor.run();
2017-09-08 12:58:44 +00:00
// Get Info about npmci itself
2018-04-04 20:25:13 +00:00
let npmciInfo = new plugins.projectinfo.ProjectinfoNpm(paths.NpmciPackageRoot);
plugins.beautylog.log('npmci version: ' + npmciInfo.version);
2017-05-18 20:40:09 +00:00
2018-04-04 20:25:13 +00:00
import * as NpmciEnv from './npmci.env';
2017-05-18 20:40:09 +00:00
2018-04-04 20:25:13 +00:00
import * as npmciMods from './npmci.mods';
2017-05-18 20:40:09 +00:00
2018-05-04 13:58:11 +00:00
const npmciSmartcli = new plugins.smartcli.Smartcli();
npmciSmartcli.addVersion(npmciInfo.version);
2017-05-18 20:40:09 +00:00
// clean
npmciSmartcli.addCommand('clean').subscribe(
async argv => {
2018-04-04 20:25:13 +00:00
let modClean = await npmciMods.modClean.load();
await modClean.clean();
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
process.exit(1);
}
);
2017-05-18 20:40:09 +00:00
2017-08-27 13:24:17 +00:00
// cloudflare
npmciSmartcli.addCommand('cloudflare').subscribe(
async argvArg => {
2018-04-04 20:25:13 +00:00
let modPurge = await npmciMods.modCloudflare.load();
await modPurge.handleCli(argvArg);
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
}
);
2017-08-27 13:24:17 +00:00
2017-05-18 20:40:09 +00:00
// command
npmciSmartcli.addCommand('command').subscribe(
async argv => {
2018-04-04 20:25:13 +00:00
let modCommand = await npmciMods.modCommand.load();
await modCommand.command();
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
process.exit(1);
}
);
2017-05-18 20:40:09 +00:00
2017-09-08 12:58:44 +00:00
// command
npmciSmartcli.addCommand('git').subscribe(
async argvArg => {
2018-04-04 20:25:13 +00:00
let modGit = await npmciMods.modGit.load();
await modGit.handleCli(argvArg);
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
process.exit(1);
}
);
2017-09-08 12:58:44 +00:00
2017-08-27 13:24:17 +00:00
// build
npmciSmartcli.addCommand('docker').subscribe(
async argvArg => {
2018-04-04 20:25:13 +00:00
let modDocker = await npmciMods.modDocker.load();
await modDocker.handleCli(argvArg);
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
process.exit(1);
}
);
2017-05-18 20:40:09 +00:00
2017-08-27 13:24:17 +00:00
// node
npmciSmartcli.addCommand('node').subscribe(
async argvArg => {
2018-04-04 20:25:13 +00:00
let modNode = await npmciMods.modNode.load();
await modNode.handleCli(argvArg);
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
2018-05-04 13:58:11 +00:00
process.exit(1);
}
);
2017-05-18 20:40:09 +00:00
2017-08-27 13:24:17 +00:00
// npm
npmciSmartcli.addCommand('npm').subscribe(
async argvArg => {
2018-04-04 20:25:13 +00:00
let modNpm = await npmciMods.modNpm.load();
await modNpm.handleCli(argvArg);
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
}
);
2017-05-18 20:40:09 +00:00
2017-08-27 13:24:17 +00:00
// trigger
npmciSmartcli.addCommand('ssh').subscribe(
async argvArg => {
2018-04-04 20:25:13 +00:00
let modSsh = await npmciMods.modSsh.load();
await modSsh.handleCli(argvArg);
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
process.exit(1);
}
);
2017-05-18 20:40:09 +00:00
// trigger
npmciSmartcli.addCommand('trigger').subscribe(
async argv => {
2018-04-04 20:25:13 +00:00
let modTrigger = await npmciMods.modTrigger.load();
await modTrigger.trigger();
},
err => {
2018-04-04 20:25:13 +00:00
console.log(err);
process.exit(1);
}
);
2017-05-18 20:40:09 +00:00
2018-05-04 13:58:11 +00:00
npmciSmartcli.startParse();