test
This commit is contained in:
parent
09c7dae079
commit
299d2567f8
8
dist/index.d.ts
vendored
8
dist/index.d.ts
vendored
@ -1,4 +1,4 @@
|
|||||||
import "typings-global";
|
import 'typings-global';
|
||||||
export { build } from "./npmci.build";
|
export { build } from './npmci.build';
|
||||||
export { install } from "./npmci.install";
|
export { install } from './npmci.install';
|
||||||
export { publish } from "./npmci.publish";
|
export { publish } from './npmci.publish';
|
||||||
|
20
dist/index.js
vendored
20
dist/index.js
vendored
@ -4,7 +4,7 @@ require("typings-global");
|
|||||||
const plugins = require("./npmci.plugins");
|
const plugins = require("./npmci.plugins");
|
||||||
const paths = require("./npmci.paths");
|
const paths = require("./npmci.paths");
|
||||||
let npmciInfo = new plugins.projectinfo.ProjectinfoNpm(paths.NpmciPackageRoot);
|
let npmciInfo = new plugins.projectinfo.ProjectinfoNpm(paths.NpmciPackageRoot);
|
||||||
plugins.beautylog.log("npmci version: " + npmciInfo.version);
|
plugins.beautylog.log('npmci version: ' + npmciInfo.version);
|
||||||
const npmci_build_1 = require("./npmci.build");
|
const npmci_build_1 = require("./npmci.build");
|
||||||
const npmci_clean_1 = require("./npmci.clean");
|
const npmci_clean_1 = require("./npmci.clean");
|
||||||
const npmci_command_1 = require("./npmci.command");
|
const npmci_command_1 = require("./npmci.command");
|
||||||
@ -24,58 +24,58 @@ let smartcli = new plugins.smartcli.Smartcli();
|
|||||||
smartcli.addVersion(npmciInfo.version);
|
smartcli.addVersion(npmciInfo.version);
|
||||||
// build
|
// build
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "build"
|
commandName: 'build'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_build_1.build(argv._[1])
|
npmci_build_1.build(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// clean
|
// clean
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "clean"
|
commandName: 'clean'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_clean_1.clean()
|
npmci_clean_1.clean()
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// command
|
// command
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "command"
|
commandName: 'command'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_command_1.command()
|
npmci_command_1.command()
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// install
|
// install
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "install"
|
commandName: 'install'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_install_1.install(argv._[1])
|
npmci_install_1.install(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// prepare
|
// prepare
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "prepare"
|
commandName: 'prepare'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_prepare_1.prepare(argv._[1])
|
npmci_prepare_1.prepare(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// publish
|
// publish
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "publish"
|
commandName: 'publish'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_publish_1.publish(argv._[1])
|
npmci_publish_1.publish(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// test
|
// test
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "test"
|
commandName: 'test'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_test_1.test(argv._[1])
|
npmci_test_1.test(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore);
|
||||||
});
|
});
|
||||||
// trigger
|
// trigger
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName: "trigger"
|
commandName: 'trigger'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
npmci_trigger_1.trigger();
|
npmci_trigger_1.trigger();
|
||||||
});
|
});
|
||||||
smartcli.startParse();
|
smartcli.startParse();
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFDM0MsdUNBQXVDO0FBQ3ZDLElBQUksU0FBUyxHQUFHLElBQUksT0FBTyxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7QUFDL0UsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBRTdELCtDQUFtQztBQUNuQywrQ0FBb0M7QUFDcEMsbURBQXdDO0FBQ3hDLG1EQUF3QztBQUN4QyxtREFBd0M7QUFDeEMsbURBQXdDO0FBQ3hDLDZDQUFrQztBQUNsQyxtREFBd0M7QUFDeEMsd0NBQXdDO0FBRXhDLDZDQUFtQztBQUEzQiw4QkFBQSxLQUFLLENBQUE7QUFDYixpREFBd0M7QUFBaEMsa0NBQUEsT0FBTyxDQUFBO0FBQ2YsaURBQXdDO0FBQWhDLGtDQUFBLE9BQU8sQ0FBQTtBQUdmLElBQUksUUFBUSxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztBQUMvQyxRQUFRLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUV2QyxRQUFRO0FBQ1IsUUFBUSxDQUFDLFVBQVUsQ0FBQztJQUNoQixXQUFXLEVBQUMsT0FBTztDQUN0QixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSTtJQUNULG1CQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUNYLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7QUFDcEMsQ0FBQyxDQUFDLENBQUM7QUFFSCxRQUFRO0FBQ1IsUUFBUSxDQUFDLFVBQVUsQ0FBQztJQUNoQixXQUFXLEVBQUMsT0FBTztDQUN0QixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSTtJQUNULG1CQUFLLEVBQUU7U0FDRixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3BDLENBQUMsQ0FBQyxDQUFDO0FBRUgsVUFBVTtBQUNWLFFBQVEsQ0FBQyxVQUFVLENBQUM7SUFDaEIsV0FBVyxFQUFDLFNBQVM7Q0FDeEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUk7SUFDVCx1QkFBTyxFQUFFO1NBQ0osSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNwQyxDQUFDLENBQUMsQ0FBQztBQUVILFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBQyxTQUFTO0NBQ3hCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNwQyxDQUFDLENBQUMsQ0FBQztBQUVILFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBQyxTQUFTO0NBQ3hCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNwQyxDQUFDLENBQUMsQ0FBQztBQUVILFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBQyxTQUFTO0NBQ3hCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNwQyxDQUFDLENBQUMsQ0FBQztBQUVILE9BQU87QUFDUCxRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBQyxNQUFNO0NBQ3JCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsaUJBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ1YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNwQyxDQUFDLENBQUMsQ0FBQztBQUVILFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBQyxTQUFTO0NBQ3hCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sRUFBRSxDQUFDO0FBQ2QsQ0FBQyxDQUFDLENBQUM7QUFFSCxRQUFRLENBQUMsVUFBVSxFQUFFLENBQUMifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFDMUMsdUNBQXNDO0FBQ3RDLElBQUksU0FBUyxHQUFHLElBQUksT0FBTyxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUE7QUFDOUUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFBO0FBRTVELCtDQUFtQztBQUNuQywrQ0FBbUM7QUFDbkMsbURBQXVDO0FBQ3ZDLG1EQUF1QztBQUN2QyxtREFBdUM7QUFDdkMsbURBQXVDO0FBQ3ZDLDZDQUFpQztBQUNqQyxtREFBdUM7QUFDdkMsd0NBQXVDO0FBRXZDLDZDQUFtQztBQUEzQiw4QkFBQSxLQUFLLENBQUE7QUFDYixpREFBd0M7QUFBaEMsa0NBQUEsT0FBTyxDQUFBO0FBQ2YsaURBQXdDO0FBQWhDLGtDQUFBLE9BQU8sQ0FBQTtBQUVmLElBQUksUUFBUSxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQTtBQUM5QyxRQUFRLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQTtBQUV0QyxRQUFRO0FBQ1IsUUFBUSxDQUFDLFVBQVUsQ0FBQztJQUNoQixXQUFXLEVBQUUsT0FBTztDQUN2QixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSTtJQUNULG1CQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUNYLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUE7QUFDbkMsQ0FBQyxDQUFDLENBQUE7QUFFRixRQUFRO0FBQ1IsUUFBUSxDQUFDLFVBQVUsQ0FBQztJQUNoQixXQUFXLEVBQUUsT0FBTztDQUN2QixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSTtJQUNULG1CQUFLLEVBQUU7U0FDRixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFBO0FBQ25DLENBQUMsQ0FBQyxDQUFBO0FBRUYsVUFBVTtBQUNWLFFBQVEsQ0FBQyxVQUFVLENBQUM7SUFDaEIsV0FBVyxFQUFFLFNBQVM7Q0FDekIsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUk7SUFDVCx1QkFBTyxFQUFFO1NBQ0osSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQTtBQUNuQyxDQUFDLENBQUMsQ0FBQTtBQUVGLFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBRSxTQUFTO0NBQ3pCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQTtBQUNuQyxDQUFDLENBQUMsQ0FBQTtBQUVGLFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBRSxTQUFTO0NBQ3pCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQTtBQUNuQyxDQUFDLENBQUMsQ0FBQTtBQUVGLFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBRSxTQUFTO0NBQ3pCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQTtBQUNuQyxDQUFDLENBQUMsQ0FBQTtBQUVGLE9BQU87QUFDUCxRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBRSxNQUFNO0NBQ3RCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsaUJBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ1YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQTtBQUNuQyxDQUFDLENBQUMsQ0FBQTtBQUVGLFVBQVU7QUFDVixRQUFRLENBQUMsVUFBVSxDQUFDO0lBQ2hCLFdBQVcsRUFBRSxTQUFTO0NBQ3pCLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJO0lBQ1QsdUJBQU8sRUFBRSxDQUFBO0FBQ2IsQ0FBQyxDQUFDLENBQUE7QUFFRixRQUFRLENBQUMsVUFBVSxFQUFFLENBQUEifQ==
|
2
dist/npmci.bash.d.ts
vendored
2
dist/npmci.bash.d.ts
vendored
@ -1,4 +1,4 @@
|
|||||||
import "typings-global";
|
import 'typings-global';
|
||||||
export declare let nvmAvailable: boolean;
|
export declare let nvmAvailable: boolean;
|
||||||
export declare let bash: (commandArg: string, retryArg?: number, bareArg?: boolean) => string;
|
export declare let bash: (commandArg: string, retryArg?: number, bareArg?: boolean) => string;
|
||||||
export declare let bashBare: (commandArg: any, retryArg?: number) => string;
|
export declare let bashBare: (commandArg: any, retryArg?: number) => string;
|
||||||
|
14
dist/npmci.bash.js
vendored
14
dist/npmci.bash.js
vendored
@ -1,7 +1,7 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
require("typings-global");
|
require("typings-global");
|
||||||
const plugins = require("./npmci.plugins");
|
const plugins = require("./npmci.plugins");
|
||||||
let nvmSourceString = "";
|
let nvmSourceString = '';
|
||||||
exports.nvmAvailable = false;
|
exports.nvmAvailable = false;
|
||||||
let checkNvm = () => {
|
let checkNvm = () => {
|
||||||
if (plugins.shelljs.exec(`bash -c "source /usr/local/nvm/nvm.sh"`, { silent: true }).code === 0) {
|
if (plugins.shelljs.exec(`bash -c "source /usr/local/nvm/nvm.sh"`, { silent: true }).code === 0) {
|
||||||
@ -29,24 +29,24 @@ exports.bash = (commandArg, retryArg = 2, bareArg = false) => {
|
|||||||
}
|
}
|
||||||
exitCode = execResult.code;
|
exitCode = execResult.code;
|
||||||
stdOut = execResult.stdout;
|
stdOut = execResult.stdout;
|
||||||
if (exitCode !== 0 && i == retryArg) {
|
if (exitCode !== 0 && i === retryArg) {
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
else if (exitCode == 0) {
|
else if (exitCode === 0) {
|
||||||
i = retryArg + 1; // if everything works out ok retrials are not wanted
|
i = retryArg + 1; // if everything works out ok retrials are not wanted
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
plugins.beautylog.warn("Something went wrong! Exit Code: " + exitCode.toString());
|
plugins.beautylog.warn('Something went wrong! Exit Code: ' + exitCode.toString());
|
||||||
plugins.beautylog.info("Retry " + (i + 1).toString() + " of " + retryArg.toString());
|
plugins.beautylog.info('Retry ' + (i + 1).toString() + ' of ' + retryArg.toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
plugins.beautylog.log("ShellExec would be: " + commandArg);
|
plugins.beautylog.log('ShellExec would be: ' + commandArg);
|
||||||
}
|
}
|
||||||
return stdOut;
|
return stdOut;
|
||||||
};
|
};
|
||||||
exports.bashBare = (commandArg, retryArg = 2) => {
|
exports.bashBare = (commandArg, retryArg = 2) => {
|
||||||
return exports.bash(commandArg, retryArg, true);
|
return exports.bash(commandArg, retryArg, true);
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuYmFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLmJhc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFHM0MsSUFBSSxlQUFlLEdBQVcsRUFBRSxDQUFDO0FBQ3RCLFFBQUEsWUFBWSxHQUFZLEtBQUssQ0FBQztBQUN6QyxJQUFJLFFBQVEsR0FBRztJQUNYLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHdDQUF3QyxFQUFDLEVBQUMsTUFBTSxFQUFDLElBQUksRUFBQyxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUYsZUFBZSxHQUFHLGtDQUFrQyxDQUFBO1FBQ3BELG9CQUFZLEdBQUcsSUFBSSxDQUFDO0lBQ3hCLENBQUM7SUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsZ0NBQWdDLEVBQUMsRUFBQyxNQUFNLEVBQUMsSUFBSSxFQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN6RixlQUFlLEdBQUcsMEJBQTBCLENBQUE7UUFDNUMsb0JBQVksR0FBRyxJQUFJLENBQUM7SUFDeEIsQ0FBQztJQUFBLENBQUM7QUFDTixDQUFDLENBQUM7QUFDRixRQUFRLEVBQUUsQ0FBQztBQUVBLFFBQUEsSUFBSSxHQUFHLENBQUMsVUFBa0IsRUFBRSxRQUFRLEdBQUcsQ0FBQyxFQUFFLE9BQU8sR0FBRyxLQUFLO0lBQ2hFLElBQUksUUFBZ0IsQ0FBQztJQUNyQixJQUFJLE1BQWMsQ0FBQztJQUNuQixJQUFJLFVBQVUsQ0FBQztJQUNmLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQzFCLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLElBQUksUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO2dCQUNYLFVBQVUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDN0IsWUFBWSxlQUFlLElBQUksVUFBVSxHQUFHLENBQy9DLENBQUM7WUFDTixDQUFDO1lBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ0osVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQ2xELENBQUM7WUFDRCxRQUFRLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQztZQUMzQixNQUFNLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQztZQUMzQixFQUFFLENBQUMsQ0FBQyxRQUFRLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDO2dCQUNsQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3BCLENBQUM7WUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3ZCLENBQUMsR0FBRyxRQUFRLEdBQUcsQ0FBQyxDQUFDLENBQUMscURBQXFEO1lBQzNFLENBQUM7WUFBQyxJQUFJLENBQUMsQ0FBQztnQkFDSixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxtQ0FBbUMsR0FBRyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztnQkFDbEYsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxHQUFHLE1BQU0sR0FBRyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztZQUN6RixDQUFDO1FBQ0wsQ0FBQztJQUNMLENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLHNCQUFzQixHQUFHLFVBQVUsQ0FBQyxDQUFBO0lBQzlELENBQUM7SUFDRCxNQUFNLENBQUMsTUFBTSxDQUFDO0FBQ2xCLENBQUMsQ0FBQTtBQUVVLFFBQUEsUUFBUSxHQUFHLENBQUMsVUFBVSxFQUFFLFFBQVEsR0FBRyxDQUFDO0lBQzNDLE1BQU0sQ0FBQyxZQUFJLENBQUMsVUFBVSxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUM1QyxDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuYmFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLmJhc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFFMUMsSUFBSSxlQUFlLEdBQVcsRUFBRSxDQUFBO0FBQ3JCLFFBQUEsWUFBWSxHQUFZLEtBQUssQ0FBQTtBQUN4QyxJQUFJLFFBQVEsR0FBRztJQUNYLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHdDQUF3QyxFQUFDLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQyxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0YsZUFBZSxHQUFHLGtDQUFrQyxDQUFBO1FBQ3BELG9CQUFZLEdBQUcsSUFBSSxDQUFBO0lBQ3ZCLENBQUM7SUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsZ0NBQWdDLEVBQUMsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRixlQUFlLEdBQUcsMEJBQTBCLENBQUE7UUFDNUMsb0JBQVksR0FBRyxJQUFJLENBQUE7SUFDdkIsQ0FBQztJQUFBLENBQUM7QUFDTixDQUFDLENBQUE7QUFDRCxRQUFRLEVBQUUsQ0FBQTtBQUVDLFFBQUEsSUFBSSxHQUFHLENBQUMsVUFBa0IsRUFBRSxRQUFRLEdBQUcsQ0FBQyxFQUFFLE9BQU8sR0FBRyxLQUFLO0lBQ2hFLElBQUksUUFBZ0IsQ0FBQTtJQUNwQixJQUFJLE1BQWMsQ0FBQTtJQUNsQixJQUFJLFVBQVUsQ0FBQTtJQUNkLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQzFCLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLElBQUksUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO2dCQUNYLFVBQVUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDN0IsWUFBWSxlQUFlLElBQUksVUFBVSxHQUFHLENBQy9DLENBQUE7WUFDTCxDQUFDO1lBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ0osVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1lBQ2pELENBQUM7WUFDRCxRQUFRLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQTtZQUMxQixNQUFNLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQTtZQUMxQixFQUFFLENBQUMsQ0FBQyxRQUFRLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDO2dCQUNuQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFBO1lBQ25CLENBQUM7WUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsUUFBUSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3hCLENBQUMsR0FBRyxRQUFRLEdBQUcsQ0FBQyxDQUFBLENBQUMscURBQXFEO1lBQzFFLENBQUM7WUFBQyxJQUFJLENBQUMsQ0FBQztnQkFDSixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxtQ0FBbUMsR0FBRyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtnQkFDakYsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxHQUFHLE1BQU0sR0FBRyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtZQUN4RixDQUFDO1FBQ0wsQ0FBQztJQUNMLENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLHNCQUFzQixHQUFHLFVBQVUsQ0FBQyxDQUFBO0lBQzlELENBQUM7SUFDRCxNQUFNLENBQUMsTUFBTSxDQUFBO0FBQ2pCLENBQUMsQ0FBQTtBQUVVLFFBQUEsUUFBUSxHQUFHLENBQUMsVUFBVSxFQUFFLFFBQVEsR0FBRyxDQUFDO0lBQzNDLE1BQU0sQ0FBQyxZQUFJLENBQUMsVUFBVSxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQTtBQUMzQyxDQUFDLENBQUEifQ==
|
6
dist/npmci.build.d.ts
vendored
6
dist/npmci.build.d.ts
vendored
@ -1,10 +1,10 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
import "typings-global";
|
import 'typings-global';
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
/**
|
/**
|
||||||
* defines possible build services
|
* defines possible build services
|
||||||
*/
|
*/
|
||||||
export declare type TBuildService = "docker";
|
export declare type TBuildService = 'docker';
|
||||||
/**
|
/**
|
||||||
* builds for a specific service
|
* builds for a specific service
|
||||||
*/
|
*/
|
||||||
|
2
dist/npmci.build.docker.d.ts
vendored
2
dist/npmci.build.docker.d.ts
vendored
@ -1,6 +1,6 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
/// <reference types="node" />
|
/// <reference types="node" />
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
/**
|
/**
|
||||||
* builds a cwd of Dockerfiles by triggering a promisechain
|
* builds a cwd of Dockerfiles by triggering a promisechain
|
||||||
*/
|
*/
|
||||||
|
66
dist/npmci.build.docker.js
vendored
66
dist/npmci.build.docker.js
vendored
File diff suppressed because one or more lines are too long
6
dist/npmci.build.js
vendored
6
dist/npmci.build.js
vendored
@ -7,12 +7,12 @@ const buildDocker = require("./npmci.build.docker");
|
|||||||
*/
|
*/
|
||||||
exports.build = function (commandArg) {
|
exports.build = function (commandArg) {
|
||||||
switch (commandArg) {
|
switch (commandArg) {
|
||||||
case "docker":
|
case 'docker':
|
||||||
return buildDocker.build();
|
return buildDocker.build();
|
||||||
default:
|
default:
|
||||||
plugins.beautylog.log("build target " + commandArg + " not recognised!");
|
plugins.beautylog.log('build target ' + commandArg + ' not recognised!');
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuYnVpbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9ucG1jaS5idWlsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQXdCO0FBQ3hCLDJDQUEyQztBQUczQyxvREFBbUQ7QUFPbkQ7O0dBRUc7QUFDUSxRQUFBLEtBQUssR0FBRyxVQUFTLFVBQVU7SUFDbEMsTUFBTSxDQUFBLENBQUMsVUFBVSxDQUFDLENBQUEsQ0FBQztRQUNmLEtBQUssUUFBUTtZQUNULE1BQU0sQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDL0I7WUFDSSxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxlQUFlLEdBQUcsVUFBVSxHQUFHLGtCQUFrQixDQUFDLENBQUM7SUFDakYsQ0FBQztJQUFBLENBQUM7SUFDRixNQUFNLENBQUM7QUFDWCxDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuYnVpbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9ucG1jaS5idWlsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQXVCO0FBQ3ZCLDJDQUEwQztBQUcxQyxvREFBbUQ7QUFPbkQ7O0dBRUc7QUFDUSxRQUFBLEtBQUssR0FBRyxVQUFTLFVBQVU7SUFDbEMsTUFBTSxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUNqQixLQUFLLFFBQVE7WUFDVCxNQUFNLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFBO1FBQzlCO1lBQ0ksT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZUFBZSxHQUFHLFVBQVUsR0FBRyxrQkFBa0IsQ0FBQyxDQUFBO0lBQ2hGLENBQUM7SUFBQSxDQUFDO0lBQ0YsTUFBTSxDQUFBO0FBQ1YsQ0FBQyxDQUFBIn0=
|
6
dist/npmci.config.d.ts
vendored
Normal file
6
dist/npmci.config.d.ts
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
/// <reference types="q" />
|
||||||
|
import * as q from 'q';
|
||||||
|
export interface INpmciOptions {
|
||||||
|
globalNpmTools: string[];
|
||||||
|
}
|
||||||
|
export declare let getConfig: () => q.Promise<INpmciOptions>;
|
16
dist/npmci.config.js
vendored
Normal file
16
dist/npmci.config.js
vendored
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
"use strict";
|
||||||
|
const q = require("q");
|
||||||
|
const plugins = require("./npmci.plugins");
|
||||||
|
const paths = require("./npmci.paths");
|
||||||
|
exports.getConfig = () => {
|
||||||
|
console.log('getting config');
|
||||||
|
let done = q.defer();
|
||||||
|
let npmciNpmextra = new plugins.npmextra.Npmextra(paths.cwd);
|
||||||
|
let defaultConfig = {
|
||||||
|
globalNpmTools: []
|
||||||
|
};
|
||||||
|
let npmciConfig = npmciNpmextra.dataFor('npmci', defaultConfig);
|
||||||
|
done.resolve(npmciConfig);
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtY2kuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx1QkFBc0I7QUFFdEIsMkNBQTBDO0FBQzFDLHVDQUFzQztBQU0zQixRQUFBLFNBQVMsR0FBRztJQUNuQixPQUFPLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUE7SUFDN0IsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBaUIsQ0FBQTtJQUNuQyxJQUFJLGFBQWEsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUM1RCxJQUFJLGFBQWEsR0FBa0I7UUFDL0IsY0FBYyxFQUFFLEVBQUU7S0FDckIsQ0FBQTtJQUNELElBQUksV0FBVyxHQUFHLGFBQWEsQ0FBQyxPQUFPLENBQWdCLE9BQU8sRUFBRSxhQUFhLENBQUMsQ0FBQTtJQUM5RSxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBQ3pCLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFBO0FBQ3ZCLENBQUMsQ0FBQSJ9
|
11
dist/npmci.install.js
vendored
11
dist/npmci.install.js
vendored
@ -1,6 +1,7 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
require("typings-global");
|
require("typings-global");
|
||||||
const plugins = require("./npmci.plugins");
|
const plugins = require("./npmci.plugins");
|
||||||
|
const configModule = require("./npmci.config");
|
||||||
const npmci_bash_1 = require("./npmci.bash");
|
const npmci_bash_1 = require("./npmci.bash");
|
||||||
const npmci_bash_2 = require("./npmci.bash");
|
const npmci_bash_2 = require("./npmci.bash");
|
||||||
exports.install = (versionArg) => {
|
exports.install = (versionArg) => {
|
||||||
@ -30,7 +31,15 @@ exports.install = (versionArg) => {
|
|||||||
;
|
;
|
||||||
npmci_bash_1.bash('node -v');
|
npmci_bash_1.bash('node -v');
|
||||||
npmci_bash_1.bash('npm -v');
|
npmci_bash_1.bash('npm -v');
|
||||||
|
// lets look for further config
|
||||||
|
configModule.getConfig()
|
||||||
|
.then(config => {
|
||||||
|
for (let npmTool of config.globalNpmTools) {
|
||||||
|
plugins.beautylog.info(`globally installing ${npmTool} from npm`);
|
||||||
|
npmci_bash_1.bash(`npm install --loglevel=silent -g ${npmTool}`);
|
||||||
|
}
|
||||||
done.resolve();
|
done.resolve();
|
||||||
|
});
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuaW5zdGFsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLmluc3RhbGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFDM0MsNkNBQW9DO0FBQ3BDLDZDQUEyQztBQUVoQyxRQUFBLE9BQU8sR0FBRyxDQUFDLFVBQVU7SUFDNUIsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUM1QixPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQywrQkFBK0IsVUFBVSxFQUFFLENBQUMsQ0FBQTtJQUNsRSxJQUFJLE9BQWUsQ0FBQTtJQUNuQixFQUFFLENBQUMsQ0FBQyxVQUFVLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQztRQUMxQixPQUFPLEdBQUcsUUFBUSxDQUFBO0lBQ3RCLENBQUM7SUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsVUFBVSxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDOUIsT0FBTyxHQUFHLEdBQUcsQ0FBQTtJQUNqQixDQUFDO0lBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLFVBQVUsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBQ2pDLE9BQU8sR0FBRyxHQUFHLENBQUE7SUFDakIsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ0osT0FBTyxHQUFHLFVBQVUsQ0FBQTtJQUN4QixDQUFDO0lBQUEsQ0FBQztJQUNGLEVBQUUsQ0FBQyxDQUFDLHlCQUFZLENBQUMsQ0FBQyxDQUFDO1FBQ2YsaUJBQUksQ0FBQyxlQUFlLE9BQU8seUJBQXlCLE9BQU8sRUFBRSxDQUFDLENBQUE7UUFDOUQsT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLE9BQU8sMEJBQTBCLENBQUMsQ0FBQTtJQUNoRixDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyx1REFBdUQsQ0FBQyxDQUFBO0lBQ25GLENBQUM7SUFBQSxDQUFDO0lBQ0YsaUJBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtJQUNmLGlCQUFJLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDZCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuaW5zdGFsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLmluc3RhbGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFDMUMsK0NBQThDO0FBQzlDLDZDQUFtQztBQUNuQyw2Q0FBMkM7QUFDaEMsUUFBQSxPQUFPLEdBQUcsQ0FBQyxVQUFVO0lBQzVCLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDNUIsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsK0JBQStCLFVBQVUsRUFBRSxDQUFDLENBQUE7SUFDbEUsSUFBSSxPQUFlLENBQUE7SUFDbkIsRUFBRSxDQUFDLENBQUMsVUFBVSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDMUIsT0FBTyxHQUFHLFFBQVEsQ0FBQTtJQUN0QixDQUFDO0lBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLFVBQVUsS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQzlCLE9BQU8sR0FBRyxHQUFHLENBQUE7SUFDakIsQ0FBQztJQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxVQUFVLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQztRQUNqQyxPQUFPLEdBQUcsR0FBRyxDQUFBO0lBQ2pCLENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLE9BQU8sR0FBRyxVQUFVLENBQUE7SUFDeEIsQ0FBQztJQUFBLENBQUM7SUFDRixFQUFFLENBQUMsQ0FBQyx5QkFBWSxDQUFDLENBQUMsQ0FBQztRQUNmLGlCQUFJLENBQUMsZUFBZSxPQUFPLHlCQUF5QixPQUFPLEVBQUUsQ0FBQyxDQUFBO1FBQzlELE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLGdCQUFnQixPQUFPLDBCQUEwQixDQUFDLENBQUE7SUFDaEYsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ0osT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsdURBQXVELENBQUMsQ0FBQTtJQUNuRixDQUFDO0lBQUEsQ0FBQztJQUNGLGlCQUFJLENBQUMsU0FBUyxDQUFDLENBQUE7SUFDZixpQkFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO0lBRWQsK0JBQStCO0lBQy9CLFlBQVksQ0FBQyxTQUFTLEVBQUU7U0FDbkIsSUFBSSxDQUFDLE1BQU07UUFDUixHQUFHLENBQUMsQ0FBQyxJQUFJLE9BQU8sSUFBSSxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQztZQUN4QyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsT0FBTyxXQUFXLENBQUMsQ0FBQTtZQUNqRSxpQkFBSSxDQUFDLHFDQUFxQyxPQUFPLEVBQUUsQ0FBQyxDQUFBO1FBQ3hELENBQUM7UUFDRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDbEIsQ0FBQyxDQUFDLENBQUE7SUFDTixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUEifQ==
|
2
dist/npmci.paths.d.ts
vendored
2
dist/npmci.paths.d.ts
vendored
@ -1,4 +1,4 @@
|
|||||||
import "typings-global";
|
import 'typings-global';
|
||||||
export declare let cwd: string;
|
export declare let cwd: string;
|
||||||
export declare let NpmciPackageRoot: string;
|
export declare let NpmciPackageRoot: string;
|
||||||
export declare let NpmciPackageConfig: string;
|
export declare let NpmciPackageConfig: string;
|
||||||
|
8
dist/npmci.paths.js
vendored
8
dist/npmci.paths.js
vendored
@ -2,8 +2,8 @@
|
|||||||
require("typings-global");
|
require("typings-global");
|
||||||
const plugins = require("./npmci.plugins");
|
const plugins = require("./npmci.plugins");
|
||||||
exports.cwd = process.cwd();
|
exports.cwd = process.cwd();
|
||||||
exports.NpmciPackageRoot = plugins.path.join(__dirname, "../");
|
exports.NpmciPackageRoot = plugins.path.join(__dirname, '../');
|
||||||
exports.NpmciPackageConfig = plugins.path.join(exports.NpmciPackageRoot, "./config.json");
|
exports.NpmciPackageConfig = plugins.path.join(exports.NpmciPackageRoot, './config.json');
|
||||||
exports.NpmciProjectDir = exports.cwd;
|
exports.NpmciProjectDir = exports.cwd;
|
||||||
exports.NpmciTestDir = plugins.path.join(exports.cwd, "./test");
|
exports.NpmciTestDir = plugins.path.join(exports.cwd, './test');
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9ucG1jaS5wYXRocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQXdCO0FBQ3hCLDJDQUEyQztBQUVoQyxRQUFBLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7QUFFcEIsUUFBQSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUMsS0FBSyxDQUFDLENBQUM7QUFDdEQsUUFBQSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyx3QkFBZ0IsRUFBQyxlQUFlLENBQUMsQ0FBQztBQUN6RSxRQUFBLGVBQWUsR0FBRyxXQUFHLENBQUM7QUFDdEIsUUFBQSxZQUFZLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBRyxFQUFDLFFBQVEsQ0FBQyxDQUFDIn0=
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9ucG1jaS5wYXRocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQXVCO0FBQ3ZCLDJDQUEwQztBQUUvQixRQUFBLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUE7QUFFbkIsUUFBQSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUMsS0FBSyxDQUFDLENBQUE7QUFDckQsUUFBQSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyx3QkFBZ0IsRUFBQyxlQUFlLENBQUMsQ0FBQTtBQUN4RSxRQUFBLGVBQWUsR0FBRyxXQUFHLENBQUE7QUFDckIsUUFBQSxZQUFZLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBRyxFQUFDLFFBQVEsQ0FBQyxDQUFBIn0=
|
31
dist/npmci.plugins.d.ts
vendored
31
dist/npmci.plugins.d.ts
vendored
@ -1,17 +1,18 @@
|
|||||||
import "typings-global";
|
import 'typings-global';
|
||||||
export import beautylog = require("beautylog");
|
export import beautylog = require('beautylog');
|
||||||
export declare let gulp: any;
|
export declare let gulp: any;
|
||||||
export declare let gulpFunction: any;
|
export import gulpFunction = require('gulp-function');
|
||||||
export declare let lodash: any;
|
export import lodash = require('lodash');
|
||||||
export import path = require("path");
|
export import npmextra = require('npmextra');
|
||||||
export import projectinfo = require("projectinfo");
|
export import path = require('path');
|
||||||
export import q = require("q");
|
export import projectinfo = require('projectinfo');
|
||||||
|
export import q = require('q');
|
||||||
export declare let request: any;
|
export declare let request: any;
|
||||||
export import shelljs = require("shelljs");
|
export import shelljs = require('shelljs');
|
||||||
export import smartcli = require("smartcli");
|
export import smartcli = require('smartcli');
|
||||||
export import smartfile = require("smartfile");
|
export import smartfile = require('smartfile');
|
||||||
export import smartparam = require("smartparam");
|
export import smartparam = require('smartparam');
|
||||||
export import smartsocket = require("smartsocket");
|
export import smartsocket = require('smartsocket');
|
||||||
export import smartssh = require("smartssh");
|
export import smartssh = require('smartssh');
|
||||||
export import smartstring = require("smartstring");
|
export import smartstring = require('smartstring');
|
||||||
export declare let through2: any;
|
export import through2 = require('through2');
|
||||||
|
7
dist/npmci.plugins.js
vendored
7
dist/npmci.plugins.js
vendored
@ -1,13 +1,14 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
require("typings-global");
|
require("typings-global");
|
||||||
exports.beautylog = require("beautylog");
|
exports.beautylog = require("beautylog");
|
||||||
exports.gulp = require("gulp");
|
exports.gulp = require('gulp');
|
||||||
exports.gulpFunction = require("gulp-function");
|
exports.gulpFunction = require("gulp-function");
|
||||||
exports.lodash = require("lodash");
|
exports.lodash = require("lodash");
|
||||||
|
exports.npmextra = require("npmextra");
|
||||||
exports.path = require("path");
|
exports.path = require("path");
|
||||||
exports.projectinfo = require("projectinfo");
|
exports.projectinfo = require("projectinfo");
|
||||||
exports.q = require("q");
|
exports.q = require("q");
|
||||||
exports.request = require("request");
|
exports.request = require('request');
|
||||||
exports.shelljs = require("shelljs");
|
exports.shelljs = require("shelljs");
|
||||||
exports.smartcli = require("smartcli");
|
exports.smartcli = require("smartcli");
|
||||||
exports.smartfile = require("smartfile");
|
exports.smartfile = require("smartfile");
|
||||||
@ -16,4 +17,4 @@ exports.smartsocket = require("smartsocket");
|
|||||||
exports.smartssh = require("smartssh");
|
exports.smartssh = require("smartssh");
|
||||||
exports.smartstring = require("smartstring");
|
exports.smartstring = require("smartstring");
|
||||||
exports.through2 = require("through2");
|
exports.through2 = require("through2");
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4Qix5Q0FBK0M7QUFDcEMsUUFBQSxJQUFJLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ3ZCLFFBQUEsWUFBWSxHQUFHLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQztBQUN4QyxRQUFBLE1BQU0sR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDdEMsK0JBQXFDO0FBQ3JDLDZDQUFtRDtBQUNuRCx5QkFBK0I7QUFDcEIsUUFBQSxPQUFPLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQ3hDLHFDQUEyQztBQUMzQyx1Q0FBNkM7QUFDN0MseUNBQStDO0FBQy9DLDJDQUFpRDtBQUNqRCw2Q0FBbUQ7QUFDbkQsdUNBQTZDO0FBQzdDLDZDQUFtRDtBQUN4QyxRQUFBLFFBQVEsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2Qix5Q0FBOEM7QUFDbkMsUUFBQSxJQUFJLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0FBQ2pDLGdEQUFxRDtBQUNyRCxtQ0FBd0M7QUFDeEMsdUNBQTRDO0FBQzVDLCtCQUFvQztBQUNwQyw2Q0FBa0Q7QUFDbEQseUJBQThCO0FBQ25CLFFBQUEsT0FBTyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQTtBQUN2QyxxQ0FBMEM7QUFDMUMsdUNBQTRDO0FBQzVDLHlDQUE4QztBQUM5QywyQ0FBZ0Q7QUFDaEQsNkNBQWtEO0FBQ2xELHVDQUE0QztBQUM1Qyw2Q0FBa0Q7QUFDbEQsdUNBQTRDIn0=
|
6
dist/npmci.prepare.d.ts
vendored
6
dist/npmci.prepare.d.ts
vendored
@ -1,10 +1,10 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
import "typings-global";
|
import 'typings-global';
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
/**
|
/**
|
||||||
* defines possible prepare services
|
* defines possible prepare services
|
||||||
*/
|
*/
|
||||||
export declare type TPrepService = "npm" | "docker" | "docker-gitlab" | "ssh";
|
export declare type TPrepService = 'npm' | 'docker' | 'docker-gitlab' | 'ssh';
|
||||||
/**
|
/**
|
||||||
* the main exported prepare function
|
* the main exported prepare function
|
||||||
* @param servieArg describes the service to prepare
|
* @param servieArg describes the service to prepare
|
||||||
|
30
dist/npmci.prepare.js
vendored
30
dist/npmci.prepare.js
vendored
@ -8,17 +8,17 @@ const sshModule = require("./npmci.ssh");
|
|||||||
*/
|
*/
|
||||||
let npm = function () {
|
let npm = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
let npmrcPrefix = "//registry.npmjs.org/:_authToken=";
|
let npmrcPrefix = '//registry.npmjs.org/:_authToken=';
|
||||||
let npmToken = process.env.NPMCI_TOKEN_NPM;
|
let npmToken = process.env.NPMCI_TOKEN_NPM;
|
||||||
let npmrcFileString = npmrcPrefix + npmToken;
|
let npmrcFileString = npmrcPrefix + npmToken;
|
||||||
if (npmToken) {
|
if (npmToken) {
|
||||||
plugins.beautylog.info("found access token");
|
plugins.beautylog.info('found access token');
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
plugins.beautylog.error("no access token found! Exiting!");
|
plugins.beautylog.error('no access token found! Exiting!');
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
plugins.smartfile.memory.toFsSync(npmrcFileString, "/root/.npmrc");
|
plugins.smartfile.memory.toFsSync(npmrcFileString, '/root/.npmrc');
|
||||||
done.resolve();
|
done.resolve();
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
@ -27,17 +27,17 @@ let npm = function () {
|
|||||||
*/
|
*/
|
||||||
let docker = function () {
|
let docker = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
env.setDockerRegistry("docker.io");
|
env.setDockerRegistry('docker.io');
|
||||||
let dockerRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)/;
|
let dockerRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)/;
|
||||||
if (!process.env.NPMCI_LOGIN_DOCKER) {
|
if (!process.env.NPMCI_LOGIN_DOCKER) {
|
||||||
plugins.beautylog.error("You have to specify Login Data to the Docker Registry");
|
plugins.beautylog.error('You have to specify Login Data to the Docker Registry');
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
plugins.shelljs.exec("docker login -u gitlab-ci-token -p " + process.env.CI_BUILD_TOKEN + " " + "registry.gitlab.com"); // Always also login to GitLab Registry
|
plugins.shelljs.exec('docker login -u gitlab-ci-token -p ' + process.env.CI_BUILD_TOKEN + ' ' + 'registry.gitlab.com'); // Always also login to GitLab Registry
|
||||||
let dockerRegexResultArray = dockerRegex.exec(process.env.NPMCI_LOGIN_DOCKER);
|
let dockerRegexResultArray = dockerRegex.exec(process.env.NPMCI_LOGIN_DOCKER);
|
||||||
let username = dockerRegexResultArray[1];
|
let username = dockerRegexResultArray[1];
|
||||||
let password = dockerRegexResultArray[2];
|
let password = dockerRegexResultArray[2];
|
||||||
plugins.shelljs.exec("docker login -u " + username + " -p " + password);
|
plugins.shelljs.exec('docker login -u ' + username + ' -p ' + password);
|
||||||
done.resolve();
|
done.resolve();
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
@ -46,8 +46,8 @@ let docker = function () {
|
|||||||
*/
|
*/
|
||||||
let dockerGitlab = function () {
|
let dockerGitlab = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
env.setDockerRegistry("registry.gitlab.com");
|
env.setDockerRegistry('registry.gitlab.com');
|
||||||
plugins.shelljs.exec("docker login -u gitlab-ci-token -p " + process.env.CI_BUILD_TOKEN + " " + "registry.gitlab.com");
|
plugins.shelljs.exec('docker login -u gitlab-ci-token -p ' + process.env.CI_BUILD_TOKEN + ' ' + 'registry.gitlab.com');
|
||||||
done.resolve();
|
done.resolve();
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
@ -66,16 +66,16 @@ let ssh = function () {
|
|||||||
*/
|
*/
|
||||||
exports.prepare = function (serviceArg) {
|
exports.prepare = function (serviceArg) {
|
||||||
switch (serviceArg) {
|
switch (serviceArg) {
|
||||||
case "npm":
|
case 'npm':
|
||||||
return npm();
|
return npm();
|
||||||
case "docker":
|
case 'docker':
|
||||||
return docker();
|
return docker();
|
||||||
case "docker-gitlab":
|
case 'docker-gitlab':
|
||||||
return dockerGitlab();
|
return dockerGitlab();
|
||||||
case "ssh":
|
case 'ssh':
|
||||||
return ssh();
|
return ssh();
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucHJlcGFyZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnByZXBhcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFFM0MsbUNBQWtDO0FBQ2xDLHlDQUF3QztBQVV4Qzs7R0FFRztBQUNILElBQUksR0FBRyxHQUFHO0lBQ04sSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUU3QixJQUFJLFdBQVcsR0FBVSxtQ0FBbUMsQ0FBQztJQUM3RCxJQUFJLFFBQVEsR0FBVSxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQztJQUNsRCxJQUFJLGVBQWUsR0FBRyxXQUFXLEdBQUcsUUFBUSxDQUFDO0lBRTdDLEVBQUUsQ0FBQSxDQUFDLFFBQVEsQ0FBQyxDQUFBLENBQUM7UUFDVCxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLE9BQU8sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7UUFDM0QsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQixDQUFDO0lBQ0QsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLGVBQWUsRUFBQyxjQUFjLENBQUMsQ0FBQztJQUNsRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDZixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN4QixDQUFDLENBQUM7QUFFRjs7R0FFRztBQUNILElBQUksTUFBTSxHQUFHO0lBQ1QsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM3QixHQUFHLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDbkMsSUFBSSxXQUFXLEdBQUcscUNBQXFDLENBQUE7SUFDdkQsRUFBRSxDQUFBLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUEsQ0FBQztRQUNoQyxPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyx1REFBdUQsQ0FBQyxDQUFDO1FBQ2pGLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDcEIsQ0FBQztJQUNELE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHFDQUFxQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxHQUFHLEdBQUcsR0FBRyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsdUNBQXVDO0lBQy9KLElBQUksc0JBQXNCLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDOUUsSUFBSSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDekMsSUFBSSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDekMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsUUFBUSxHQUFHLE1BQU0sR0FBRyxRQUFRLENBQUMsQ0FBQztJQUN4RSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDZixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN4QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksWUFBWSxHQUFHO0lBQ2YsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM3QixHQUFHLENBQUMsaUJBQWlCLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUM3QyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxxQ0FBcUMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsR0FBRyxHQUFHLEdBQUcscUJBQXFCLENBQUMsQ0FBQztJQUN2SCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDZixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN4QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksR0FBRyxHQUFHO0lBQ04sSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM3QixTQUFTLENBQUMsR0FBRyxFQUFFO1NBQ1YsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN4QixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN4QixDQUFDLENBQUM7QUFFRjs7O0dBR0c7QUFDUSxRQUFBLE9BQU8sR0FBRyxVQUFTLFVBQXVCO0lBQ2pELE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFDakIsS0FBSyxLQUFLO1lBQ04sTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ2pCLEtBQUssUUFBUTtZQUNULE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNwQixLQUFLLGVBQWU7WUFDaEIsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQzFCLEtBQUssS0FBSztZQUNOLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNqQjtZQUNJLEtBQUssQ0FBQztJQUNkLENBQUM7QUFDTCxDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucHJlcGFyZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnByZXBhcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFFMUMsbUNBQWtDO0FBQ2xDLHlDQUF3QztBQVV4Qzs7R0FFRztBQUNILElBQUksR0FBRyxHQUFHO0lBQ04sSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUU1QixJQUFJLFdBQVcsR0FBVyxtQ0FBbUMsQ0FBQTtJQUM3RCxJQUFJLFFBQVEsR0FBVyxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQTtJQUNsRCxJQUFJLGVBQWUsR0FBRyxXQUFXLEdBQUcsUUFBUSxDQUFBO0lBRTVDLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDWCxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFBO0lBQ2hELENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLE9BQU8sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGlDQUFpQyxDQUFDLENBQUE7UUFDMUQsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUNuQixDQUFDO0lBQ0QsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLGVBQWUsRUFBQyxjQUFjLENBQUMsQ0FBQTtJQUNqRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksTUFBTSxHQUFHO0lBQ1QsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUM1QixHQUFHLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUE7SUFDbEMsSUFBSSxXQUFXLEdBQUcscUNBQXFDLENBQUE7SUFDdkQsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztRQUNsQyxPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyx1REFBdUQsQ0FBQyxDQUFBO1FBQ2hGLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDbkIsQ0FBQztJQUNELE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHFDQUFxQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxHQUFHLEdBQUcsR0FBRyxxQkFBcUIsQ0FBQyxDQUFBLENBQUMsdUNBQXVDO0lBQzlKLElBQUksc0JBQXNCLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUE7SUFDN0UsSUFBSSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDeEMsSUFBSSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDeEMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsUUFBUSxHQUFHLE1BQU0sR0FBRyxRQUFRLENBQUMsQ0FBQTtJQUN2RSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksWUFBWSxHQUFHO0lBQ2YsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUM1QixHQUFHLENBQUMsaUJBQWlCLENBQUMscUJBQXFCLENBQUMsQ0FBQTtJQUM1QyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxxQ0FBcUMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsR0FBRyxHQUFHLEdBQUcscUJBQXFCLENBQUMsQ0FBQTtJQUN0SCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksR0FBRyxHQUFHO0lBQ04sSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUM1QixTQUFTLENBQUMsR0FBRyxFQUFFO1NBQ1YsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtJQUN2QixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUE7QUFFRDs7O0dBR0c7QUFDUSxRQUFBLE9BQU8sR0FBRyxVQUFTLFVBQXdCO0lBQ2xELE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFDakIsS0FBSyxLQUFLO1lBQ04sTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFBO1FBQ2hCLEtBQUssUUFBUTtZQUNULE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQTtRQUNuQixLQUFLLGVBQWU7WUFDaEIsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFBO1FBQ3pCLEtBQUssS0FBSztZQUNOLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQTtRQUNoQjtZQUNJLEtBQUssQ0FBQTtJQUNiLENBQUM7QUFDTCxDQUFDLENBQUEifQ==
|
6
dist/npmci.publish.d.ts
vendored
6
dist/npmci.publish.d.ts
vendored
@ -1,10 +1,10 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
import "typings-global";
|
import 'typings-global';
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
/**
|
/**
|
||||||
* type of supported services
|
* type of supported services
|
||||||
*/
|
*/
|
||||||
export declare type TPubService = "npm" | "docker";
|
export declare type TPubService = 'npm' | 'docker';
|
||||||
/**
|
/**
|
||||||
* the main exported publish function.
|
* the main exported publish function.
|
||||||
* @param pubServiceArg references targeted service to publish to
|
* @param pubServiceArg references targeted service to publish to
|
||||||
|
14
dist/npmci.publish.js
vendored
14
dist/npmci.publish.js
vendored
@ -8,11 +8,11 @@ const NpmciBuildDocker = require("./npmci.build.docker");
|
|||||||
* the main exported publish function.
|
* the main exported publish function.
|
||||||
* @param pubServiceArg references targeted service to publish to
|
* @param pubServiceArg references targeted service to publish to
|
||||||
*/
|
*/
|
||||||
exports.publish = (pubServiceArg = "npm") => {
|
exports.publish = (pubServiceArg = 'npm') => {
|
||||||
switch (pubServiceArg) {
|
switch (pubServiceArg) {
|
||||||
case "npm":
|
case 'npm':
|
||||||
return publishNpm();
|
return publishNpm();
|
||||||
case "docker":
|
case 'docker':
|
||||||
return publishDocker();
|
return publishDocker();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -21,10 +21,10 @@ exports.publish = (pubServiceArg = "npm") => {
|
|||||||
*/
|
*/
|
||||||
let publishNpm = function () {
|
let publishNpm = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
npmci_prepare_1.prepare("npm")
|
npmci_prepare_1.prepare('npm')
|
||||||
.then(function () {
|
.then(function () {
|
||||||
npmci_bash_1.bash("npm publish");
|
npmci_bash_1.bash('npm publish');
|
||||||
plugins.beautylog.ok("Done!");
|
plugins.beautylog.ok('Done!');
|
||||||
done.resolve();
|
done.resolve();
|
||||||
});
|
});
|
||||||
return done.promise;
|
return done.promise;
|
||||||
@ -40,4 +40,4 @@ let publishDocker = function () {
|
|||||||
.then(done.resolve);
|
.then(done.resolve);
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucHVibGlzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnB1Ymxpc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFDM0MsbURBQXdDO0FBQ3hDLDZDQUFrQztBQUVsQyx5REFBd0Q7QUFPeEQ7OztHQUdHO0FBQ1EsUUFBQSxPQUFPLEdBQUcsQ0FBQyxnQkFBNEIsS0FBSztJQUNuRCxNQUFNLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQSxDQUFDO1FBQ25CLEtBQUssS0FBSztZQUNOLE1BQU0sQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUN4QixLQUFLLFFBQVE7WUFDVCxNQUFNLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDL0IsQ0FBQztBQUNMLENBQUMsQ0FBQztBQUVGOztHQUVHO0FBQ0gsSUFBSSxVQUFVLEdBQUk7SUFDZCxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzdCLHVCQUFPLENBQUMsS0FBSyxDQUFDO1NBQ1QsSUFBSSxDQUFDO1FBQ0YsaUJBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNwQixPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBRTtRQUMvQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbkIsQ0FBQyxDQUFDLENBQUM7SUFDUixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN2QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksYUFBYSxHQUFHO0lBQ2hCLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDekIsZ0JBQWdCLENBQUMsZUFBZSxFQUFFO1NBQ2pDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQztTQUMzQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDO1NBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDeEIsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7QUFDeEIsQ0FBQyxDQUFDIn0=
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kucHVibGlzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnB1Ymxpc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFDMUMsbURBQXVDO0FBQ3ZDLDZDQUFpQztBQUVqQyx5REFBd0Q7QUFPeEQ7OztHQUdHO0FBQ1EsUUFBQSxPQUFPLEdBQUcsQ0FBQyxnQkFBNkIsS0FBSztJQUNwRCxNQUFNLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO1FBQ3BCLEtBQUssS0FBSztZQUNOLE1BQU0sQ0FBQyxVQUFVLEVBQUUsQ0FBQTtRQUN2QixLQUFLLFFBQVE7WUFDVCxNQUFNLENBQUMsYUFBYSxFQUFFLENBQUE7SUFDOUIsQ0FBQztBQUNMLENBQUMsQ0FBQTtBQUVEOztHQUVHO0FBQ0gsSUFBSSxVQUFVLEdBQUk7SUFDZCxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO0lBQzVCLHVCQUFPLENBQUMsS0FBSyxDQUFDO1NBQ1QsSUFBSSxDQUFDO1FBQ0YsaUJBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQTtRQUNuQixPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUM3QixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDbEIsQ0FBQyxDQUFDLENBQUE7SUFDUCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN0QixDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksYUFBYSxHQUFHO0lBQ2hCLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDeEIsZ0JBQWdCLENBQUMsZUFBZSxFQUFFO1NBQ2pDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQztTQUMzQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDO1NBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDdkIsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7QUFDdkIsQ0FBQyxDQUFBIn0=
|
6
dist/npmci.servezone.js
vendored
6
dist/npmci.servezone.js
vendored
@ -13,10 +13,10 @@ let servezoneRegexResultArray = servezoneRegex.exec(process.env.NPMCI_SERVEZONE)
|
|||||||
* the data object that is used for the smartsocket client object
|
* the data object that is used for the smartsocket client object
|
||||||
*/
|
*/
|
||||||
let smartsocketClientConstructorOptions = {
|
let smartsocketClientConstructorOptions = {
|
||||||
alias: "npmci",
|
alias: 'npmci',
|
||||||
password: servezoneRegexResultArray[3],
|
password: servezoneRegexResultArray[3],
|
||||||
port: parseInt(servezoneRegexResultArray[2]),
|
port: parseInt(servezoneRegexResultArray[2]),
|
||||||
role: "ci",
|
role: 'ci',
|
||||||
url: servezoneRegexResultArray[1]
|
url: servezoneRegexResultArray[1]
|
||||||
};
|
};
|
||||||
/**
|
/**
|
||||||
@ -25,4 +25,4 @@ let smartsocketClientConstructorOptions = {
|
|||||||
exports.run = (configArg) => {
|
exports.run = (configArg) => {
|
||||||
new plugins.smartsocket.SmartsocketClient(smartsocketClientConstructorOptions);
|
new plugins.smartsocket.SmartsocketClient(smartsocketClientConstructorOptions);
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuc2VydmV6b25lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtY2kuc2VydmV6b25lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSwyQ0FBMkM7QUFFM0M7OztHQUdHO0FBQ0gsSUFBSSxjQUFjLEdBQUcsbUJBQW1CLENBQUM7QUFFekM7O0dBRUc7QUFDSCxJQUFJLHlCQUF5QixHQUFHLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQztBQUVqRjs7R0FFRztBQUNILElBQUksbUNBQW1DLEdBQUc7SUFDdEMsS0FBSyxFQUFFLE9BQU87SUFDZCxRQUFRLEVBQUUseUJBQXlCLENBQUMsQ0FBQyxDQUFDO0lBQ3RDLElBQUksRUFBRSxRQUFRLENBQUMseUJBQXlCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUMsSUFBSSxFQUFFLElBQUk7SUFDVixHQUFHLEVBQUUseUJBQXlCLENBQUMsQ0FBQyxDQUFDO0NBQ3BDLENBQUM7QUFFRjs7R0FFRztBQUNRLFFBQUEsR0FBRyxHQUFHLENBQUMsU0FBUztJQUN2QixJQUFJLE9BQU8sQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQ3JDLG1DQUFtQyxDQUN0QyxDQUFDO0FBQ04sQ0FBQyxDQUFDIn0=
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuc2VydmV6b25lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtY2kuc2VydmV6b25lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSwyQ0FBMEM7QUFFMUM7OztHQUdHO0FBQ0gsSUFBSSxjQUFjLEdBQUcsbUJBQW1CLENBQUE7QUFFeEM7O0dBRUc7QUFDSCxJQUFJLHlCQUF5QixHQUFHLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQTtBQUVoRjs7R0FFRztBQUNILElBQUksbUNBQW1DLEdBQUc7SUFDdEMsS0FBSyxFQUFFLE9BQU87SUFDZCxRQUFRLEVBQUUseUJBQXlCLENBQUMsQ0FBQyxDQUFDO0lBQ3RDLElBQUksRUFBRSxRQUFRLENBQUMseUJBQXlCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUMsSUFBSSxFQUFFLElBQUk7SUFDVixHQUFHLEVBQUUseUJBQXlCLENBQUMsQ0FBQyxDQUFDO0NBQ3BDLENBQUE7QUFFRDs7R0FFRztBQUNRLFFBQUEsR0FBRyxHQUFHLENBQUMsU0FBUztJQUN2QixJQUFJLE9BQU8sQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQ3JDLG1DQUFtQyxDQUN0QyxDQUFBO0FBQ0wsQ0FBQyxDQUFBIn0=
|
4
dist/npmci.ssh.d.ts
vendored
4
dist/npmci.ssh.d.ts
vendored
@ -1,6 +1,6 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
import "typings-global";
|
import 'typings-global';
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
/**
|
/**
|
||||||
* checks for ENV vars in form of NPMCI_SSHKEY_* and deploys any found ones
|
* checks for ENV vars in form of NPMCI_SSHKEY_* and deploys any found ones
|
||||||
*/
|
*/
|
||||||
|
16
dist/npmci.ssh.js
vendored
16
dist/npmci.ssh.js
vendored
@ -9,12 +9,12 @@ let sshInstance;
|
|||||||
exports.ssh = () => {
|
exports.ssh = () => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
sshInstance = new plugins.smartssh.SshInstance(); // init ssh instance
|
sshInstance = new plugins.smartssh.SshInstance(); // init ssh instance
|
||||||
plugins.smartparam.forEachMinimatch(process.env, "NPMCI_SSHKEY_*", evaluateSshEnv);
|
plugins.smartparam.forEachMinimatch(process.env, 'NPMCI_SSHKEY_*', evaluateSshEnv);
|
||||||
if (!process.env.NPMTS_TEST) {
|
if (!process.env.NPMTS_TEST) {
|
||||||
sshInstance.writeToDisk();
|
sshInstance.writeToDisk();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
plugins.beautylog.log("In test mode, so not storing SSH keys to disk!");
|
plugins.beautylog.log('In test mode, so not storing SSH keys to disk!');
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
done.resolve();
|
done.resolve();
|
||||||
@ -26,18 +26,18 @@ exports.ssh = () => {
|
|||||||
let evaluateSshEnv = (sshkeyEnvVarArg) => {
|
let evaluateSshEnv = (sshkeyEnvVarArg) => {
|
||||||
let resultArray = sshRegex.exec(sshkeyEnvVarArg);
|
let resultArray = sshRegex.exec(sshkeyEnvVarArg);
|
||||||
let sshKey = new plugins.smartssh.SshKey();
|
let sshKey = new plugins.smartssh.SshKey();
|
||||||
plugins.beautylog.info("Found SSH identity for " + resultArray[1]);
|
plugins.beautylog.info('Found SSH identity for ' + resultArray[1]);
|
||||||
if (notUndefined(resultArray[1])) {
|
if (notUndefined(resultArray[1])) {
|
||||||
plugins.beautylog.log("---> host defined!");
|
plugins.beautylog.log('---> host defined!');
|
||||||
sshKey.host = resultArray[1];
|
sshKey.host = resultArray[1];
|
||||||
}
|
}
|
||||||
if (notUndefined(resultArray[2])) {
|
if (notUndefined(resultArray[2])) {
|
||||||
plugins.beautylog.log("---> privKey defined!");
|
plugins.beautylog.log('---> privKey defined!');
|
||||||
sshKey.privKeyBase64 = resultArray[2];
|
sshKey.privKeyBase64 = resultArray[2];
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
if (notUndefined(resultArray[3])) {
|
if (notUndefined(resultArray[3])) {
|
||||||
"---> pubKey defined!";
|
'---> pubKey defined!';
|
||||||
sshKey.pubKeyBase64 = resultArray[3];
|
sshKey.pubKeyBase64 = resultArray[3];
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
@ -47,6 +47,6 @@ let evaluateSshEnv = (sshkeyEnvVarArg) => {
|
|||||||
* checks if not undefined
|
* checks if not undefined
|
||||||
*/
|
*/
|
||||||
let notUndefined = (stringArg) => {
|
let notUndefined = (stringArg) => {
|
||||||
return (stringArg && stringArg != "undefined" && stringArg != "##");
|
return (stringArg && stringArg !== 'undefined' && stringArg !== '##');
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuc3NoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtY2kuc3NoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSwwQkFBd0I7QUFDeEIsMkNBQTJDO0FBRTNDLElBQUksUUFBUSxHQUFHLG1CQUFtQixDQUFBO0FBQ2xDLElBQUksV0FBd0MsQ0FBQztBQUU3Qzs7R0FFRztBQUNRLFFBQUEsR0FBRyxHQUFHO0lBQ2IsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM3QixXQUFXLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsb0JBQW9CO0lBQ3RFLE9BQU8sQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBQyxnQkFBZ0IsRUFBQyxjQUFjLENBQUMsQ0FBQztJQUNqRixFQUFFLENBQUEsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUEsQ0FBQztRQUN4QixXQUFXLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ0osT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0RBQWdELENBQUMsQ0FBQztJQUM1RSxDQUFDO0lBQUEsQ0FBQztJQUNGLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNmLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQUVGOztHQUVHO0FBQ0gsSUFBSSxjQUFjLEdBQUcsQ0FBQyxlQUFlO0lBQ2pDLElBQUksV0FBVyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDakQsSUFBSSxNQUFNLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzNDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHlCQUF5QixHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25FLEVBQUUsQ0FBQSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBLENBQUM7UUFDN0IsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsb0JBQW9CLENBQUMsQ0FBQTtRQUMzQyxNQUFNLENBQUMsSUFBSSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBQ0QsRUFBRSxDQUFBLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUEsQ0FBQztRQUM3QixPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFBO1FBQzlDLE1BQU0sQ0FBQyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFBQSxDQUFDO0lBQ0YsRUFBRSxDQUFBLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUEsQ0FBQztRQUM3QixzQkFBc0IsQ0FBQTtRQUN0QixNQUFNLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBQUEsQ0FBQztJQUVGLFdBQVcsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7QUFDL0IsQ0FBQyxDQUFDO0FBRUY7O0dBRUc7QUFDSCxJQUFJLFlBQVksR0FBRyxDQUFDLFNBQWdCO0lBQ2hDLE1BQU0sQ0FBQyxDQUFDLFNBQVMsSUFBSSxTQUFTLElBQUksV0FBVyxJQUFJLFNBQVMsSUFBSSxJQUFJLENBQUMsQ0FBQztBQUN4RSxDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuc3NoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtY2kuc3NoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSwwQkFBdUI7QUFDdkIsMkNBQTBDO0FBRTFDLElBQUksUUFBUSxHQUFHLG1CQUFtQixDQUFBO0FBQ2xDLElBQUksV0FBeUMsQ0FBQTtBQUU3Qzs7R0FFRztBQUNRLFFBQUEsR0FBRyxHQUFHO0lBQ2IsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUM1QixXQUFXLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFBLENBQUMsb0JBQW9CO0lBQ3JFLE9BQU8sQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBQyxnQkFBZ0IsRUFBQyxjQUFjLENBQUMsQ0FBQTtJQUNoRixFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUMxQixXQUFXLENBQUMsV0FBVyxFQUFFLENBQUE7SUFDN0IsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ0osT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0RBQWdELENBQUMsQ0FBQTtJQUMzRSxDQUFDO0lBQUEsQ0FBQztJQUNGLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQTtJQUNkLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFBO0FBQ3ZCLENBQUMsQ0FBQTtBQUVEOztHQUVHO0FBQ0gsSUFBSSxjQUFjLEdBQUcsQ0FBQyxlQUFlO0lBQ2pDLElBQUksV0FBVyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUE7SUFDaEQsSUFBSSxNQUFNLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFBO0lBQzFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHlCQUF5QixHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ2xFLEVBQUUsQ0FBQyxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDL0IsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsb0JBQW9CLENBQUMsQ0FBQTtRQUMzQyxNQUFNLENBQUMsSUFBSSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUNoQyxDQUFDO0lBQ0QsRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvQixPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFBO1FBQzlDLE1BQU0sQ0FBQyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ3pDLENBQUM7SUFBQSxDQUFDO0lBQ0YsRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvQixzQkFBc0IsQ0FBQTtRQUN0QixNQUFNLENBQUMsWUFBWSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUN4QyxDQUFDO0lBQUEsQ0FBQztJQUVGLFdBQVcsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUE7QUFDOUIsQ0FBQyxDQUFBO0FBRUQ7O0dBRUc7QUFDSCxJQUFJLFlBQVksR0FBRyxDQUFDLFNBQWlCO0lBQ2pDLE1BQU0sQ0FBQyxDQUFDLFNBQVMsSUFBSSxTQUFTLEtBQUssV0FBVyxJQUFJLFNBQVMsS0FBSyxJQUFJLENBQUMsQ0FBQTtBQUN6RSxDQUFDLENBQUEifQ==
|
4
dist/npmci.test.d.ts
vendored
4
dist/npmci.test.d.ts
vendored
@ -1,4 +1,4 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
import "typings-global";
|
import 'typings-global';
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
export declare let test: (versionArg: any) => plugins.q.Promise<{}>;
|
export declare let test: (versionArg: any) => plugins.q.Promise<{}>;
|
||||||
|
12
dist/npmci.test.js
vendored
12
dist/npmci.test.js
vendored
@ -6,7 +6,7 @@ const npmci_install_1 = require("./npmci.install");
|
|||||||
const NpmciBuildDocker = require("./npmci.build.docker");
|
const NpmciBuildDocker = require("./npmci.build.docker");
|
||||||
exports.test = (versionArg) => {
|
exports.test = (versionArg) => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
if (versionArg == "docker") {
|
if (versionArg === 'docker') {
|
||||||
testDocker()
|
testDocker()
|
||||||
.then(() => {
|
.then(() => {
|
||||||
done.resolve();
|
done.resolve();
|
||||||
@ -24,15 +24,15 @@ exports.test = (versionArg) => {
|
|||||||
};
|
};
|
||||||
let npmDependencies = function () {
|
let npmDependencies = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
plugins.beautylog.info("now installing dependencies:");
|
plugins.beautylog.info('now installing dependencies:');
|
||||||
npmci_bash_1.bash("npm install");
|
npmci_bash_1.bash('npm install');
|
||||||
done.resolve();
|
done.resolve();
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
let npmTest = () => {
|
let npmTest = () => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
plugins.beautylog.info("now starting tests:");
|
plugins.beautylog.info('now starting tests:');
|
||||||
npmci_bash_1.bash("npm test");
|
npmci_bash_1.bash('npm test');
|
||||||
done.resolve();
|
done.resolve();
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
@ -44,4 +44,4 @@ let testDocker = function () {
|
|||||||
.then(done.resolve);
|
.then(done.resolve);
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFDM0MsNkNBQWtDO0FBQ2xDLG1EQUF3QztBQUV4Qyx5REFBeUQ7QUFFOUMsUUFBQSxJQUFJLEdBQUcsQ0FBQyxVQUFVO0lBQ3pCLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDN0IsRUFBRSxDQUFBLENBQUMsVUFBVSxJQUFJLFFBQVEsQ0FBQyxDQUFBLENBQUM7UUFDdkIsVUFBVSxFQUFFO2FBQ1AsSUFBSSxDQUFDO1lBQ0YsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ0osdUJBQU8sQ0FBQyxVQUFVLENBQUM7YUFDZCxJQUFJLENBQUMsZUFBZSxDQUFDO2FBQ3JCLElBQUksQ0FBQyxPQUFPLENBQUM7YUFDYixJQUFJLENBQUM7WUFDRixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7QUFDeEIsQ0FBQyxDQUFBO0FBRUQsSUFBSSxlQUFlLEdBQUc7SUFDbEIsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM3QixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDO0lBQ3ZELGlCQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDcEIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7QUFDeEIsQ0FBQyxDQUFBO0FBRUQsSUFBSSxPQUFPLEdBQUc7SUFDVixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzdCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDOUMsaUJBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNqQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDZixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN4QixDQUFDLENBQUE7QUFFRCxJQUFJLFVBQVUsR0FBRztJQUNiLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDN0IsZ0JBQWdCLENBQUMsZUFBZSxFQUFFO1NBQzdCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQztTQUMzQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDO1NBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDdkIsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7QUFDeEIsQ0FBQyxDQUFBIn0=
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFDMUMsNkNBQWlDO0FBQ2pDLG1EQUF1QztBQUV2Qyx5REFBd0Q7QUFFN0MsUUFBQSxJQUFJLEdBQUcsQ0FBQyxVQUFVO0lBQ3pCLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDNUIsRUFBRSxDQUFDLENBQUMsVUFBVSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDMUIsVUFBVSxFQUFFO2FBQ1AsSUFBSSxDQUFDO1lBQ0YsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFBO1FBQ2xCLENBQUMsQ0FBQyxDQUFBO0lBQ1YsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ0osdUJBQU8sQ0FBQyxVQUFVLENBQUM7YUFDZCxJQUFJLENBQUMsZUFBZSxDQUFDO2FBQ3JCLElBQUksQ0FBQyxPQUFPLENBQUM7YUFDYixJQUFJLENBQUM7WUFDRixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDbEIsQ0FBQyxDQUFDLENBQUE7SUFDVixDQUFDO0lBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7QUFDdkIsQ0FBQyxDQUFBO0FBRUQsSUFBSSxlQUFlLEdBQUc7SUFDbEIsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUM1QixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxDQUFBO0lBQ3RELGlCQUFJLENBQUMsYUFBYSxDQUFDLENBQUE7SUFDbkIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFBO0lBQ2QsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7QUFDdkIsQ0FBQyxDQUFBO0FBRUQsSUFBSSxPQUFPLEdBQUc7SUFDVixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO0lBQzVCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUE7SUFDN0MsaUJBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQTtJQUNoQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDZCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtBQUN2QixDQUFDLENBQUE7QUFFRCxJQUFJLFVBQVUsR0FBRztJQUNiLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDNUIsZ0JBQWdCLENBQUMsZUFBZSxFQUFFO1NBQzdCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQztTQUMzQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDO1NBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDdkIsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7QUFDdkIsQ0FBQyxDQUFBIn0=
|
4
dist/npmci.trigger.d.ts
vendored
4
dist/npmci.trigger.d.ts
vendored
@ -1,4 +1,4 @@
|
|||||||
/// <reference types="q" />
|
/// <reference types="q" />
|
||||||
import "typings-global";
|
import 'typings-global';
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins';
|
||||||
export declare let trigger: () => plugins.q.Promise<{}>;
|
export declare let trigger: () => plugins.q.Promise<{}>;
|
||||||
|
16
dist/npmci.trigger.js
vendored
16
dist/npmci.trigger.js
vendored
@ -4,8 +4,8 @@ const plugins = require("./npmci.plugins");
|
|||||||
let triggerValueRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|?([a-zA-Z0-9\.\-\/]*)/;
|
let triggerValueRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|?([a-zA-Z0-9\.\-\/]*)/;
|
||||||
exports.trigger = function () {
|
exports.trigger = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer();
|
||||||
plugins.beautylog.info("now running triggers");
|
plugins.beautylog.info('now running triggers');
|
||||||
plugins.smartparam.forEachMinimatch(process.env, "NPMCI_TRIGGER_*", evaluateTrigger);
|
plugins.smartparam.forEachMinimatch(process.env, 'NPMCI_TRIGGER_*', evaluateTrigger);
|
||||||
done.resolve();
|
done.resolve();
|
||||||
return done.promise;
|
return done.promise;
|
||||||
};
|
};
|
||||||
@ -16,14 +16,14 @@ let evaluateTrigger = (triggerEnvVarArg) => {
|
|||||||
let regexProjectTriggerToken = triggerRegexResultArray[3];
|
let regexProjectTriggerToken = triggerRegexResultArray[3];
|
||||||
let regexRefName = triggerRegexResultArray[4];
|
let regexRefName = triggerRegexResultArray[4];
|
||||||
let regexTriggerName;
|
let regexTriggerName;
|
||||||
if (triggerRegexResultArray.length == 6) {
|
if (triggerRegexResultArray.length === 6) {
|
||||||
regexTriggerName = triggerRegexResultArray[5];
|
regexTriggerName = triggerRegexResultArray[5];
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
regexTriggerName = "Unnamed Trigger";
|
regexTriggerName = 'Unnamed Trigger';
|
||||||
}
|
}
|
||||||
plugins.beautylog.info("Found Trigger!");
|
plugins.beautylog.info('Found Trigger!');
|
||||||
plugins.beautylog.log("triggering build for ref " + regexRefName + " of " + regexTriggerName);
|
plugins.beautylog.log('triggering build for ref ' + regexRefName + ' of ' + regexTriggerName);
|
||||||
plugins.request.post("https://gitlab.com/api/v3/projects/" + regexProjectId + "/trigger/builds", { form: { token: regexProjectTriggerToken, ref: regexRefName } });
|
plugins.request.post('https://gitlab.com/api/v3/projects/' + regexProjectId + '/trigger/builds', { form: { token: regexProjectTriggerToken, ref: regexRefName } });
|
||||||
};
|
};
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kudHJpZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnRyaWdnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF3QjtBQUN4QiwyQ0FBMkM7QUFLM0MsSUFBSSxpQkFBaUIsR0FBRyxnR0FBZ0csQ0FBQztBQUU5RyxRQUFBLE9BQU8sR0FBRztJQUNqQixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzdCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFDL0MsT0FBTyxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLGlCQUFpQixFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQ3JGLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNmLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0FBQ3hCLENBQUMsQ0FBQTtBQUVELElBQUksZUFBZSxHQUFHLENBQUMsZ0JBQWdCO0lBQ25DLElBQUksdUJBQXVCLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDdkUsSUFBSSxXQUFXLEdBQUcsdUJBQXVCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDN0MsSUFBSSxjQUFjLEdBQUcsdUJBQXVCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDaEQsSUFBSSx3QkFBd0IsR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMxRCxJQUFJLFlBQVksR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5QyxJQUFJLGdCQUFnQixDQUFDO0lBQ3JCLEVBQUUsQ0FBQyxDQUFDLHVCQUF1QixDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLGdCQUFnQixHQUFHLHVCQUF1QixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLGdCQUFnQixHQUFHLGlCQUFpQixDQUFDO0lBQ3pDLENBQUM7SUFDRCxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3pDLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLDJCQUEyQixHQUFHLFlBQVksR0FBRyxNQUFNLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQztJQUM5RixPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxxQ0FBcUMsR0FBRyxjQUFjLEdBQUcsaUJBQWlCLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsR0FBRyxFQUFFLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQztBQUN2SyxDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kudHJpZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLnRyaWdnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2QiwyQ0FBMEM7QUFJMUMsSUFBSSxpQkFBaUIsR0FBRyxnR0FBZ0csQ0FBQTtBQUU3RyxRQUFBLE9BQU8sR0FBRztJQUNqQixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO0lBQzVCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLENBQUE7SUFDOUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLGlCQUFpQixFQUFFLGVBQWUsQ0FBQyxDQUFBO0lBQ3BGLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQTtJQUNkLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFBO0FBQ3ZCLENBQUMsQ0FBQTtBQUVELElBQUksZUFBZSxHQUFHLENBQUMsZ0JBQWdCO0lBQ25DLElBQUksdUJBQXVCLEdBQUcsaUJBQWlCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUE7SUFDdEUsSUFBSSxXQUFXLEdBQUcsdUJBQXVCLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDNUMsSUFBSSxjQUFjLEdBQUcsdUJBQXVCLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDL0MsSUFBSSx3QkFBd0IsR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUN6RCxJQUFJLFlBQVksR0FBRyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUM3QyxJQUFJLGdCQUFnQixDQUFBO0lBQ3BCLEVBQUUsQ0FBQyxDQUFDLHVCQUF1QixDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZDLGdCQUFnQixHQUFHLHVCQUF1QixDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQ2pELENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLGdCQUFnQixHQUFHLGlCQUFpQixDQUFBO0lBQ3hDLENBQUM7SUFDRCxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFBO0lBQ3hDLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLDJCQUEyQixHQUFHLFlBQVksR0FBRyxNQUFNLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQTtJQUM3RixPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxxQ0FBcUMsR0FBRyxjQUFjLEdBQUcsaUJBQWlCLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsR0FBRyxFQUFFLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUN0SyxDQUFDLENBQUEifQ==
|
16
package.json
16
package.json
@ -27,24 +27,26 @@
|
|||||||
"typings-test": "^1.0.3"
|
"typings-test": "^1.0.3"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/lodash": "^4.14.39",
|
"@types/lodash": "^4.14.40",
|
||||||
"@types/node": "^6.0.47",
|
"@types/node": "^6.0.51",
|
||||||
"@types/q": "0.x.x",
|
"@types/q": "0.x.x",
|
||||||
"@types/request": "0.x.x",
|
"@types/request": "0.x.x",
|
||||||
"@types/shelljs": "^0.3.32",
|
"@types/shelljs": "^0.3.33",
|
||||||
|
"@types/through2": "^2.0.32",
|
||||||
"beautylog": "^6.0.0",
|
"beautylog": "^6.0.0",
|
||||||
"gulp": "^3.9.1",
|
"gulp": "^3.9.1",
|
||||||
"gulp-function": "^2.2.0",
|
"gulp-function": "^2.2.0",
|
||||||
"lodash": "^4.17.0",
|
"lodash": "^4.17.2",
|
||||||
|
"npmextra": "^2.0.3",
|
||||||
"projectinfo": "^1.0.4",
|
"projectinfo": "^1.0.4",
|
||||||
"q": "^1.4.1",
|
"q": "^1.4.1",
|
||||||
"request": "^2.78.0",
|
"request": "^2.79.0",
|
||||||
"shelljs": "^0.7.5",
|
"shelljs": "^0.7.5",
|
||||||
"smartcli": "^1.0.10",
|
"smartcli": "^1.0.15",
|
||||||
"smartfile": "^4.1.0",
|
"smartfile": "^4.1.0",
|
||||||
"smartparam": "^0.1.1",
|
"smartparam": "^0.1.1",
|
||||||
"smartsocket": "^1.1.7",
|
"smartsocket": "^1.1.7",
|
||||||
"smartssh": "^1.1.5",
|
"smartssh": "^1.2.1",
|
||||||
"smartstring": "^2.0.22",
|
"smartstring": "^2.0.22",
|
||||||
"through2": "^2.0.1",
|
"through2": "^2.0.1",
|
||||||
"typings-global": "^1.0.14"
|
"typings-global": "^1.0.14"
|
||||||
|
1
test/assets/npmextra.json
Normal file
1
test/assets/npmextra.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
@ -2,7 +2,6 @@
|
|||||||
require("typings-test");
|
require("typings-test");
|
||||||
const should = require("should");
|
const should = require("should");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const beautylog = require("beautylog");
|
|
||||||
// set up environment
|
// set up environment
|
||||||
process.env.CI_BUILD_REPO = 'https://yyyyyy:xxxxxxxx@gitlab.com/mygroup/myrepo.git';
|
process.env.CI_BUILD_REPO = 'https://yyyyyy:xxxxxxxx@gitlab.com/mygroup/myrepo.git';
|
||||||
process.env.NPMCI_SSHKEY_1 = 'hostString|somePrivKey|##';
|
process.env.NPMCI_SSHKEY_1 = 'hostString|somePrivKey|##';
|
||||||
@ -10,6 +9,7 @@ process.env.NPMTS_TEST = 'true';
|
|||||||
process.cwd = () => {
|
process.cwd = () => {
|
||||||
return path.join(__dirname, 'assets/');
|
return path.join(__dirname, 'assets/');
|
||||||
};
|
};
|
||||||
|
// require NPMCI files
|
||||||
const NpmciBuildDocker = require("../dist/npmci.build.docker");
|
const NpmciBuildDocker = require("../dist/npmci.build.docker");
|
||||||
const NpmciPublish = require("../dist/npmci.publish");
|
const NpmciPublish = require("../dist/npmci.publish");
|
||||||
const NpmciTest = require("../dist/npmci.test");
|
const NpmciTest = require("../dist/npmci.test");
|
||||||
@ -36,7 +36,6 @@ describe('NPMCI', function () {
|
|||||||
it('should sort an array of Dockerfiles', function (done) {
|
it('should sort an array of Dockerfiles', function (done) {
|
||||||
NpmciBuildDocker.sortDockerfiles(sortableArray)
|
NpmciBuildDocker.sortDockerfiles(sortableArray)
|
||||||
.then(function (sortedArrayArg) {
|
.then(function (sortedArrayArg) {
|
||||||
beautylog.success('final result');
|
|
||||||
console.log(sortedArrayArg);
|
console.log(sortedArrayArg);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
@ -87,4 +86,4 @@ describe('NPMCI', function () {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHdCQUFxQjtBQUNyQixpQ0FBZ0M7QUFDaEMsNkJBQTZCO0FBQzdCLHVDQUFzQztBQUV0QyxxQkFBcUI7QUFDckIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEdBQUcsdURBQXVELENBQUE7QUFDbkYsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEdBQUcsMkJBQTJCLENBQUE7QUFDeEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFBO0FBQy9CLE9BQU8sQ0FBQyxHQUFHLEdBQUc7SUFDVixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUMsU0FBUyxDQUFDLENBQUE7QUFDekMsQ0FBQyxDQUFBO0FBSUQsK0RBQStEO0FBQy9ELHNEQUFzRDtBQUN0RCxnREFBZ0Q7QUFDaEQsOENBQThDO0FBRzlDLElBQUksV0FBd0MsQ0FBQTtBQUM1QyxJQUFJLFdBQXdDLENBQUE7QUFDNUMsSUFBSSxhQUE0QyxDQUFBO0FBRWhELFFBQVEsQ0FBQyxPQUFPLEVBQUM7SUFDYixRQUFRLENBQUMsY0FBYyxFQUFDO1FBQ3BCLEVBQUUsQ0FBQyxpQ0FBaUMsRUFBQztZQUNqQyxXQUFXLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsRUFBQyxRQUFRLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFBO1lBQ3JGLFdBQVcsR0FBRyxJQUFJLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxFQUFDLFFBQVEsRUFBRSx1QkFBdUIsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQTtZQUM5RixNQUFNLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUMzQyxNQUFNLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUNqRCxDQUFDLENBQUMsQ0FBQTtRQUVGLEVBQUUsQ0FBQyx3Q0FBd0MsRUFBQyxVQUFTLElBQUk7WUFDckQsZ0JBQWdCLENBQUMsZUFBZSxFQUFFO2lCQUM3QixJQUFJLENBQUMsVUFBUyx1QkFBc0Q7Z0JBQ2pFLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUE7Z0JBQzVELGFBQWEsR0FBRyx1QkFBdUIsQ0FBQTtnQkFDdkMsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLHFDQUFxQyxFQUFDLFVBQVMsSUFBSTtZQUNsRCxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDO2lCQUMxQyxJQUFJLENBQUMsVUFBUyxjQUE2QztnQkFDeEQsU0FBUyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQTtnQkFDakMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQTtnQkFDM0IsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLDRDQUE0QyxFQUFFLFVBQVMsSUFBSTtZQUMxRCxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUU7aUJBQ25CLElBQUksQ0FBQztnQkFDRixJQUFJLEVBQUUsQ0FBQTtZQUNWLENBQUMsQ0FBQyxDQUFBO1FBQ1YsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDLENBQUMsQ0FBQTtJQUVGLFFBQVEsQ0FBQyxpQkFBaUIsRUFBQztRQUN2QixFQUFFLENBQUMsc0NBQXNDLEVBQUMsVUFBUyxJQUFJO1lBQ25ELFlBQVksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO2lCQUN6QixJQUFJLENBQUM7Z0JBQ0YsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQyxDQUFDLENBQUE7SUFFRixRQUFRLENBQUMsV0FBVyxFQUFDO1FBQ2pCLEVBQUUsQ0FBQyxnRkFBZ0YsRUFBQyxVQUFTLElBQUk7WUFDN0YsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7aUJBQ25CLElBQUksQ0FBQztnQkFDRixNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUNoQyxDQUFDLENBQUM7aUJBQ0QsSUFBSSxDQUFDO2dCQUNGLE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1lBQ25DLENBQUMsQ0FBQztpQkFDRCxJQUFJLENBQUM7Z0JBQ0YsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQyxDQUFDLENBQUE7SUFFRixRQUFRLENBQUMsYUFBYSxFQUFDO1FBQ25CLEVBQUUsQ0FBQyx5QkFBeUIsRUFBQyxVQUFTLElBQUk7WUFDdEMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7aUJBQ25CLElBQUksQ0FBQztnQkFDRixJQUFJLEVBQUUsQ0FBQTtZQUNWLENBQUMsQ0FBQyxDQUFBO1FBQ1YsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDLENBQUMsQ0FBQTtJQUVGLFFBQVEsQ0FBQyxtQkFBbUIsRUFBQztRQUN6QixFQUFFLENBQUMseUJBQXlCLEVBQUMsVUFBUyxJQUFJO1lBQ3RDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7aUJBQ1QsSUFBSSxDQUFDO2dCQUNGLElBQUksRUFBRSxDQUFBO1lBQ1YsQ0FBQyxDQUFDLENBQUE7UUFDVixDQUFDLENBQUMsQ0FBQTtJQUNOLENBQUMsQ0FBQyxDQUFBO0FBQ04sQ0FBQyxDQUFDLENBQUEifQ==
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHdCQUFxQjtBQUNyQixpQ0FBZ0M7QUFDaEMsNkJBQTRCO0FBRTVCLHFCQUFxQjtBQUNyQixPQUFPLENBQUMsR0FBRyxDQUFDLGFBQWEsR0FBRyx1REFBdUQsQ0FBQTtBQUNuRixPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsR0FBRywyQkFBMkIsQ0FBQTtBQUN4RCxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsR0FBRyxNQUFNLENBQUE7QUFDL0IsT0FBTyxDQUFDLEdBQUcsR0FBRztJQUNWLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBQyxTQUFTLENBQUMsQ0FBQTtBQUN6QyxDQUFDLENBQUE7QUFFRCxzQkFBc0I7QUFDdEIsK0RBQStEO0FBQy9ELHNEQUFzRDtBQUN0RCxnREFBZ0Q7QUFDaEQsOENBQThDO0FBRzlDLElBQUksV0FBd0MsQ0FBQTtBQUM1QyxJQUFJLFdBQXdDLENBQUE7QUFDNUMsSUFBSSxhQUE0QyxDQUFBO0FBRWhELFFBQVEsQ0FBQyxPQUFPLEVBQUM7SUFDYixRQUFRLENBQUMsY0FBYyxFQUFDO1FBQ3BCLEVBQUUsQ0FBQyxpQ0FBaUMsRUFBQztZQUNqQyxXQUFXLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsRUFBQyxRQUFRLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFBO1lBQ3JGLFdBQVcsR0FBRyxJQUFJLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxFQUFDLFFBQVEsRUFBRSx1QkFBdUIsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQTtZQUM5RixNQUFNLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUMzQyxNQUFNLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUNqRCxDQUFDLENBQUMsQ0FBQTtRQUVGLEVBQUUsQ0FBQyx3Q0FBd0MsRUFBQyxVQUFTLElBQUk7WUFDckQsZ0JBQWdCLENBQUMsZUFBZSxFQUFFO2lCQUM3QixJQUFJLENBQUMsVUFBUyx1QkFBc0Q7Z0JBQ2pFLE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUE7Z0JBQzVELGFBQWEsR0FBRyx1QkFBdUIsQ0FBQTtnQkFDdkMsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLHFDQUFxQyxFQUFDLFVBQVMsSUFBSTtZQUNsRCxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDO2lCQUMxQyxJQUFJLENBQUMsVUFBUyxjQUE2QztnQkFDeEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQTtnQkFDM0IsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLDRDQUE0QyxFQUFFLFVBQVMsSUFBSTtZQUMxRCxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUU7aUJBQ25CLElBQUksQ0FBQztnQkFDRixJQUFJLEVBQUUsQ0FBQTtZQUNWLENBQUMsQ0FBQyxDQUFBO1FBQ1YsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDLENBQUMsQ0FBQTtJQUVGLFFBQVEsQ0FBQyxpQkFBaUIsRUFBQztRQUN2QixFQUFFLENBQUMsc0NBQXNDLEVBQUMsVUFBUyxJQUFJO1lBQ25ELFlBQVksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO2lCQUN6QixJQUFJLENBQUM7Z0JBQ0YsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQyxDQUFDLENBQUE7SUFFRixRQUFRLENBQUMsV0FBVyxFQUFDO1FBQ2pCLEVBQUUsQ0FBQyxnRkFBZ0YsRUFBQyxVQUFTLElBQUk7WUFDN0YsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7aUJBQ25CLElBQUksQ0FBQztnQkFDRixNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUNoQyxDQUFDLENBQUM7aUJBQ0QsSUFBSSxDQUFDO2dCQUNGLE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1lBQ25DLENBQUMsQ0FBQztpQkFDRCxJQUFJLENBQUM7Z0JBQ0YsSUFBSSxFQUFFLENBQUE7WUFDVixDQUFDLENBQUMsQ0FBQTtRQUNWLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQyxDQUFDLENBQUE7SUFFRixRQUFRLENBQUMsYUFBYSxFQUFDO1FBQ25CLEVBQUUsQ0FBQyx5QkFBeUIsRUFBQyxVQUFTLElBQUk7WUFDdEMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7aUJBQ25CLElBQUksQ0FBQztnQkFDRixJQUFJLEVBQUUsQ0FBQTtZQUNWLENBQUMsQ0FBQyxDQUFBO1FBQ1YsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDLENBQUMsQ0FBQTtJQUVGLFFBQVEsQ0FBQyxtQkFBbUIsRUFBQztRQUN6QixFQUFFLENBQUMseUJBQXlCLEVBQUMsVUFBUyxJQUFJO1lBQ3RDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7aUJBQ1QsSUFBSSxDQUFDO2dCQUNGLElBQUksRUFBRSxDQUFBO1lBQ1YsQ0FBQyxDQUFDLENBQUE7UUFDVixDQUFDLENBQUMsQ0FBQTtJQUNOLENBQUMsQ0FBQyxDQUFBO0FBQ04sQ0FBQyxDQUFDLENBQUEifQ==
|
@ -1,7 +1,6 @@
|
|||||||
import 'typings-test'
|
import 'typings-test'
|
||||||
import * as should from 'should'
|
import * as should from 'should'
|
||||||
import path = require('path')
|
import * as path from 'path'
|
||||||
import * as beautylog from 'beautylog'
|
|
||||||
|
|
||||||
// set up environment
|
// set up environment
|
||||||
process.env.CI_BUILD_REPO = 'https://yyyyyy:xxxxxxxx@gitlab.com/mygroup/myrepo.git'
|
process.env.CI_BUILD_REPO = 'https://yyyyyy:xxxxxxxx@gitlab.com/mygroup/myrepo.git'
|
||||||
@ -12,7 +11,6 @@ process.cwd = () => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// require NPMCI files
|
// require NPMCI files
|
||||||
import npmci = require('../dist/index')
|
|
||||||
import NpmciBuildDocker = require('../dist/npmci.build.docker')
|
import NpmciBuildDocker = require('../dist/npmci.build.docker')
|
||||||
import NpmciPublish = require('../dist/npmci.publish')
|
import NpmciPublish = require('../dist/npmci.publish')
|
||||||
import NpmciTest = require('../dist/npmci.test')
|
import NpmciTest = require('../dist/npmci.test')
|
||||||
@ -44,7 +42,6 @@ describe('NPMCI',function(){
|
|||||||
it('should sort an array of Dockerfiles',function(done){
|
it('should sort an array of Dockerfiles',function(done){
|
||||||
NpmciBuildDocker.sortDockerfiles(sortableArray)
|
NpmciBuildDocker.sortDockerfiles(sortableArray)
|
||||||
.then(function(sortedArrayArg: NpmciBuildDocker.Dockerfile[]){
|
.then(function(sortedArrayArg: NpmciBuildDocker.Dockerfile[]){
|
||||||
beautylog.success('final result')
|
|
||||||
console.log(sortedArrayArg)
|
console.log(sortedArrayArg)
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
|
89
ts/index.ts
89
ts/index.ts
@ -1,89 +1,88 @@
|
|||||||
#!/usr/bin/env node
|
#!/usr/bin/env node
|
||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import * as paths from "./npmci.paths";
|
import * as paths from './npmci.paths'
|
||||||
let npmciInfo = new plugins.projectinfo.ProjectinfoNpm(paths.NpmciPackageRoot);
|
let npmciInfo = new plugins.projectinfo.ProjectinfoNpm(paths.NpmciPackageRoot)
|
||||||
plugins.beautylog.log("npmci version: " + npmciInfo.version);
|
plugins.beautylog.log('npmci version: ' + npmciInfo.version)
|
||||||
|
|
||||||
import {build} from "./npmci.build"
|
import {build} from './npmci.build'
|
||||||
import {clean} from "./npmci.clean";
|
import {clean} from './npmci.clean'
|
||||||
import {command} from "./npmci.command";
|
import {command} from './npmci.command'
|
||||||
import {install} from "./npmci.install";
|
import {install} from './npmci.install'
|
||||||
import {publish} from "./npmci.publish";
|
import {publish} from './npmci.publish'
|
||||||
import {prepare} from "./npmci.prepare";
|
import {prepare} from './npmci.prepare'
|
||||||
import {test} from "./npmci.test";
|
import {test} from './npmci.test'
|
||||||
import {trigger} from "./npmci.trigger";
|
import {trigger} from './npmci.trigger'
|
||||||
import * as NpmciEnv from "./npmci.env";
|
import * as NpmciEnv from './npmci.env'
|
||||||
|
|
||||||
export {build} from "./npmci.build"
|
export {build} from './npmci.build'
|
||||||
export {install} from "./npmci.install";
|
export {install} from './npmci.install';
|
||||||
export {publish} from "./npmci.publish";
|
export {publish} from './npmci.publish';
|
||||||
|
|
||||||
|
let smartcli = new plugins.smartcli.Smartcli()
|
||||||
let smartcli = new plugins.smartcli.Smartcli();
|
smartcli.addVersion(npmciInfo.version)
|
||||||
smartcli.addVersion(npmciInfo.version);
|
|
||||||
|
|
||||||
// build
|
// build
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"build"
|
commandName: 'build'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
build(argv._[1])
|
build(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// clean
|
// clean
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"clean"
|
commandName: 'clean'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
clean()
|
clean()
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// command
|
// command
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"command"
|
commandName: 'command'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
command()
|
command()
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// install
|
// install
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"install"
|
commandName: 'install'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
install(argv._[1])
|
install(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// prepare
|
// prepare
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"prepare"
|
commandName: 'prepare'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
prepare(argv._[1])
|
prepare(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// publish
|
// publish
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"publish"
|
commandName: 'publish'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
publish(argv._[1])
|
publish(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// test
|
// test
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"test"
|
commandName: 'test'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
test(argv._[1])
|
test(argv._[1])
|
||||||
.then(NpmciEnv.configStore);
|
.then(NpmciEnv.configStore)
|
||||||
});
|
})
|
||||||
|
|
||||||
// trigger
|
// trigger
|
||||||
smartcli.addCommand({
|
smartcli.addCommand({
|
||||||
commandName:"trigger"
|
commandName: 'trigger'
|
||||||
}).then((argv) => {
|
}).then((argv) => {
|
||||||
trigger();
|
trigger()
|
||||||
});
|
})
|
||||||
|
|
||||||
smartcli.startParse();
|
smartcli.startParse()
|
||||||
|
@ -1,50 +1,49 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
|
|
||||||
|
let nvmSourceString: string = ''
|
||||||
let nvmSourceString: string = "";
|
export let nvmAvailable: boolean = false
|
||||||
export let nvmAvailable: boolean = false;
|
|
||||||
let checkNvm = () => {
|
let checkNvm = () => {
|
||||||
if (plugins.shelljs.exec(`bash -c "source /usr/local/nvm/nvm.sh"`,{silent:true}).code === 0) {
|
if (plugins.shelljs.exec(`bash -c "source /usr/local/nvm/nvm.sh"`,{silent: true}).code === 0) {
|
||||||
nvmSourceString = `source /usr/local/nvm/nvm.sh && `
|
nvmSourceString = `source /usr/local/nvm/nvm.sh && `
|
||||||
nvmAvailable = true;
|
nvmAvailable = true
|
||||||
} else if (plugins.shelljs.exec(`bash -c "source ~/.nvm/nvm.sh"`,{silent:true}).code === 0) {
|
} else if (plugins.shelljs.exec(`bash -c "source ~/.nvm/nvm.sh"`,{silent: true}).code === 0) {
|
||||||
nvmSourceString = `source ~/.nvm/nvm.sh && `
|
nvmSourceString = `source ~/.nvm/nvm.sh && `
|
||||||
nvmAvailable = true;
|
nvmAvailable = true
|
||||||
};
|
};
|
||||||
};
|
}
|
||||||
checkNvm();
|
checkNvm()
|
||||||
|
|
||||||
export let bash = (commandArg: string, retryArg = 2, bareArg = false) => {
|
export let bash = (commandArg: string, retryArg = 2, bareArg = false) => {
|
||||||
let exitCode: number;
|
let exitCode: number
|
||||||
let stdOut: string;
|
let stdOut: string
|
||||||
let execResult;
|
let execResult
|
||||||
if (!process.env.NPMTS_TEST) { // NPMTS_TEST is used during testing
|
if (!process.env.NPMTS_TEST) { // NPMTS_TEST is used during testing
|
||||||
for (let i = 0; i <= retryArg; i++) {
|
for (let i = 0; i <= retryArg; i++) {
|
||||||
if (!bareArg) {
|
if (!bareArg) {
|
||||||
execResult = plugins.shelljs.exec(
|
execResult = plugins.shelljs.exec(
|
||||||
`bash -c "${nvmSourceString} ${commandArg}"`
|
`bash -c "${nvmSourceString} ${commandArg}"`
|
||||||
);
|
)
|
||||||
} else {
|
} else {
|
||||||
execResult = plugins.shelljs.exec(commandArg);
|
execResult = plugins.shelljs.exec(commandArg)
|
||||||
}
|
}
|
||||||
exitCode = execResult.code;
|
exitCode = execResult.code
|
||||||
stdOut = execResult.stdout;
|
stdOut = execResult.stdout
|
||||||
if (exitCode !== 0 && i == retryArg) {
|
if (exitCode !== 0 && i === retryArg) {
|
||||||
process.exit(1);
|
process.exit(1)
|
||||||
} else if (exitCode == 0) {
|
} else if (exitCode === 0) {
|
||||||
i = retryArg + 1; // if everything works out ok retrials are not wanted
|
i = retryArg + 1 // if everything works out ok retrials are not wanted
|
||||||
} else {
|
} else {
|
||||||
plugins.beautylog.warn("Something went wrong! Exit Code: " + exitCode.toString());
|
plugins.beautylog.warn('Something went wrong! Exit Code: ' + exitCode.toString())
|
||||||
plugins.beautylog.info("Retry " + (i + 1).toString() + " of " + retryArg.toString());
|
plugins.beautylog.info('Retry ' + (i + 1).toString() + ' of ' + retryArg.toString())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
plugins.beautylog.log("ShellExec would be: " + commandArg)
|
plugins.beautylog.log('ShellExec would be: ' + commandArg)
|
||||||
}
|
}
|
||||||
return stdOut;
|
return stdOut
|
||||||
}
|
}
|
||||||
|
|
||||||
export let bashBare = (commandArg, retryArg = 2) => {
|
export let bashBare = (commandArg, retryArg = 2) => {
|
||||||
return bash(commandArg, retryArg, true);
|
return bash(commandArg, retryArg, true)
|
||||||
}
|
}
|
@ -1,43 +1,43 @@
|
|||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import * as paths from "./npmci.paths";
|
import * as paths from './npmci.paths'
|
||||||
import * as NpmciEnv from "./npmci.env";
|
import * as NpmciEnv from './npmci.env'
|
||||||
import {bashBare} from "./npmci.bash";
|
import {bashBare} from './npmci.bash'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* builds a cwd of Dockerfiles by triggering a promisechain
|
* builds a cwd of Dockerfiles by triggering a promisechain
|
||||||
*/
|
*/
|
||||||
export let build = function(){
|
export let build = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
readDockerfiles()
|
readDockerfiles()
|
||||||
.then(sortDockerfiles)
|
.then(sortDockerfiles)
|
||||||
.then(mapDockerfiles)
|
.then(mapDockerfiles)
|
||||||
.then(buildDockerfiles)
|
.then(buildDockerfiles)
|
||||||
.then(pushDockerfiles)
|
.then(pushDockerfiles)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
done.resolve();
|
done.resolve()
|
||||||
});
|
})
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* creates instance of class Dockerfile for all Dockerfiles in cwd
|
* creates instance of class Dockerfile for all Dockerfiles in cwd
|
||||||
* @returns Promise<Dockerfile[]>
|
* @returns Promise<Dockerfile[]>
|
||||||
*/
|
*/
|
||||||
export let readDockerfiles = function():plugins.q.Promise<Dockerfile[]>{
|
export let readDockerfiles = function(): plugins.q.Promise<Dockerfile[]>{
|
||||||
let done = plugins.q.defer<Dockerfile[]>();
|
let done = plugins.q.defer<Dockerfile[]>()
|
||||||
let readDockerfilesArray:Dockerfile[] = []
|
let readDockerfilesArray: Dockerfile[] = []
|
||||||
plugins.gulp.src("./Dockerfile*")
|
plugins.gulp.src('./Dockerfile*')
|
||||||
.pipe(plugins.through2.obj(function(file,enc,cb){
|
.pipe(plugins.through2.obj(function(file,enc,cb){
|
||||||
let myDockerfile = new Dockerfile({
|
let myDockerfile = new Dockerfile({
|
||||||
filePath:file.path,
|
filePath: file.path,
|
||||||
read:true
|
read: true
|
||||||
});
|
})
|
||||||
readDockerfilesArray.push(myDockerfile);
|
readDockerfilesArray.push(myDockerfile)
|
||||||
cb(null,file);
|
cb(null,file)
|
||||||
},function(){
|
},function(){
|
||||||
done.resolve(readDockerfilesArray);
|
done.resolve(readDockerfilesArray)
|
||||||
}));
|
}))
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -45,249 +45,249 @@ export let readDockerfiles = function():plugins.q.Promise<Dockerfile[]>{
|
|||||||
* @param sortableArrayArg an array of instances of class Dockerfile
|
* @param sortableArrayArg an array of instances of class Dockerfile
|
||||||
* @returns Promise<Dockerfile[]>
|
* @returns Promise<Dockerfile[]>
|
||||||
*/
|
*/
|
||||||
export let sortDockerfiles = function(sortableArrayArg:Dockerfile[]):plugins.q.Promise<Dockerfile[]>{
|
export let sortDockerfiles = function(sortableArrayArg: Dockerfile[]): plugins.q.Promise<Dockerfile[]>{
|
||||||
let done = plugins.q.defer<Dockerfile[]>();
|
let done = plugins.q.defer<Dockerfile[]>()
|
||||||
let sortedArray:Dockerfile[] = [];
|
let sortedArray: Dockerfile[] = []
|
||||||
let cleanTagsOriginal = cleanTagsArrayFunction(sortableArrayArg,sortedArray);
|
let cleanTagsOriginal = cleanTagsArrayFunction(sortableArrayArg,sortedArray)
|
||||||
let sorterFunctionCounter:number = 0;
|
let sorterFunctionCounter: number = 0
|
||||||
let sorterFunction = function(){
|
let sorterFunction = function(){
|
||||||
sortableArrayArg.forEach((dockerfileArg)=>{
|
sortableArrayArg.forEach((dockerfileArg) => {
|
||||||
let cleanTags = cleanTagsArrayFunction(sortableArrayArg,sortedArray);
|
let cleanTags = cleanTagsArrayFunction(sortableArrayArg,sortedArray)
|
||||||
if(cleanTags.indexOf(dockerfileArg.baseImage) == -1 && sortedArray.indexOf(dockerfileArg) == -1){
|
if (cleanTags.indexOf(dockerfileArg.baseImage) === -1 && sortedArray.indexOf(dockerfileArg) === -1) {
|
||||||
sortedArray.push(dockerfileArg);
|
sortedArray.push(dockerfileArg)
|
||||||
};
|
};
|
||||||
if(cleanTagsOriginal.indexOf(dockerfileArg.baseImage) != -1){
|
if (cleanTagsOriginal.indexOf(dockerfileArg.baseImage) !== -1) {
|
||||||
dockerfileArg.localBaseImageDependent = true;
|
dockerfileArg.localBaseImageDependent = true
|
||||||
};
|
};
|
||||||
});
|
})
|
||||||
if(sortableArrayArg.length == sortedArray.length){
|
if (sortableArrayArg.length === sortedArray.length) {
|
||||||
done.resolve(sortedArray);
|
done.resolve(sortedArray)
|
||||||
} else if (sorterFunctionCounter < 10) {
|
} else if (sorterFunctionCounter < 10) {
|
||||||
sorterFunctionCounter++;
|
sorterFunctionCounter++
|
||||||
sorterFunction();
|
sorterFunction()
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
sorterFunction();
|
sorterFunction()
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* maps local Dockerfiles dependencies to the correspoding Dockerfile class instances
|
* maps local Dockerfiles dependencies to the correspoding Dockerfile class instances
|
||||||
*/
|
*/
|
||||||
export let mapDockerfiles = function(sortedArray:Dockerfile[]):plugins.q.Promise<Dockerfile[]>{
|
export let mapDockerfiles = function(sortedArray: Dockerfile[]): plugins.q.Promise<Dockerfile[]>{
|
||||||
let done = plugins.q.defer<Dockerfile[]>();
|
let done = plugins.q.defer<Dockerfile[]>()
|
||||||
sortedArray.forEach((dockerfileArg) => {
|
sortedArray.forEach((dockerfileArg) => {
|
||||||
if(dockerfileArg.localBaseImageDependent){
|
if (dockerfileArg.localBaseImageDependent) {
|
||||||
sortedArray.forEach((dockfile2:Dockerfile) => {
|
sortedArray.forEach((dockfile2: Dockerfile) => {
|
||||||
if(dockfile2.cleanTag == dockerfileArg.baseImage){
|
if (dockfile2.cleanTag === dockerfileArg.baseImage) {
|
||||||
dockerfileArg.localBaseDockerfile = dockfile2;
|
dockerfileArg.localBaseDockerfile = dockfile2
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
};
|
};
|
||||||
});
|
})
|
||||||
done.resolve(sortedArray);
|
done.resolve(sortedArray)
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* builds the correspoding real docker image for each Dockerfile class instance
|
* builds the correspoding real docker image for each Dockerfile class instance
|
||||||
*/
|
*/
|
||||||
export let buildDockerfiles = (sortedArrayArg:Dockerfile[]) => {
|
export let buildDockerfiles = (sortedArrayArg: Dockerfile[]) => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
sortedArrayArg.forEach(function(dockerfileArg){
|
sortedArrayArg.forEach(function(dockerfileArg){
|
||||||
dockerfileArg.build();
|
dockerfileArg.build()
|
||||||
})
|
})
|
||||||
done.resolve(sortedArrayArg);
|
done.resolve(sortedArrayArg)
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* pushes the real Dockerfile images to a Docker registry
|
* pushes the real Dockerfile images to a Docker registry
|
||||||
*/
|
*/
|
||||||
export let pushDockerfiles = function(sortedArrayArg:Dockerfile[]){
|
export let pushDockerfiles = function(sortedArrayArg: Dockerfile[]){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
sortedArrayArg.forEach(function(dockerfileArg){
|
sortedArrayArg.forEach(function(dockerfileArg){
|
||||||
dockerfileArg.push(NpmciEnv.buildStage);
|
dockerfileArg.push(NpmciEnv.buildStage)
|
||||||
});
|
})
|
||||||
done.resolve(sortedArrayArg);
|
done.resolve(sortedArrayArg)
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* pulls corresponding real Docker images for instances of Dockerfile from a registry.
|
* pulls corresponding real Docker images for instances of Dockerfile from a registry.
|
||||||
* This is needed if building, testing, and publishing of Docker images is carried out in seperate CI stages.
|
* This is needed if building, testing, and publishing of Docker images is carried out in seperate CI stages.
|
||||||
*/
|
*/
|
||||||
export let pullDockerfileImages = (sortableArrayArg:Dockerfile[],registryArg = "registry.gitlab.com") => {
|
export let pullDockerfileImages = (sortableArrayArg: Dockerfile[],registryArg = 'registry.gitlab.com') => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
sortableArrayArg.forEach((dockerfileArg) => {
|
sortableArrayArg.forEach((dockerfileArg) => {
|
||||||
dockerfileArg.pull(registryArg);
|
dockerfileArg.pull(registryArg)
|
||||||
});
|
})
|
||||||
done.resolve(sortableArrayArg);
|
done.resolve(sortableArrayArg)
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* tests all Dockerfiles in by calling class Dockerfile.test();
|
* tests all Dockerfiles in by calling class Dockerfile.test();
|
||||||
* @param sortedArrayArg Dockerfile[] that contains all Dockerfiles in cwd
|
* @param sortedArrayArg Dockerfile[] that contains all Dockerfiles in cwd
|
||||||
*/
|
*/
|
||||||
export let testDockerfiles = (sortedArrayArg:Dockerfile[]) => {
|
export let testDockerfiles = (sortedArrayArg: Dockerfile[]) => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
sortedArrayArg.forEach(function(dockerfileArg){
|
sortedArrayArg.forEach(function(dockerfileArg){
|
||||||
dockerfileArg.test();
|
dockerfileArg.test()
|
||||||
});
|
})
|
||||||
done.resolve(sortedArrayArg);
|
done.resolve(sortedArrayArg)
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* class Dockerfile represents a Dockerfile on disk in npmci
|
* class Dockerfile represents a Dockerfile on disk in npmci
|
||||||
*/
|
*/
|
||||||
export class Dockerfile {
|
export class Dockerfile {
|
||||||
filePath:string;
|
filePath: string
|
||||||
repo:string;
|
repo: string
|
||||||
version:string;
|
version: string
|
||||||
cleanTag:string;
|
cleanTag: string
|
||||||
buildTag:string;
|
buildTag: string
|
||||||
testTag:string;
|
testTag: string
|
||||||
releaseTag:string;
|
releaseTag: string
|
||||||
containerName:string
|
containerName: string
|
||||||
content:string;
|
content: string
|
||||||
baseImage:string;
|
baseImage: string
|
||||||
localBaseImageDependent:boolean;
|
localBaseImageDependent: boolean
|
||||||
localBaseDockerfile:Dockerfile;
|
localBaseDockerfile: Dockerfile
|
||||||
constructor(options:{filePath?:string,fileContents?:string|Buffer,read?:boolean}){
|
constructor(options: {filePath?: string,fileContents?: string|Buffer,read?: boolean}) {
|
||||||
this.filePath = options.filePath;
|
this.filePath = options.filePath
|
||||||
this.repo = NpmciEnv.repo.user + "/" + NpmciEnv.repo.repo;
|
this.repo = NpmciEnv.repo.user + '/' + NpmciEnv.repo.repo
|
||||||
this.version = dockerFileVersion(plugins.path.parse(options.filePath).base);
|
this.version = dockerFileVersion(plugins.path.parse(options.filePath).base)
|
||||||
this.cleanTag = this.repo + ":" + this.version;
|
this.cleanTag = this.repo + ':' + this.version
|
||||||
this.buildTag = this.cleanTag;
|
this.buildTag = this.cleanTag
|
||||||
this.testTag = dockerTag("registry.gitlab.com",this.repo,this.version,"test");
|
this.testTag = dockerTag('registry.gitlab.com',this.repo,this.version,'test')
|
||||||
this.releaseTag = dockerTag(NpmciEnv.dockerRegistry,this.repo,this.version);
|
this.releaseTag = dockerTag(NpmciEnv.dockerRegistry,this.repo,this.version)
|
||||||
this.containerName = "dockerfile-" + this.version;
|
this.containerName = 'dockerfile-' + this.version
|
||||||
if(options.filePath && options.read){
|
if (options.filePath && options.read) {
|
||||||
this.content = plugins.smartfile.fs.toStringSync(plugins.path.resolve(options.filePath));
|
this.content = plugins.smartfile.fs.toStringSync(plugins.path.resolve(options.filePath))
|
||||||
};
|
};
|
||||||
this.baseImage = dockerBaseImage(this.content);
|
this.baseImage = dockerBaseImage(this.content)
|
||||||
this.localBaseImageDependent = false;
|
this.localBaseImageDependent = false
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* builds the Dockerfile
|
* builds the Dockerfile
|
||||||
*/
|
*/
|
||||||
build(){
|
build() {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
plugins.beautylog.info("now building Dockerfile for " + this.cleanTag);
|
plugins.beautylog.info('now building Dockerfile for ' + this.cleanTag)
|
||||||
bashBare("docker build -t " + this.buildTag + " -f " + this.filePath + " .");
|
bashBare('docker build -t ' + this.buildTag + ' -f ' + this.filePath + ' .')
|
||||||
NpmciEnv.dockerFilesBuilt.push(this);
|
NpmciEnv.dockerFilesBuilt.push(this)
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* pushes the Dockerfile to a registry
|
* pushes the Dockerfile to a registry
|
||||||
*/
|
*/
|
||||||
push(stageArg){
|
push(stageArg) {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
let pushTag;
|
let pushTag
|
||||||
switch (stageArg){
|
switch (stageArg) {
|
||||||
case "release":
|
case 'release':
|
||||||
pushTag = this.releaseTag;
|
pushTag = this.releaseTag
|
||||||
break;
|
break
|
||||||
case "test":
|
case 'test':
|
||||||
default:
|
default:
|
||||||
pushTag = this.testTag;
|
pushTag = this.testTag
|
||||||
break;
|
break
|
||||||
}
|
}
|
||||||
bashBare("docker tag " + this.buildTag + " " + pushTag);
|
bashBare('docker tag ' + this.buildTag + ' ' + pushTag)
|
||||||
bashBare("docker push " + pushTag);
|
bashBare('docker push ' + pushTag)
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* pulls the Dockerfile from a registry
|
* pulls the Dockerfile from a registry
|
||||||
*/
|
*/
|
||||||
pull(registryArg:string){
|
pull(registryArg: string) {
|
||||||
let pullTag = this.testTag;
|
let pullTag = this.testTag
|
||||||
bashBare("docker pull " + pullTag);
|
bashBare('docker pull ' + pullTag)
|
||||||
bashBare("docker tag " + pullTag + " " + this.buildTag);
|
bashBare('docker tag ' + pullTag + ' ' + this.buildTag)
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* tests the Dockerfile;
|
* tests the Dockerfile;
|
||||||
*/
|
*/
|
||||||
test(){
|
test() {
|
||||||
let testFile:string = plugins.path.join(paths.NpmciTestDir,"test_" + this.version + ".sh");
|
let testFile: string = plugins.path.join(paths.NpmciTestDir,'test_' + this.version + '.sh')
|
||||||
let testFileExists:boolean = plugins.smartfile.fs.fileExistsSync(testFile);
|
let testFileExists: boolean = plugins.smartfile.fs.fileExistsSync(testFile)
|
||||||
if(testFileExists){
|
if (testFileExists) {
|
||||||
bashBare("docker run --name npmci_test_container " + this.buildTag + " mkdir /npmci_test");
|
bashBare('docker run --name npmci_test_container ' + this.buildTag + ' mkdir /npmci_test')
|
||||||
bashBare("docker cp " + testFile + " npmci_test_container:/npmci_test/test.sh");
|
bashBare('docker cp ' + testFile + ' npmci_test_container:/npmci_test/test.sh')
|
||||||
bashBare("docker commit npmci_test_container npmci_test_image");
|
bashBare('docker commit npmci_test_container npmci_test_image')
|
||||||
bashBare("docker run npmci_test_image sh /npmci_test/test.sh");
|
bashBare('docker run npmci_test_image sh /npmci_test/test.sh')
|
||||||
bashBare("docker rm npmci_test_container");
|
bashBare('docker rm npmci_test_container')
|
||||||
bashBare("docker rmi --force npmci_test_image");
|
bashBare('docker rmi --force npmci_test_image')
|
||||||
} else {
|
} else {
|
||||||
plugins.beautylog.warn("skipping tests for " + this.cleanTag + " because no testfile was found!");
|
plugins.beautylog.warn('skipping tests for ' + this.cleanTag + ' because no testfile was found!')
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gets the id of a Dockerfile
|
* gets the id of a Dockerfile
|
||||||
*/
|
*/
|
||||||
getId(){
|
getId() {
|
||||||
let containerId = bashBare("docker inspect --type=image --format=\"{{.Id}}\" " + this.buildTag);
|
let containerId = bashBare('docker inspect --type=image --format=\"{{.Id}}\" ' + this.buildTag)
|
||||||
return containerId;
|
return containerId
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
export let dockerFileVersion = function(dockerfileNameArg:string):string{
|
export let dockerFileVersion = function(dockerfileNameArg: string): string{
|
||||||
let versionString:string;
|
let versionString: string
|
||||||
let versionRegex = /Dockerfile_([a-zA-Z0-9\.]*)$/;
|
let versionRegex = /Dockerfile_([a-zA-Z0-9\.]*)$/
|
||||||
let regexResultArray = versionRegex.exec(dockerfileNameArg);
|
let regexResultArray = versionRegex.exec(dockerfileNameArg)
|
||||||
if(regexResultArray && regexResultArray.length == 2){
|
if (regexResultArray && regexResultArray.length === 2) {
|
||||||
versionString = regexResultArray[1];
|
versionString = regexResultArray[1]
|
||||||
} else {
|
} else {
|
||||||
versionString = "latest";
|
versionString = 'latest'
|
||||||
}
|
}
|
||||||
return versionString;
|
return versionString
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
export let dockerBaseImage = function(dockerfileContentArg:string){
|
export let dockerBaseImage = function(dockerfileContentArg: string){
|
||||||
let baseImageRegex = /FROM\s([a-zA-z0-9\/\-\:]*)\n?/
|
let baseImageRegex = /FROM\s([a-zA-z0-9\/\-\:]*)\n?/
|
||||||
let regexResultArray = baseImageRegex.exec(dockerfileContentArg)
|
let regexResultArray = baseImageRegex.exec(dockerfileContentArg)
|
||||||
return regexResultArray[1];
|
return regexResultArray[1]
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
export let dockerTag = function(registryArg:string,repoArg:string,versionArg:string,suffixArg?:string):string{
|
export let dockerTag = function(registryArg: string,repoArg: string,versionArg: string,suffixArg?: string): string{
|
||||||
let tagString:string;
|
let tagString: string
|
||||||
let registry = registryArg;
|
let registry = registryArg
|
||||||
let repo = repoArg;
|
let repo = repoArg
|
||||||
let version = versionArg;
|
let version = versionArg
|
||||||
if(suffixArg){
|
if (suffixArg) {
|
||||||
version = versionArg + "_" + suffixArg;
|
version = versionArg + '_' + suffixArg
|
||||||
};
|
};
|
||||||
tagString = registry + "/" + repo + ":" + version;
|
tagString = registry + '/' + repo + ':' + version
|
||||||
return tagString;
|
return tagString
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
export let cleanTagsArrayFunction = function(dockerfileArrayArg:Dockerfile[],trackingArrayArg:Dockerfile[]):string[]{
|
export let cleanTagsArrayFunction = function(dockerfileArrayArg: Dockerfile[],trackingArrayArg: Dockerfile[]): string[]{
|
||||||
let cleanTagsArray:string[] = [];
|
let cleanTagsArray: string[] = []
|
||||||
dockerfileArrayArg.forEach(function(dockerfileArg){
|
dockerfileArrayArg.forEach(function(dockerfileArg){
|
||||||
if(trackingArrayArg.indexOf(dockerfileArg) == -1){
|
if (trackingArrayArg.indexOf(dockerfileArg) === -1) {
|
||||||
cleanTagsArray.push(dockerfileArg.cleanTag);
|
cleanTagsArray.push(dockerfileArg.cleanTag)
|
||||||
}
|
}
|
||||||
});
|
})
|
||||||
return cleanTagsArray;
|
return cleanTagsArray
|
||||||
}
|
}
|
@ -1,26 +1,23 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import {bash} from "./npmci.bash";
|
import {bash} from './npmci.bash'
|
||||||
import * as env from "./npmci.env";
|
import * as env from './npmci.env'
|
||||||
import * as buildDocker from "./npmci.build.docker"
|
import * as buildDocker from './npmci.build.docker'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* defines possible build services
|
* defines possible build services
|
||||||
*/
|
*/
|
||||||
export type TBuildService = "docker";
|
export type TBuildService = 'docker';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* builds for a specific service
|
* builds for a specific service
|
||||||
*/
|
*/
|
||||||
export let build = function(commandArg):plugins.q.Promise<any> {
|
export let build = function(commandArg): plugins.q.Promise<any> {
|
||||||
switch(commandArg){
|
switch (commandArg) {
|
||||||
case "docker":
|
case 'docker':
|
||||||
return buildDocker.build();
|
return buildDocker.build()
|
||||||
default:
|
default:
|
||||||
plugins.beautylog.log("build target " + commandArg + " not recognised!");
|
plugins.beautylog.log('build target ' + commandArg + ' not recognised!')
|
||||||
};
|
};
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
20
ts/npmci.config.ts
Normal file
20
ts/npmci.config.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import * as q from 'q'
|
||||||
|
|
||||||
|
import * as plugins from './npmci.plugins'
|
||||||
|
import * as paths from './npmci.paths'
|
||||||
|
|
||||||
|
export interface INpmciOptions {
|
||||||
|
globalNpmTools: string[]
|
||||||
|
}
|
||||||
|
|
||||||
|
export let getConfig = () => {
|
||||||
|
console.log('getting config')
|
||||||
|
let done = q.defer<INpmciOptions>()
|
||||||
|
let npmciNpmextra = new plugins.npmextra.Npmextra(paths.cwd)
|
||||||
|
let defaultConfig: INpmciOptions = {
|
||||||
|
globalNpmTools: []
|
||||||
|
}
|
||||||
|
let npmciConfig = npmciNpmextra.dataFor<INpmciOptions>('npmci', defaultConfig)
|
||||||
|
done.resolve(npmciConfig)
|
||||||
|
return done.promise
|
||||||
|
}
|
@ -1,8 +1,8 @@
|
|||||||
import 'typings-global';
|
import 'typings-global'
|
||||||
import * as plugins from './npmci.plugins';
|
import * as plugins from './npmci.plugins'
|
||||||
import { bash } from './npmci.bash';
|
import * as configModule from './npmci.config'
|
||||||
|
import { bash } from './npmci.bash'
|
||||||
import { nvmAvailable } from './npmci.bash'
|
import { nvmAvailable } from './npmci.bash'
|
||||||
|
|
||||||
export let install = (versionArg) => {
|
export let install = (versionArg) => {
|
||||||
let done = plugins.q.defer()
|
let done = plugins.q.defer()
|
||||||
plugins.beautylog.log(`now installing node version ${versionArg}`)
|
plugins.beautylog.log(`now installing node version ${versionArg}`)
|
||||||
@ -24,6 +24,15 @@ export let install = (versionArg) => {
|
|||||||
};
|
};
|
||||||
bash('node -v')
|
bash('node -v')
|
||||||
bash('npm -v')
|
bash('npm -v')
|
||||||
|
|
||||||
|
// lets look for further config
|
||||||
|
configModule.getConfig()
|
||||||
|
.then(config => {
|
||||||
|
for (let npmTool of config.globalNpmTools) {
|
||||||
|
plugins.beautylog.info(`globally installing ${npmTool} from npm`)
|
||||||
|
bash(`npm install --loglevel=silent -g ${npmTool}`)
|
||||||
|
}
|
||||||
done.resolve()
|
done.resolve()
|
||||||
|
})
|
||||||
return done.promise
|
return done.promise
|
||||||
}
|
}
|
@ -1,9 +1,9 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
|
|
||||||
export let cwd = process.cwd();
|
export let cwd = process.cwd()
|
||||||
|
|
||||||
export let NpmciPackageRoot = plugins.path.join(__dirname,"../");
|
export let NpmciPackageRoot = plugins.path.join(__dirname,'../')
|
||||||
export let NpmciPackageConfig = plugins.path.join(NpmciPackageRoot,"./config.json");
|
export let NpmciPackageConfig = plugins.path.join(NpmciPackageRoot,'./config.json')
|
||||||
export let NpmciProjectDir = cwd;
|
export let NpmciProjectDir = cwd
|
||||||
export let NpmciTestDir = plugins.path.join(cwd,"./test");
|
export let NpmciTestDir = plugins.path.join(cwd,'./test')
|
||||||
|
@ -1,17 +1,18 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
export import beautylog = require("beautylog");
|
export import beautylog = require('beautylog')
|
||||||
export let gulp = require("gulp");
|
export let gulp = require('gulp')
|
||||||
export let gulpFunction = require("gulp-function");
|
export import gulpFunction = require('gulp-function')
|
||||||
export let lodash = require("lodash");
|
export import lodash = require('lodash')
|
||||||
export import path = require("path");
|
export import npmextra = require('npmextra')
|
||||||
export import projectinfo = require("projectinfo");
|
export import path = require('path')
|
||||||
export import q = require("q");
|
export import projectinfo = require('projectinfo')
|
||||||
export let request = require("request");
|
export import q = require('q')
|
||||||
export import shelljs = require("shelljs");
|
export let request = require('request')
|
||||||
export import smartcli = require("smartcli");
|
export import shelljs = require('shelljs')
|
||||||
export import smartfile = require("smartfile");
|
export import smartcli = require('smartcli')
|
||||||
export import smartparam = require("smartparam");
|
export import smartfile = require('smartfile')
|
||||||
export import smartsocket = require("smartsocket");
|
export import smartparam = require('smartparam')
|
||||||
export import smartssh = require("smartssh");
|
export import smartsocket = require('smartsocket')
|
||||||
export import smartstring = require("smartstring");
|
export import smartssh = require('smartssh')
|
||||||
export let through2 = require("through2");
|
export import smartstring = require('smartstring')
|
||||||
|
export import through2 = require('through2')
|
||||||
|
@ -1,94 +1,94 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import {bash} from "./npmci.bash";
|
import {bash} from './npmci.bash'
|
||||||
import * as env from "./npmci.env"
|
import * as env from './npmci.env'
|
||||||
import * as sshModule from "./npmci.ssh"
|
import * as sshModule from './npmci.ssh'
|
||||||
|
|
||||||
|
|
||||||
//types
|
// types
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* defines possible prepare services
|
* defines possible prepare services
|
||||||
*/
|
*/
|
||||||
export type TPrepService = "npm" | "docker" | "docker-gitlab" | "ssh";
|
export type TPrepService = 'npm' | 'docker' | 'docker-gitlab' | 'ssh';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* authenticates npm with token from env var
|
* authenticates npm with token from env var
|
||||||
*/
|
*/
|
||||||
let npm = function(){
|
let npm = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
|
|
||||||
let npmrcPrefix:string = "//registry.npmjs.org/:_authToken=";
|
let npmrcPrefix: string = '//registry.npmjs.org/:_authToken='
|
||||||
let npmToken:string = process.env.NPMCI_TOKEN_NPM;
|
let npmToken: string = process.env.NPMCI_TOKEN_NPM
|
||||||
let npmrcFileString = npmrcPrefix + npmToken;
|
let npmrcFileString = npmrcPrefix + npmToken
|
||||||
|
|
||||||
if(npmToken){
|
if (npmToken) {
|
||||||
plugins.beautylog.info("found access token");
|
plugins.beautylog.info('found access token')
|
||||||
} else {
|
} else {
|
||||||
plugins.beautylog.error("no access token found! Exiting!");
|
plugins.beautylog.error('no access token found! Exiting!')
|
||||||
process.exit(1);
|
process.exit(1)
|
||||||
}
|
}
|
||||||
plugins.smartfile.memory.toFsSync(npmrcFileString,"/root/.npmrc");
|
plugins.smartfile.memory.toFsSync(npmrcFileString,'/root/.npmrc')
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* logs in docker
|
* logs in docker
|
||||||
*/
|
*/
|
||||||
let docker = function(){
|
let docker = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
env.setDockerRegistry("docker.io");
|
env.setDockerRegistry('docker.io')
|
||||||
let dockerRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)/
|
let dockerRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)/
|
||||||
if(!process.env.NPMCI_LOGIN_DOCKER){
|
if (!process.env.NPMCI_LOGIN_DOCKER) {
|
||||||
plugins.beautylog.error("You have to specify Login Data to the Docker Registry");
|
plugins.beautylog.error('You have to specify Login Data to the Docker Registry')
|
||||||
process.exit(1);
|
process.exit(1)
|
||||||
}
|
}
|
||||||
plugins.shelljs.exec("docker login -u gitlab-ci-token -p " + process.env.CI_BUILD_TOKEN + " " + "registry.gitlab.com"); // Always also login to GitLab Registry
|
plugins.shelljs.exec('docker login -u gitlab-ci-token -p ' + process.env.CI_BUILD_TOKEN + ' ' + 'registry.gitlab.com') // Always also login to GitLab Registry
|
||||||
let dockerRegexResultArray = dockerRegex.exec(process.env.NPMCI_LOGIN_DOCKER);
|
let dockerRegexResultArray = dockerRegex.exec(process.env.NPMCI_LOGIN_DOCKER)
|
||||||
let username = dockerRegexResultArray[1];
|
let username = dockerRegexResultArray[1]
|
||||||
let password = dockerRegexResultArray[2];
|
let password = dockerRegexResultArray[2]
|
||||||
plugins.shelljs.exec("docker login -u " + username + " -p " + password);
|
plugins.shelljs.exec('docker login -u ' + username + ' -p ' + password)
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* prepare docker for gitlab registry
|
* prepare docker for gitlab registry
|
||||||
*/
|
*/
|
||||||
let dockerGitlab = function(){
|
let dockerGitlab = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
env.setDockerRegistry("registry.gitlab.com");
|
env.setDockerRegistry('registry.gitlab.com')
|
||||||
plugins.shelljs.exec("docker login -u gitlab-ci-token -p " + process.env.CI_BUILD_TOKEN + " " + "registry.gitlab.com");
|
plugins.shelljs.exec('docker login -u gitlab-ci-token -p ' + process.env.CI_BUILD_TOKEN + ' ' + 'registry.gitlab.com')
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* prepare ssh
|
* prepare ssh
|
||||||
*/
|
*/
|
||||||
let ssh = function(){
|
let ssh = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
sshModule.ssh()
|
sshModule.ssh()
|
||||||
.then(done.resolve);
|
.then(done.resolve)
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the main exported prepare function
|
* the main exported prepare function
|
||||||
* @param servieArg describes the service to prepare
|
* @param servieArg describes the service to prepare
|
||||||
*/
|
*/
|
||||||
export let prepare = function(serviceArg:TPrepService){
|
export let prepare = function(serviceArg: TPrepService){
|
||||||
switch (serviceArg) {
|
switch (serviceArg) {
|
||||||
case "npm":
|
case 'npm':
|
||||||
return npm();
|
return npm()
|
||||||
case "docker":
|
case 'docker':
|
||||||
return docker();
|
return docker()
|
||||||
case "docker-gitlab":
|
case 'docker-gitlab':
|
||||||
return dockerGitlab();
|
return dockerGitlab()
|
||||||
case "ssh":
|
case 'ssh':
|
||||||
return ssh();
|
return ssh()
|
||||||
default:
|
default:
|
||||||
break;
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,50 +1,50 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import {prepare} from "./npmci.prepare";
|
import {prepare} from './npmci.prepare'
|
||||||
import {bash} from "./npmci.bash";
|
import {bash} from './npmci.bash'
|
||||||
import * as NpmciEnv from "./npmci.env";
|
import * as NpmciEnv from './npmci.env'
|
||||||
import * as NpmciBuildDocker from "./npmci.build.docker"
|
import * as NpmciBuildDocker from './npmci.build.docker'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* type of supported services
|
* type of supported services
|
||||||
*/
|
*/
|
||||||
export type TPubService = "npm" | "docker";
|
export type TPubService = 'npm' | 'docker';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the main exported publish function.
|
* the main exported publish function.
|
||||||
* @param pubServiceArg references targeted service to publish to
|
* @param pubServiceArg references targeted service to publish to
|
||||||
*/
|
*/
|
||||||
export let publish = (pubServiceArg:TPubService = "npm") => {
|
export let publish = (pubServiceArg: TPubService = 'npm') => {
|
||||||
switch (pubServiceArg){
|
switch (pubServiceArg) {
|
||||||
case "npm":
|
case 'npm':
|
||||||
return publishNpm();
|
return publishNpm()
|
||||||
case "docker":
|
case 'docker':
|
||||||
return publishDocker();
|
return publishDocker()
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* tries to publish current cwd to NPM registry
|
* tries to publish current cwd to NPM registry
|
||||||
*/
|
*/
|
||||||
let publishNpm = function(){
|
let publishNpm = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
prepare("npm")
|
prepare('npm')
|
||||||
.then(function(){
|
.then(function(){
|
||||||
bash("npm publish");
|
bash('npm publish')
|
||||||
plugins.beautylog.ok("Done!") ;
|
plugins.beautylog.ok('Done!')
|
||||||
done.resolve();
|
done.resolve()
|
||||||
});
|
})
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* tries to pubish current cwd to Docker registry
|
* tries to pubish current cwd to Docker registry
|
||||||
*/
|
*/
|
||||||
let publishDocker = function(){
|
let publishDocker = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
NpmciBuildDocker.readDockerfiles()
|
NpmciBuildDocker.readDockerfiles()
|
||||||
.then(NpmciBuildDocker.pullDockerfileImages)
|
.then(NpmciBuildDocker.pullDockerfileImages)
|
||||||
.then(NpmciBuildDocker.pushDockerfiles)
|
.then(NpmciBuildDocker.pushDockerfiles)
|
||||||
.then(done.resolve);
|
.then(done.resolve)
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
}
|
||||||
|
@ -1,26 +1,26 @@
|
|||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* servezoneRegex is the regex that parses the servezone connection data
|
* servezoneRegex is the regex that parses the servezone connection data
|
||||||
* parses strings in the form of "servezone.example.com|3000|somepassword"
|
* parses strings in the form of "servezone.example.com|3000|somepassword"
|
||||||
*/
|
*/
|
||||||
let servezoneRegex = /^(.*)\|(.*)\|(.*)/;
|
let servezoneRegex = /^(.*)\|(.*)\|(.*)/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* holds the results of the parsed servezone env string
|
* holds the results of the parsed servezone env string
|
||||||
*/
|
*/
|
||||||
let servezoneRegexResultArray = servezoneRegex.exec(process.env.NPMCI_SERVEZONE);
|
let servezoneRegexResultArray = servezoneRegex.exec(process.env.NPMCI_SERVEZONE)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the data object that is used for the smartsocket client object
|
* the data object that is used for the smartsocket client object
|
||||||
*/
|
*/
|
||||||
let smartsocketClientConstructorOptions = {
|
let smartsocketClientConstructorOptions = {
|
||||||
alias: "npmci",
|
alias: 'npmci',
|
||||||
password: servezoneRegexResultArray[3],
|
password: servezoneRegexResultArray[3],
|
||||||
port: parseInt(servezoneRegexResultArray[2]),
|
port: parseInt(servezoneRegexResultArray[2]),
|
||||||
role: "ci",
|
role: 'ci',
|
||||||
url: servezoneRegexResultArray[1]
|
url: servezoneRegexResultArray[1]
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the main run function to submit a service to a servezone
|
* the main run function to submit a service to a servezone
|
||||||
@ -28,5 +28,5 @@ let smartsocketClientConstructorOptions = {
|
|||||||
export let run = (configArg) => {
|
export let run = (configArg) => {
|
||||||
new plugins.smartsocket.SmartsocketClient(
|
new plugins.smartsocket.SmartsocketClient(
|
||||||
smartsocketClientConstructorOptions
|
smartsocketClientConstructorOptions
|
||||||
);
|
)
|
||||||
};
|
}
|
||||||
|
@ -1,51 +1,51 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
|
|
||||||
let sshRegex = /^(.*)\|(.*)\|(.*)/
|
let sshRegex = /^(.*)\|(.*)\|(.*)/
|
||||||
let sshInstance:plugins.smartssh.SshInstance;
|
let sshInstance: plugins.smartssh.SshInstance
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* checks for ENV vars in form of NPMCI_SSHKEY_* and deploys any found ones
|
* checks for ENV vars in form of NPMCI_SSHKEY_* and deploys any found ones
|
||||||
*/
|
*/
|
||||||
export let ssh = () => {
|
export let ssh = () => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
sshInstance = new plugins.smartssh.SshInstance(); // init ssh instance
|
sshInstance = new plugins.smartssh.SshInstance() // init ssh instance
|
||||||
plugins.smartparam.forEachMinimatch(process.env,"NPMCI_SSHKEY_*",evaluateSshEnv);
|
plugins.smartparam.forEachMinimatch(process.env,'NPMCI_SSHKEY_*',evaluateSshEnv)
|
||||||
if(!process.env.NPMTS_TEST){
|
if (!process.env.NPMTS_TEST) {
|
||||||
sshInstance.writeToDisk();
|
sshInstance.writeToDisk()
|
||||||
} else {
|
} else {
|
||||||
plugins.beautylog.log("In test mode, so not storing SSH keys to disk!");
|
plugins.beautylog.log('In test mode, so not storing SSH keys to disk!')
|
||||||
};
|
};
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gets called for each found SSH ENV Var and deploys it
|
* gets called for each found SSH ENV Var and deploys it
|
||||||
*/
|
*/
|
||||||
let evaluateSshEnv = (sshkeyEnvVarArg) => {
|
let evaluateSshEnv = (sshkeyEnvVarArg) => {
|
||||||
let resultArray = sshRegex.exec(sshkeyEnvVarArg);
|
let resultArray = sshRegex.exec(sshkeyEnvVarArg)
|
||||||
let sshKey = new plugins.smartssh.SshKey();
|
let sshKey = new plugins.smartssh.SshKey()
|
||||||
plugins.beautylog.info("Found SSH identity for " + resultArray[1]);
|
plugins.beautylog.info('Found SSH identity for ' + resultArray[1])
|
||||||
if(notUndefined(resultArray[1])){
|
if (notUndefined(resultArray[1])) {
|
||||||
plugins.beautylog.log("---> host defined!")
|
plugins.beautylog.log('---> host defined!')
|
||||||
sshKey.host = resultArray[1];
|
sshKey.host = resultArray[1]
|
||||||
}
|
}
|
||||||
if(notUndefined(resultArray[2])){
|
if (notUndefined(resultArray[2])) {
|
||||||
plugins.beautylog.log("---> privKey defined!")
|
plugins.beautylog.log('---> privKey defined!')
|
||||||
sshKey.privKeyBase64 = resultArray[2];
|
sshKey.privKeyBase64 = resultArray[2]
|
||||||
};
|
};
|
||||||
if(notUndefined(resultArray[3])){
|
if (notUndefined(resultArray[3])) {
|
||||||
"---> pubKey defined!"
|
'---> pubKey defined!'
|
||||||
sshKey.pubKeyBase64 = resultArray[3];
|
sshKey.pubKeyBase64 = resultArray[3]
|
||||||
};
|
};
|
||||||
|
|
||||||
sshInstance.addKey(sshKey);
|
sshInstance.addKey(sshKey)
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* checks if not undefined
|
* checks if not undefined
|
||||||
*/
|
*/
|
||||||
let notUndefined = (stringArg:string) => {
|
let notUndefined = (stringArg: string) => {
|
||||||
return (stringArg && stringArg != "undefined" && stringArg != "##");
|
return (stringArg && stringArg !== 'undefined' && stringArg !== '##')
|
||||||
}
|
}
|
@ -1,50 +1,50 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import {bash} from "./npmci.bash";
|
import {bash} from './npmci.bash'
|
||||||
import {install} from "./npmci.install";
|
import {install} from './npmci.install'
|
||||||
import * as env from "./npmci.env";
|
import * as env from './npmci.env'
|
||||||
import * as NpmciBuildDocker from "./npmci.build.docker";
|
import * as NpmciBuildDocker from './npmci.build.docker'
|
||||||
|
|
||||||
export let test = (versionArg) => {
|
export let test = (versionArg) => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
if(versionArg == "docker"){
|
if (versionArg === 'docker') {
|
||||||
testDocker()
|
testDocker()
|
||||||
.then(()=>{
|
.then(() => {
|
||||||
done.resolve();
|
done.resolve()
|
||||||
});
|
})
|
||||||
} else {
|
} else {
|
||||||
install(versionArg)
|
install(versionArg)
|
||||||
.then(npmDependencies)
|
.then(npmDependencies)
|
||||||
.then(npmTest)
|
.then(npmTest)
|
||||||
.then(()=>{
|
.then(() => {
|
||||||
done.resolve();
|
done.resolve()
|
||||||
});
|
})
|
||||||
}
|
}
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
let npmDependencies = function(){
|
let npmDependencies = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
plugins.beautylog.info("now installing dependencies:");
|
plugins.beautylog.info('now installing dependencies:')
|
||||||
bash("npm install");
|
bash('npm install')
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
let npmTest = () => {
|
let npmTest = () => {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
plugins.beautylog.info("now starting tests:");
|
plugins.beautylog.info('now starting tests:')
|
||||||
bash("npm test");
|
bash('npm test')
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
let testDocker = function(){
|
let testDocker = function(){
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
NpmciBuildDocker.readDockerfiles()
|
NpmciBuildDocker.readDockerfiles()
|
||||||
.then(NpmciBuildDocker.pullDockerfileImages)
|
.then(NpmciBuildDocker.pullDockerfileImages)
|
||||||
.then(NpmciBuildDocker.testDockerfiles)
|
.then(NpmciBuildDocker.testDockerfiles)
|
||||||
.then(done.resolve)
|
.then(done.resolve)
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,32 +1,31 @@
|
|||||||
import "typings-global";
|
import 'typings-global'
|
||||||
import * as plugins from "./npmci.plugins";
|
import * as plugins from './npmci.plugins'
|
||||||
import {prepare} from "./npmci.prepare";
|
import { prepare } from './npmci.prepare'
|
||||||
import {bash} from "./npmci.bash";
|
import { bash } from './npmci.bash'
|
||||||
|
|
||||||
|
let triggerValueRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|?([a-zA-Z0-9\.\-\/]*)/
|
||||||
let triggerValueRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)\|?([a-zA-Z0-9\.\-\/]*)/;
|
|
||||||
|
|
||||||
export let trigger = function () {
|
export let trigger = function () {
|
||||||
let done = plugins.q.defer();
|
let done = plugins.q.defer()
|
||||||
plugins.beautylog.info("now running triggers");
|
plugins.beautylog.info('now running triggers')
|
||||||
plugins.smartparam.forEachMinimatch(process.env, "NPMCI_TRIGGER_*", evaluateTrigger);
|
plugins.smartparam.forEachMinimatch(process.env, 'NPMCI_TRIGGER_*', evaluateTrigger)
|
||||||
done.resolve();
|
done.resolve()
|
||||||
return done.promise;
|
return done.promise
|
||||||
}
|
}
|
||||||
|
|
||||||
let evaluateTrigger = (triggerEnvVarArg) => {
|
let evaluateTrigger = (triggerEnvVarArg) => {
|
||||||
let triggerRegexResultArray = triggerValueRegex.exec(triggerEnvVarArg);
|
let triggerRegexResultArray = triggerValueRegex.exec(triggerEnvVarArg)
|
||||||
let regexDomain = triggerRegexResultArray[1];
|
let regexDomain = triggerRegexResultArray[1]
|
||||||
let regexProjectId = triggerRegexResultArray[2];
|
let regexProjectId = triggerRegexResultArray[2]
|
||||||
let regexProjectTriggerToken = triggerRegexResultArray[3];
|
let regexProjectTriggerToken = triggerRegexResultArray[3]
|
||||||
let regexRefName = triggerRegexResultArray[4];
|
let regexRefName = triggerRegexResultArray[4]
|
||||||
let regexTriggerName;
|
let regexTriggerName
|
||||||
if (triggerRegexResultArray.length == 6) {
|
if (triggerRegexResultArray.length === 6) {
|
||||||
regexTriggerName = triggerRegexResultArray[5];
|
regexTriggerName = triggerRegexResultArray[5]
|
||||||
} else {
|
} else {
|
||||||
regexTriggerName = "Unnamed Trigger";
|
regexTriggerName = 'Unnamed Trigger'
|
||||||
}
|
}
|
||||||
plugins.beautylog.info("Found Trigger!");
|
plugins.beautylog.info('Found Trigger!')
|
||||||
plugins.beautylog.log("triggering build for ref " + regexRefName + " of " + regexTriggerName);
|
plugins.beautylog.log('triggering build for ref ' + regexRefName + ' of ' + regexTriggerName)
|
||||||
plugins.request.post("https://gitlab.com/api/v3/projects/" + regexProjectId + "/trigger/builds", { form: { token: regexProjectTriggerToken, ref: regexRefName } });
|
plugins.request.post('https://gitlab.com/api/v3/projects/' + regexProjectId + '/trigger/builds', { form: { token: regexProjectTriggerToken, ref: regexRefName } })
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user