81 lines
5.7 KiB
JavaScript
Raw Normal View History

2016-06-01 05:44:48 +02:00
"use strict";
2017-03-11 01:10:37 +01:00
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
2017-05-19 12:09:33 +02:00
const plugins = require("./mod.plugins");
const npmci_bash_1 = require("../npmci.bash");
const env = require("../npmci.env");
const sshModule = require("../npmci.ssh");
2016-09-04 16:05:47 +02:00
/**
* authenticates npm with token from env var
*/
2017-03-11 01:10:37 +01:00
let npm = () => __awaiter(this, void 0, void 0, function* () {
2016-11-24 23:21:40 +01:00
let npmrcPrefix = '//registry.npmjs.org/:_authToken=';
2016-07-18 16:56:53 +02:00
let npmToken = process.env.NPMCI_TOKEN_NPM;
let npmrcFileString = npmrcPrefix + npmToken;
2016-06-03 01:58:37 +02:00
if (npmToken) {
2016-11-24 23:21:40 +01:00
plugins.beautylog.info('found access token');
2016-06-03 01:58:37 +02:00
}
else {
2016-11-24 23:21:40 +01:00
plugins.beautylog.error('no access token found! Exiting!');
2016-06-03 01:58:37 +02:00
process.exit(1);
}
2016-11-24 23:21:40 +01:00
plugins.smartfile.memory.toFsSync(npmrcFileString, '/root/.npmrc');
2017-03-11 01:10:37 +01:00
return;
});
2016-09-04 16:05:47 +02:00
/**
* logs in docker
*/
2017-03-11 01:10:37 +01:00
let docker = () => __awaiter(this, void 0, void 0, function* () {
2016-11-24 23:21:40 +01:00
env.setDockerRegistry('docker.io');
2016-07-18 16:56:53 +02:00
let dockerRegex = /^([a-zA-Z0-9\.]*)\|([a-zA-Z0-9\.]*)/;
2016-06-02 17:57:01 +02:00
if (!process.env.NPMCI_LOGIN_DOCKER) {
2016-11-24 23:21:40 +01:00
plugins.beautylog.error('You have to specify Login Data to the Docker Registry');
2016-06-02 17:57:01 +02:00
process.exit(1);
}
2016-11-24 23:21:40 +01:00
plugins.shelljs.exec('docker login -u gitlab-ci-token -p ' + process.env.CI_BUILD_TOKEN + ' ' + 'registry.gitlab.com'); // Always also login to GitLab Registry
2016-07-18 16:56:53 +02:00
let dockerRegexResultArray = dockerRegex.exec(process.env.NPMCI_LOGIN_DOCKER);
let username = dockerRegexResultArray[1];
let password = dockerRegexResultArray[2];
2017-03-11 01:34:03 +01:00
yield npmci_bash_1.bash('docker login -u ' + username + ' -p ' + password);
2017-03-11 01:10:37 +01:00
return;
});
2016-09-04 16:05:47 +02:00
/**
* prepare docker for gitlab registry
*/
2017-03-11 01:10:37 +01:00
let dockerGitlab = () => __awaiter(this, void 0, void 0, function* () {
2016-11-24 23:21:40 +01:00
env.setDockerRegistry('registry.gitlab.com');
plugins.shelljs.exec('docker login -u gitlab-ci-token -p ' + process.env.CI_BUILD_TOKEN + ' ' + 'registry.gitlab.com');
2017-03-11 01:10:37 +01:00
return;
});
2016-09-04 16:05:47 +02:00
/**
* prepare ssh
*/
2017-03-11 01:10:37 +01:00
let ssh = () => __awaiter(this, void 0, void 0, function* () {
yield sshModule.ssh();
});
2016-09-04 16:05:47 +02:00
/**
* the main exported prepare function
* @param servieArg describes the service to prepare
*/
2017-03-11 01:10:37 +01:00
exports.prepare = (serviceArg) => __awaiter(this, void 0, void 0, function* () {
2016-06-01 05:44:48 +02:00
switch (serviceArg) {
2016-11-24 23:21:40 +01:00
case 'npm':
2017-03-11 01:10:37 +01:00
return yield npm();
2016-11-24 23:21:40 +01:00
case 'docker':
2017-03-11 01:10:37 +01:00
return yield docker();
2016-11-24 23:21:40 +01:00
case 'docker-gitlab':
2017-03-11 01:10:37 +01:00
return yield dockerGitlab();
2016-11-24 23:21:40 +01:00
case 'ssh':
2017-03-11 01:10:37 +01:00
return yield ssh();
2016-06-03 01:58:37 +02:00
default:
break;
2016-06-01 05:44:48 +02:00
}
2017-03-11 01:10:37 +01:00
});
2017-05-19 12:09:33 +02:00
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90cy9tb2RfcHJlcGFyZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUEseUNBQXdDO0FBQ3hDLDhDQUFvQztBQUNwQyxvQ0FBbUM7QUFDbkMsMENBQXlDO0FBVXpDOztHQUVHO0FBQ0gsSUFBSSxHQUFHLEdBQUc7SUFDUixJQUFJLFdBQVcsR0FBVyxtQ0FBbUMsQ0FBQTtJQUM3RCxJQUFJLFFBQVEsR0FBVyxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQTtJQUNsRCxJQUFJLGVBQWUsR0FBVyxXQUFXLEdBQUcsUUFBUSxDQUFBO0lBQ3BELEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDYixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFBO0lBQzlDLENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNOLE9BQU8sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGlDQUFpQyxDQUFDLENBQUE7UUFDMUQsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUNqQixDQUFDO0lBQ0QsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLGVBQWUsRUFBRSxjQUFjLENBQUMsQ0FBQTtJQUNsRSxNQUFNLENBQUE7QUFDUixDQUFDLENBQUEsQ0FBQTtBQUVEOztHQUVHO0FBQ0gsSUFBSSxNQUFNLEdBQUc7SUFDWCxHQUFHLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUE7SUFDbEMsSUFBSSxXQUFXLEdBQUcscUNBQXFDLENBQUE7SUFDdkQsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztRQUNwQyxPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyx1REFBdUQsQ0FBQyxDQUFBO1FBQ2hGLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDakIsQ0FBQztJQUNELE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHFDQUFxQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxHQUFHLEdBQUcsR0FBRyxxQkFBcUIsQ0FBQyxDQUFBLENBQUMsdUNBQXVDO0lBQzlKLElBQUksc0JBQXNCLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUE7SUFDN0UsSUFBSSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDeEMsSUFBSSxRQUFRLEdBQUcsc0JBQXNCLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDeEMsTUFBTSxpQkFBSSxDQUFDLGtCQUFrQixHQUFHLFFBQVEsR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDLENBQUE7SUFDN0QsTUFBTSxDQUFBO0FBQ1IsQ0FBQyxDQUFBLENBQUE7QUFFRDs7R0FFRztBQUNILElBQUksWUFBWSxHQUFHO0lBQ2pCLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFBO0lBQzVDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHFDQUFxQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxHQUFHLEdBQUcsR0FBRyxxQkFBcUIsQ0FBQyxDQUFBO0lBQ3RILE1BQU0sQ0FBQTtBQUNSLENBQUMsQ0FBQSxDQUFBO0FBRUQ7O0dBRUc7QUFDSCxJQUFJLEdBQUcsR0FBRztJQUNSLE1BQU0sU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFBO0FBQ3ZCLENBQUMsQ0FBQSxDQUFBO0FBRUQ7OztHQUdHO0FBQ1EsUUFBQSxPQUFPLEdBQUcsQ0FBTyxVQUF3QjtJQUNsRCxNQUFNLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQ25CLEtBQUssS0FBSztZQUNSLE1BQU0sQ0FBQyxNQUFNLEdBQUcsRUFBRSxDQUFBO1FBQ3BCLEtBQUssUUFBUTtZQUNYLE1BQU0sQ0FBQyxNQUFNLE1BQU0sRUFBRSxDQUFBO1FBQ3ZCLEtBQUssZUFBZTtZQUNsQixNQUFNLENBQUMsTUFBTSxZQUFZLEVBQUUsQ0FBQTtRQUM3QixLQUFLLEtBQUs7WUFDUixNQUFNLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQTtRQUNwQjtZQUNFLEtBQUssQ0FBQTtJQUNULENBQUM7QUFDSCxDQUFDLENBQUEsQ0FBQSJ9