update
This commit is contained in:
parent
108758ad19
commit
d89cc90c4b
109
dist/mod_docker/index.d.ts
vendored
109
dist/mod_docker/index.d.ts
vendored
@ -1,111 +1,20 @@
|
|||||||
/// <reference types="node" />
|
import * as helpers from './mod.helpers';
|
||||||
|
import { Dockerfile } from './mod.classes.dockerfile';
|
||||||
|
export { Dockerfile, helpers };
|
||||||
export declare let modArgvArg: any;
|
export declare let modArgvArg: any;
|
||||||
/**
|
/**
|
||||||
* handle cli input
|
* handle cli input
|
||||||
* @param argvArg
|
* @param argvArg
|
||||||
*/
|
*/
|
||||||
export declare let handleCli: (argvArg: any) => Promise<void>;
|
export declare let handleCli: (argvArg: any) => Promise<void>;
|
||||||
/**
|
|
||||||
* logs in docker
|
|
||||||
*/
|
|
||||||
export declare let prepare: () => Promise<void>;
|
|
||||||
/**
|
/**
|
||||||
* builds a cwd of Dockerfiles by triggering a promisechain
|
* builds a cwd of Dockerfiles by triggering a promisechain
|
||||||
*/
|
*/
|
||||||
export declare let build: () => Promise<void>;
|
export declare let build: () => Promise<void>;
|
||||||
export declare let push: () => Promise<void>;
|
/**
|
||||||
export declare let pull: () => Promise<Dockerfile[]>;
|
* logs in docker
|
||||||
|
*/
|
||||||
|
export declare let prepare: () => Promise<void>;
|
||||||
|
export declare let push: (argvArg: any) => Promise<void>;
|
||||||
|
export declare let pull: (argvArg: any) => Promise<void>;
|
||||||
export declare let test: () => Promise<Dockerfile[]>;
|
export declare let test: () => Promise<Dockerfile[]>;
|
||||||
/**
|
|
||||||
* creates instance of class Dockerfile for all Dockerfiles in cwd
|
|
||||||
* @returns Promise<Dockerfile[]>
|
|
||||||
*/
|
|
||||||
export declare let readDockerfiles: () => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* sorts Dockerfiles into a dependency chain
|
|
||||||
* @param sortableArrayArg an array of instances of class Dockerfile
|
|
||||||
* @returns Promise<Dockerfile[]>
|
|
||||||
*/
|
|
||||||
export declare let sortDockerfiles: (sortableArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* maps local Dockerfiles dependencies to the correspoding Dockerfile class instances
|
|
||||||
*/
|
|
||||||
export declare let mapDockerfiles: (sortedArray: Dockerfile[]) => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* builds the correspoding real docker image for each Dockerfile class instance
|
|
||||||
*/
|
|
||||||
export declare let buildDockerfiles: (sortedArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* pushes the real Dockerfile images to a Docker registry
|
|
||||||
*/
|
|
||||||
export declare let pushDockerfiles: (sortedArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
export declare let pullDockerfileImages: (sortableArrayArg: Dockerfile[], registryArg?: string) => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* tests all Dockerfiles in by calling class Dockerfile.test();
|
|
||||||
* @param sortedArrayArg Dockerfile[] that contains all Dockerfiles in cwd
|
|
||||||
*/
|
|
||||||
export declare let testDockerfiles: (sortedArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
|
||||||
/**
|
|
||||||
* class Dockerfile represents a Dockerfile on disk in npmci
|
|
||||||
*/
|
|
||||||
export declare class Dockerfile {
|
|
||||||
filePath: string;
|
|
||||||
repo: string;
|
|
||||||
version: string;
|
|
||||||
cleanTag: string;
|
|
||||||
buildTag: string;
|
|
||||||
gitlabTestTag: string;
|
|
||||||
gitlabReleaseTag: string;
|
|
||||||
releaseTag: string;
|
|
||||||
containerName: string;
|
|
||||||
content: string;
|
|
||||||
baseImage: string;
|
|
||||||
localBaseImageDependent: boolean;
|
|
||||||
localBaseDockerfile: Dockerfile;
|
|
||||||
constructor(options: {
|
|
||||||
filePath?: string;
|
|
||||||
fileContents?: string | Buffer;
|
|
||||||
read?: boolean;
|
|
||||||
});
|
|
||||||
/**
|
|
||||||
* builds the Dockerfile
|
|
||||||
*/
|
|
||||||
build(): Promise<void>;
|
|
||||||
/**
|
|
||||||
* pushes the Dockerfile to a registry
|
|
||||||
*/
|
|
||||||
push(stageArg: any): Promise<void>;
|
|
||||||
/**
|
|
||||||
* pulls the Dockerfile from a registry
|
|
||||||
*/
|
|
||||||
pull(registryArg: string): Promise<void>;
|
|
||||||
/**
|
|
||||||
* tests the Dockerfile;
|
|
||||||
*/
|
|
||||||
test(): Promise<void>;
|
|
||||||
/**
|
|
||||||
* gets the id of a Dockerfile
|
|
||||||
*/
|
|
||||||
getId(): Promise<string>;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* returns a version for a docker file
|
|
||||||
* @execution SYNC
|
|
||||||
*/
|
|
||||||
export declare let dockerFileVersion: (dockerfileNameArg: string) => string;
|
|
||||||
/**
|
|
||||||
* returns the docker base image for a Dockerfile
|
|
||||||
*/
|
|
||||||
export declare let dockerBaseImage: (dockerfileContentArg: string) => string;
|
|
||||||
/**
|
|
||||||
* returns the docker tag
|
|
||||||
*/
|
|
||||||
export declare let getDockerTagString: (registryArg: string, repoArg: string, versionArg: string, suffixArg?: string) => string;
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
export declare let cleanTagsArrayFunction: (dockerfileArrayArg: Dockerfile[], trackingArrayArg: Dockerfile[]) => string[];
|
|
||||||
|
368
dist/mod_docker/index.js
vendored
368
dist/mod_docker/index.js
vendored
File diff suppressed because one or more lines are too long
42
dist/mod_docker/mod.classes.dockerfile.d.ts
vendored
Normal file
42
dist/mod_docker/mod.classes.dockerfile.d.ts
vendored
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/// <reference types="node" />
|
||||||
|
import { DockerRegistry } from './mod.classes.dockerregistry';
|
||||||
|
/**
|
||||||
|
* class Dockerfile represents a Dockerfile on disk in npmci
|
||||||
|
*/
|
||||||
|
export declare class Dockerfile {
|
||||||
|
filePath: string;
|
||||||
|
repo: string;
|
||||||
|
version: string;
|
||||||
|
cleanTag: string;
|
||||||
|
buildTag: string;
|
||||||
|
containerName: string;
|
||||||
|
content: string;
|
||||||
|
baseImage: string;
|
||||||
|
localBaseImageDependent: boolean;
|
||||||
|
localBaseDockerfile: Dockerfile;
|
||||||
|
constructor(options: {
|
||||||
|
filePath?: string;
|
||||||
|
fileContents?: string | Buffer;
|
||||||
|
read?: boolean;
|
||||||
|
});
|
||||||
|
/**
|
||||||
|
* builds the Dockerfile
|
||||||
|
*/
|
||||||
|
build(): Promise<void>;
|
||||||
|
/**
|
||||||
|
* pushes the Dockerfile to a registry
|
||||||
|
*/
|
||||||
|
push(dockerRegistryArg: DockerRegistry, versionSuffix?: string): Promise<void>;
|
||||||
|
/**
|
||||||
|
* pulls the Dockerfile from a registry
|
||||||
|
*/
|
||||||
|
pull(registryArg: DockerRegistry, versionSuffixArg?: string): Promise<void>;
|
||||||
|
/**
|
||||||
|
* tests the Dockerfile;
|
||||||
|
*/
|
||||||
|
test(): Promise<void>;
|
||||||
|
/**
|
||||||
|
* gets the id of a Dockerfile
|
||||||
|
*/
|
||||||
|
getId(): Promise<string>;
|
||||||
|
}
|
96
dist/mod_docker/mod.classes.dockerfile.js
vendored
Normal file
96
dist/mod_docker/mod.classes.dockerfile.js
vendored
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
"use strict";
|
||||||
|
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 });
|
||||||
|
const plugins = require("./mod.plugins");
|
||||||
|
const NpmciEnv = require("../npmci.env");
|
||||||
|
const npmci_bash_1 = require("../npmci.bash");
|
||||||
|
const paths = require("../npmci.paths");
|
||||||
|
const helpers = require("./mod.helpers");
|
||||||
|
/**
|
||||||
|
* class Dockerfile represents a Dockerfile on disk in npmci
|
||||||
|
*/
|
||||||
|
class Dockerfile {
|
||||||
|
constructor(options) {
|
||||||
|
this.filePath = options.filePath;
|
||||||
|
this.repo = NpmciEnv.repo.user + '/' + NpmciEnv.repo.repo;
|
||||||
|
this.version = helpers.dockerFileVersion(plugins.path.parse(options.filePath).base);
|
||||||
|
this.cleanTag = this.repo + ':' + this.version;
|
||||||
|
this.buildTag = this.cleanTag;
|
||||||
|
this.containerName = 'dockerfile-' + this.version;
|
||||||
|
if (options.filePath && options.read) {
|
||||||
|
this.content = plugins.smartfile.fs.toStringSync(plugins.path.resolve(options.filePath));
|
||||||
|
}
|
||||||
|
this.baseImage = helpers.dockerBaseImage(this.content);
|
||||||
|
this.localBaseImageDependent = false;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* builds the Dockerfile
|
||||||
|
*/
|
||||||
|
build() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
plugins.beautylog.info('now building Dockerfile for ' + this.cleanTag);
|
||||||
|
let buildCommand = `docker build -t ${this.buildTag} -f ${this.filePath} .`;
|
||||||
|
yield npmci_bash_1.bash(buildCommand);
|
||||||
|
NpmciEnv.dockerFilesBuilt.push(this);
|
||||||
|
return;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* pushes the Dockerfile to a registry
|
||||||
|
*/
|
||||||
|
push(dockerRegistryArg, versionSuffix = null) {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
let pushTag = helpers.getDockerTagString(dockerRegistryArg.registryUrl, this.repo, this.version, versionSuffix);
|
||||||
|
yield npmci_bash_1.bash(`docker tag ${this.buildTag} ${pushTag}`);
|
||||||
|
yield npmci_bash_1.bash(`docker push ${pushTag}`);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* pulls the Dockerfile from a registry
|
||||||
|
*/
|
||||||
|
pull(registryArg, versionSuffixArg = null) {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
let pullTag = helpers.getDockerTagString(registryArg.registryUrl, this.repo, this.version, versionSuffixArg);
|
||||||
|
yield npmci_bash_1.bash(`docker tag ${pullTag} ${this.buildTag}`);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* tests the Dockerfile;
|
||||||
|
*/
|
||||||
|
test() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
let testFile = plugins.path.join(paths.NpmciTestDir, 'test_' + this.version + '.sh');
|
||||||
|
let testFileExists = plugins.smartfile.fs.fileExistsSync(testFile);
|
||||||
|
if (testFileExists) {
|
||||||
|
// run tests
|
||||||
|
yield npmci_bash_1.bash('docker run --name npmci_test_container ' + this.buildTag + ' mkdir /npmci_test');
|
||||||
|
yield npmci_bash_1.bash('docker cp ' + testFile + ' npmci_test_container:/npmci_test/test.sh');
|
||||||
|
yield npmci_bash_1.bash('docker commit npmci_test_container npmci_test_image');
|
||||||
|
yield npmci_bash_1.bash('docker run npmci_test_image sh /npmci_test/test.sh');
|
||||||
|
yield npmci_bash_1.bash('docker rm npmci_test_container');
|
||||||
|
yield npmci_bash_1.bash('docker rmi --force npmci_test_image');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
plugins.beautylog.warn('skipping tests for ' + this.cleanTag + ' because no testfile was found!');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* gets the id of a Dockerfile
|
||||||
|
*/
|
||||||
|
getId() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
let containerId = yield npmci_bash_1.bash('docker inspect --type=image --format=\"{{.Id}}\" ' + this.buildTag);
|
||||||
|
return containerId;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.Dockerfile = Dockerfile;
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kLmNsYXNzZXMuZG9ja2VyZmlsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzL21vZF9kb2NrZXIvbW9kLmNsYXNzZXMuZG9ja2VyZmlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUEseUNBQXdDO0FBQ3hDLHlDQUF3QztBQUN4Qyw4Q0FBb0M7QUFDcEMsd0NBQXVDO0FBR3ZDLHlDQUF3QztBQUV4Qzs7R0FFRztBQUNIO0lBV0UsWUFBYSxPQUE4RTtRQUN6RixJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUE7UUFDaEMsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUE7UUFDekQsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ25GLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLElBQUksR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQTtRQUM5QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUE7UUFFN0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQTtRQUNqRCxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQ3JDLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFBO1FBQzFGLENBQUM7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
|
13
dist/mod_docker/mod.classes.dockerregistry.d.ts
vendored
Normal file
13
dist/mod_docker/mod.classes.dockerregistry.d.ts
vendored
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
export interface IDockerRegistryConstructorOptions {
|
||||||
|
registryUrl: string;
|
||||||
|
username: string;
|
||||||
|
password: string;
|
||||||
|
}
|
||||||
|
export declare class DockerRegistry {
|
||||||
|
registryUrl: string;
|
||||||
|
username: string;
|
||||||
|
password: string;
|
||||||
|
constructor(optionsArg: IDockerRegistryConstructorOptions);
|
||||||
|
static fromEnvString(envString: string): DockerRegistry;
|
||||||
|
login(): Promise<void>;
|
||||||
|
}
|
49
dist/mod_docker/mod.classes.dockerregistry.js
vendored
Normal file
49
dist/mod_docker/mod.classes.dockerregistry.js
vendored
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
"use strict";
|
||||||
|
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 });
|
||||||
|
const plugins = require("./mod.plugins");
|
||||||
|
const npmci_bash_1 = require("../npmci.bash");
|
||||||
|
class DockerRegistry {
|
||||||
|
constructor(optionsArg) {
|
||||||
|
this.registryUrl = optionsArg.registryUrl;
|
||||||
|
this.username = optionsArg.username;
|
||||||
|
this.password = optionsArg.password;
|
||||||
|
}
|
||||||
|
static fromEnvString(envString) {
|
||||||
|
let dockerRegexResultArray = envString.split('|');
|
||||||
|
if (dockerRegexResultArray.length !== 3) {
|
||||||
|
plugins.beautylog.error('malformed docker env var...');
|
||||||
|
process.exit(1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let registryUrl = dockerRegexResultArray[0];
|
||||||
|
let username = dockerRegexResultArray[1];
|
||||||
|
let password = dockerRegexResultArray[2];
|
||||||
|
return new DockerRegistry({
|
||||||
|
registryUrl: registryUrl,
|
||||||
|
username: username,
|
||||||
|
password: password
|
||||||
|
});
|
||||||
|
}
|
||||||
|
login() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
if (this.registryUrl === 'docker.io') {
|
||||||
|
yield npmci_bash_1.bash(`docker login -u ${this.username} -p ${this.password}`);
|
||||||
|
plugins.beautylog.info('Logged in to standard docker hub');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
yield npmci_bash_1.bash(`docker login -u ${this.username} -p ${this.password} ${this.registryUrl}`);
|
||||||
|
}
|
||||||
|
plugins.beautylog.success(`docker authenticated for ${this.registryUrl}!`);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.DockerRegistry = DockerRegistry;
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kLmNsYXNzZXMuZG9ja2VycmVnaXN0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90cy9tb2RfZG9ja2VyL21vZC5jbGFzc2VzLmRvY2tlcnJlZ2lzdHJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQSx5Q0FBd0M7QUFDeEMsOENBQW9DO0FBUXBDO0lBSUUsWUFBYSxVQUE2QztRQUN4RCxJQUFJLENBQUMsV0FBVyxHQUFHLFVBQVUsQ0FBQyxXQUFXLENBQUE7UUFDekMsSUFBSSxDQUFDLFFBQVEsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFBO1FBQ25DLElBQUksQ0FBQyxRQUFRLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQTtJQUNyQyxDQUFDO0lBRUQsTUFBTSxDQUFDLGFBQWEsQ0FBRSxTQUFpQjtRQUNyQyxJQUFJLHNCQUFzQixHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUE7UUFDakQsRUFBRSxDQUFDLENBQUMsc0JBQXNCLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDeEMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsNkJBQTZCLENBQUMsQ0FBQTtZQUN0RCxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFBO1lBQ2YsTUFBTSxDQUFBO1FBQ1IsQ0FBQztRQUNELElBQUksV0FBVyxHQUFHLHNCQUFzQixDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQzNDLElBQUksUUFBUSxHQUFHLHNCQUFzQixDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ3hDLElBQUksUUFBUSxHQUFHLHNCQUFzQixDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ3hDLE1BQU0sQ0FBQyxJQUFJLGNBQWMsQ0FBQztZQUN4QixXQUFXLEVBQUUsV0FBVztZQUN4QixRQUFRLEVBQUUsUUFBUTtZQUNsQixRQUFRLEVBQUUsUUFBUTtTQUNuQixDQUFDLENBQUE7SUFDSixDQUFDO0lBRUssS0FBSzs7WUFDVCxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JDLE1BQU0saUJBQUksQ0FBQyxtQkFBbUIsSUFBSSxDQUFDLFFBQVEsT0FBTyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtnQkFDbEUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsa0NBQWtDLENBQUMsQ0FBQTtZQUM1RCxDQUFDO1lBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ04sTUFBTSxpQkFBSSxDQUFDLG1CQUFtQixJQUFJLENBQUMsUUFBUSxPQUFPLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUE7WUFDeEYsQ0FBQztZQUNELE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLDRCQUE0QixJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQTtRQUM1RSxDQUFDO0tBQUE7Q0FDRjtBQXBDRCx3Q0FvQ0MifQ==
|
9
dist/mod_docker/mod.classes.registrystorage.d.ts
vendored
Normal file
9
dist/mod_docker/mod.classes.registrystorage.d.ts
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import { Objectmap } from 'lik';
|
||||||
|
import { DockerRegistry } from './mod.classes.dockerregistry';
|
||||||
|
export declare class RegistryStorage {
|
||||||
|
objectMap: Objectmap<DockerRegistry>;
|
||||||
|
constructor();
|
||||||
|
addRegistry(registryArg: DockerRegistry): void;
|
||||||
|
getRegistryByUrl(registryUrlArg: string): DockerRegistry;
|
||||||
|
loginAll(): Promise<void>;
|
||||||
|
}
|
34
dist/mod_docker/mod.classes.registrystorage.js
vendored
Normal file
34
dist/mod_docker/mod.classes.registrystorage.js
vendored
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
"use strict";
|
||||||
|
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 });
|
||||||
|
const lik_1 = require("lik");
|
||||||
|
class RegistryStorage {
|
||||||
|
constructor() {
|
||||||
|
this.objectMap = new lik_1.Objectmap();
|
||||||
|
// Nothing here
|
||||||
|
}
|
||||||
|
addRegistry(registryArg) {
|
||||||
|
this.objectMap.add(registryArg);
|
||||||
|
}
|
||||||
|
getRegistryByUrl(registryUrlArg) {
|
||||||
|
return this.objectMap.find(registryArg => {
|
||||||
|
return registryArg.registryUrl === registryUrlArg;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
loginAll() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
yield this.objectMap.forEach((registryArg) => __awaiter(this, void 0, void 0, function* () {
|
||||||
|
yield registryArg.login();
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.RegistryStorage = RegistryStorage;
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kLmNsYXNzZXMucmVnaXN0cnlzdG9yYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHMvbW9kX2RvY2tlci9tb2QuY2xhc3Nlcy5yZWdpc3RyeXN0b3JhZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUNBLDZCQUErQjtBQUkvQjtJQUVFO1FBREEsY0FBUyxHQUFHLElBQUksZUFBUyxFQUFrQixDQUFBO1FBRXpDLGVBQWU7SUFDakIsQ0FBQztJQUVELFdBQVcsQ0FBRSxXQUEyQjtRQUN0QyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUNqQyxDQUFDO0lBRUQsZ0JBQWdCLENBQUUsY0FBc0I7UUFDdEMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVc7WUFDcEMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxXQUFXLEtBQUssY0FBYyxDQUFBO1FBQ25ELENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVLLFFBQVE7O1lBQ1osTUFBTSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFNLFdBQVc7Z0JBQzVDLE1BQU0sV0FBVyxDQUFDLEtBQUssRUFBRSxDQUFBO1lBQzNCLENBQUMsQ0FBQSxDQUFDLENBQUE7UUFDSixDQUFDO0tBQUE7Q0FDRjtBQXJCRCwwQ0FxQkMifQ==
|
42
dist/mod_docker/mod.helpers.d.ts
vendored
Normal file
42
dist/mod_docker/mod.helpers.d.ts
vendored
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
import { Dockerfile } from './mod.classes.dockerfile';
|
||||||
|
/**
|
||||||
|
* creates instance of class Dockerfile for all Dockerfiles in cwd
|
||||||
|
* @returns Promise<Dockerfile[]>
|
||||||
|
*/
|
||||||
|
export declare let readDockerfiles: () => Promise<Dockerfile[]>;
|
||||||
|
/**
|
||||||
|
* sorts Dockerfiles into a dependency chain
|
||||||
|
* @param sortableArrayArg an array of instances of class Dockerfile
|
||||||
|
* @returns Promise<Dockerfile[]>
|
||||||
|
*/
|
||||||
|
export declare let sortDockerfiles: (sortableArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
||||||
|
/**
|
||||||
|
* maps local Dockerfiles dependencies to the correspoding Dockerfile class instances
|
||||||
|
*/
|
||||||
|
export declare let mapDockerfiles: (sortedArray: Dockerfile[]) => Promise<Dockerfile[]>;
|
||||||
|
/**
|
||||||
|
* builds the correspoding real docker image for each Dockerfile class instance
|
||||||
|
*/
|
||||||
|
export declare let buildDockerfiles: (sortedArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
||||||
|
/**
|
||||||
|
* tests all Dockerfiles in by calling class Dockerfile.test();
|
||||||
|
* @param sortedArrayArg Dockerfile[] that contains all Dockerfiles in cwd
|
||||||
|
*/
|
||||||
|
export declare let testDockerfiles: (sortedArrayArg: Dockerfile[]) => Promise<Dockerfile[]>;
|
||||||
|
/**
|
||||||
|
* returns a version for a docker file
|
||||||
|
* @execution SYNC
|
||||||
|
*/
|
||||||
|
export declare let dockerFileVersion: (dockerfileNameArg: string) => string;
|
||||||
|
/**
|
||||||
|
* returns the docker base image for a Dockerfile
|
||||||
|
*/
|
||||||
|
export declare let dockerBaseImage: (dockerfileContentArg: string) => string;
|
||||||
|
/**
|
||||||
|
* returns the docker tag
|
||||||
|
*/
|
||||||
|
export declare let getDockerTagString: (registryArg: string, repoArg: string, versionArg: string, suffixArg?: string) => string;
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
export declare let cleanTagsArrayFunction: (dockerfileArrayArg: Dockerfile[], trackingArrayArg: Dockerfile[]) => string[];
|
152
dist/mod_docker/mod.helpers.js
vendored
Normal file
152
dist/mod_docker/mod.helpers.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -33,6 +33,7 @@
|
|||||||
"cflare": "^1.0.5",
|
"cflare": "^1.0.5",
|
||||||
"gulp": "^3.9.1",
|
"gulp": "^3.9.1",
|
||||||
"gulp-function": "^2.2.9",
|
"gulp-function": "^2.2.9",
|
||||||
|
"lik": "^1.0.39",
|
||||||
"lodash": "^4.17.4",
|
"lodash": "^4.17.4",
|
||||||
"npmextra": "^2.0.9",
|
"npmextra": "^2.0.9",
|
||||||
"projectinfo": "^3.0.2",
|
"projectinfo": "^3.0.2",
|
||||||
|
@ -33,7 +33,7 @@ tap.test('should return valid Dockerfiles', async () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
tap.test('should read a directory of Dockerfiles', async () => {
|
tap.test('should read a directory of Dockerfiles', async () => {
|
||||||
return npmciModDocker.readDockerfiles()
|
return npmciModDocker.helpers.readDockerfiles()
|
||||||
.then(async (readDockerfilesArrayArg: npmciModDocker.Dockerfile[]) => {
|
.then(async (readDockerfilesArrayArg: npmciModDocker.Dockerfile[]) => {
|
||||||
sortableArray = readDockerfilesArrayArg
|
sortableArray = readDockerfilesArrayArg
|
||||||
return expect(readDockerfilesArrayArg[1].version).to.equal('sometag1')
|
return expect(readDockerfilesArrayArg[1].version).to.equal('sometag1')
|
||||||
@ -41,7 +41,7 @@ tap.test('should read a directory of Dockerfiles', async () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
tap.test('should sort an array of Dockerfiles', async () => {
|
tap.test('should sort an array of Dockerfiles', async () => {
|
||||||
return npmciModDocker.sortDockerfiles(sortableArray)
|
return npmciModDocker.helpers.sortDockerfiles(sortableArray)
|
||||||
.then(async (sortedArrayArg: npmciModDocker.Dockerfile[]) => {
|
.then(async (sortedArrayArg: npmciModDocker.Dockerfile[]) => {
|
||||||
console.log(sortedArrayArg)
|
console.log(sortedArrayArg)
|
||||||
})
|
})
|
||||||
|
@ -3,6 +3,21 @@ import * as paths from '../npmci.paths'
|
|||||||
import * as NpmciEnv from '../npmci.env'
|
import * as NpmciEnv from '../npmci.env'
|
||||||
import { bash } from '../npmci.bash'
|
import { bash } from '../npmci.bash'
|
||||||
|
|
||||||
|
import * as helpers from './mod.helpers'
|
||||||
|
|
||||||
|
// classes
|
||||||
|
import { Dockerfile } from './mod.classes.dockerfile'
|
||||||
|
import { DockerRegistry } from './mod.classes.dockerregistry'
|
||||||
|
import { RegistryStorage } from './mod.classes.registrystorage'
|
||||||
|
|
||||||
|
// instances
|
||||||
|
let npmciRegistryStorage = new RegistryStorage()
|
||||||
|
|
||||||
|
export {
|
||||||
|
Dockerfile,
|
||||||
|
helpers
|
||||||
|
}
|
||||||
|
|
||||||
export let modArgvArg // will be set through the build command
|
export let modArgvArg // will be set through the build command
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -12,7 +27,7 @@ export let modArgvArg // will be set through the build command
|
|||||||
export let handleCli = async (argvArg) => {
|
export let handleCli = async (argvArg) => {
|
||||||
modArgvArg = argvArg
|
modArgvArg = argvArg
|
||||||
if (argvArg._.length >= 2) {
|
if (argvArg._.length >= 2) {
|
||||||
let action: string = argvArg._[1]
|
let action: string = argvArg._[ 1 ]
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case 'build':
|
case 'build':
|
||||||
await build()
|
await build()
|
||||||
@ -23,6 +38,12 @@ export let handleCli = async (argvArg) => {
|
|||||||
case 'test':
|
case 'test':
|
||||||
await test()
|
await test()
|
||||||
break
|
break
|
||||||
|
case 'push':
|
||||||
|
await push(argvArg)
|
||||||
|
break
|
||||||
|
case 'pull':
|
||||||
|
await pull(argvArg)
|
||||||
|
break
|
||||||
default:
|
default:
|
||||||
plugins.beautylog.error(`>>npmci node ...<< action >>${action}<< not supported`)
|
plugins.beautylog.error(`>>npmci node ...<< action >>${action}<< not supported`)
|
||||||
}
|
}
|
||||||
@ -31,6 +52,16 @@ export let handleCli = async (argvArg) => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* builds a cwd of Dockerfiles by triggering a promisechain
|
||||||
|
*/
|
||||||
|
export let build = async () => {
|
||||||
|
plugins.beautylog.log('now building Dockerfiles...')
|
||||||
|
await helpers.readDockerfiles()
|
||||||
|
.then(helpers.sortDockerfiles)
|
||||||
|
.then(helpers.mapDockerfiles)
|
||||||
|
.then(helpers.buildDockerfiles)
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* logs in docker
|
* logs in docker
|
||||||
@ -38,339 +69,58 @@ export let handleCli = async (argvArg) => {
|
|||||||
export let prepare = async () => {
|
export let prepare = async () => {
|
||||||
NpmciEnv.setDockerRegistry('docker.io') // TODO: checkup why we set this here
|
NpmciEnv.setDockerRegistry('docker.io') // TODO: checkup why we set this here
|
||||||
|
|
||||||
// handle registries
|
|
||||||
plugins.smartparam.forEachMinimatch(process.env, 'NPMCI_LOGIN_DOCKER*', async (envString) => {
|
|
||||||
let dockerRegexResultArray = envString.split('|')
|
|
||||||
if (dockerRegexResultArray.length !== 3) {
|
|
||||||
plugins.beautylog.error('malformed docker env var...')
|
|
||||||
process.exit(1)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
let registry = dockerRegexResultArray[0]
|
|
||||||
let username = dockerRegexResultArray[1]
|
|
||||||
let password = dockerRegexResultArray[2]
|
|
||||||
if (registry === 'docker.io') {
|
|
||||||
await bash(`docker login -u ${username} -p ${password}`)
|
|
||||||
plugins.beautylog.info('Logged in to standard docker hub')
|
|
||||||
} else {
|
|
||||||
await bash(`docker login -u ${username} -p ${password} ${registry}`)
|
|
||||||
}
|
|
||||||
plugins.beautylog.success(`docker authenticated for ${registry}!`)
|
|
||||||
})
|
|
||||||
|
|
||||||
// Always login to GitLab Registry
|
// Always login to GitLab Registry
|
||||||
if (!process.env.CI_BUILD_TOKEN || process.env.CI_BUILD_TOKEN === '') {
|
if (!process.env.CI_BUILD_TOKEN || process.env.CI_BUILD_TOKEN === '') {
|
||||||
plugins.beautylog.error('No registry token specified by gitlab!')
|
plugins.beautylog.error('No registry token specified by gitlab!')
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
await bash(`docker login -u gitlab-ci-token -p ${process.env.CI_BUILD_TOKEN} registry.gitlab.com`)
|
npmciRegistryStorage.addRegistry(new DockerRegistry({
|
||||||
plugins.beautylog.success(`docker authenticated for registry.gitlab.com!`)
|
registryUrl: 'registry.gitlab.com',
|
||||||
|
username: 'gitlab-ci-token',
|
||||||
|
password: process.env.CI_BUILD_TOKEN
|
||||||
|
}))
|
||||||
|
|
||||||
|
// handle registries
|
||||||
|
plugins.smartparam.forEachMinimatch(process.env, 'NPMCI_LOGIN_DOCKER*', async (envString) => {
|
||||||
|
npmciRegistryStorage.addRegistry(
|
||||||
|
DockerRegistry.fromEnvString(envString)
|
||||||
|
)
|
||||||
|
await npmciRegistryStorage.loginAll()
|
||||||
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
export let push = async (argvArg) => {
|
||||||
* builds a cwd of Dockerfiles by triggering a promisechain
|
let registryUrlArg = argvArg._[ 2 ]
|
||||||
*/
|
let suffix = null
|
||||||
export let build = async () => {
|
if (argvArg._.length >= 4) {
|
||||||
plugins.beautylog.log('now building Dockerfiles...')
|
suffix = argvArg._[ 3 ]
|
||||||
await readDockerfiles()
|
}
|
||||||
.then(sortDockerfiles)
|
let dockerfileArray = await helpers.readDockerfiles()
|
||||||
.then(mapDockerfiles)
|
.then(helpers.sortDockerfiles)
|
||||||
.then(buildDockerfiles)
|
.then(helpers.mapDockerfiles)
|
||||||
|
let localDockerRegistry = npmciRegistryStorage.getRegistryByUrl(registryUrlArg)
|
||||||
|
for (let dockerfile of dockerfileArray) {
|
||||||
|
dockerfile.push(localDockerRegistry, suffix)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export let push = async () => {
|
export let pull = async (argvArg) => {
|
||||||
await readDockerfiles()
|
let registryUrlArg = argvArg._[ 2 ]
|
||||||
.then(sortDockerfiles)
|
let suffix = null
|
||||||
.then(mapDockerfiles)
|
if (argvArg._.length >= 4) {
|
||||||
.then(pushDockerfiles)
|
suffix = argvArg._[ 3 ]
|
||||||
}
|
}
|
||||||
|
let localDockerRegistry = npmciRegistryStorage.getRegistryByUrl(registryUrlArg)
|
||||||
export let pull = async () => {
|
let dockerfileArray = await helpers.readDockerfiles()
|
||||||
return await readDockerfiles()
|
.then(helpers.sortDockerfiles)
|
||||||
.then(pullDockerfileImages)
|
.then(helpers.mapDockerfiles)
|
||||||
|
for (let dockerfile of dockerfileArray) {
|
||||||
|
dockerfile.pull(localDockerRegistry, suffix)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export let test = async () => {
|
export let test = async () => {
|
||||||
return await readDockerfiles()
|
return await helpers.readDockerfiles()
|
||||||
.then(testDockerfiles)
|
.then(helpers.testDockerfiles)
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* creates instance of class Dockerfile for all Dockerfiles in cwd
|
|
||||||
* @returns Promise<Dockerfile[]>
|
|
||||||
*/
|
|
||||||
export let readDockerfiles = async (): Promise<Dockerfile[]> => {
|
|
||||||
let fileTree = await plugins.smartfile.fs.listFileTree(paths.cwd, 'Dockerfile*')
|
|
||||||
|
|
||||||
// create the Dockerfile array
|
|
||||||
let readDockerfilesArray: Dockerfile[] = []
|
|
||||||
plugins.beautylog.info(`found ${fileTree.length} Dockerfiles:`)
|
|
||||||
console.log(fileTree)
|
|
||||||
for (let dockerfilePath of fileTree) {
|
|
||||||
let myDockerfile = new Dockerfile({
|
|
||||||
filePath: dockerfilePath,
|
|
||||||
read: true
|
|
||||||
})
|
|
||||||
readDockerfilesArray.push(myDockerfile)
|
|
||||||
}
|
|
||||||
|
|
||||||
return readDockerfilesArray
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* sorts Dockerfiles into a dependency chain
|
|
||||||
* @param sortableArrayArg an array of instances of class Dockerfile
|
|
||||||
* @returns Promise<Dockerfile[]>
|
|
||||||
*/
|
|
||||||
export let sortDockerfiles = (sortableArrayArg: Dockerfile[]): Promise<Dockerfile[]> => {
|
|
||||||
let done = plugins.q.defer<Dockerfile[]>()
|
|
||||||
plugins.beautylog.info('sorting Dockerfiles:')
|
|
||||||
let sortedArray: Dockerfile[] = []
|
|
||||||
let cleanTagsOriginal = cleanTagsArrayFunction(sortableArrayArg, sortedArray)
|
|
||||||
let sorterFunctionCounter: number = 0
|
|
||||||
let sorterFunction = function () {
|
|
||||||
sortableArrayArg.forEach((dockerfileArg) => {
|
|
||||||
let cleanTags = cleanTagsArrayFunction(sortableArrayArg, sortedArray)
|
|
||||||
if (cleanTags.indexOf(dockerfileArg.baseImage) === -1 && sortedArray.indexOf(dockerfileArg) === -1) {
|
|
||||||
sortedArray.push(dockerfileArg)
|
|
||||||
}
|
|
||||||
if (cleanTagsOriginal.indexOf(dockerfileArg.baseImage) !== -1) {
|
|
||||||
dockerfileArg.localBaseImageDependent = true
|
|
||||||
}
|
|
||||||
})
|
|
||||||
if (sortableArrayArg.length === sortedArray.length) {
|
|
||||||
let counter = 1
|
|
||||||
for (let dockerfile of sortedArray) {
|
|
||||||
plugins.beautylog.log(`tag ${counter}: -> ${dockerfile.cleanTag}`)
|
|
||||||
counter++
|
|
||||||
}
|
|
||||||
done.resolve(sortedArray)
|
|
||||||
} else if (sorterFunctionCounter < 10) {
|
|
||||||
sorterFunctionCounter++
|
|
||||||
sorterFunction()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
sorterFunction()
|
|
||||||
return done.promise
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* maps local Dockerfiles dependencies to the correspoding Dockerfile class instances
|
|
||||||
*/
|
|
||||||
export let mapDockerfiles = async (sortedArray: Dockerfile[]): Promise<Dockerfile[]> => {
|
|
||||||
sortedArray.forEach((dockerfileArg) => {
|
|
||||||
if (dockerfileArg.localBaseImageDependent) {
|
|
||||||
sortedArray.forEach((dockfile2: Dockerfile) => {
|
|
||||||
if (dockfile2.cleanTag === dockerfileArg.baseImage) {
|
|
||||||
dockerfileArg.localBaseDockerfile = dockfile2
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
return sortedArray
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* builds the correspoding real docker image for each Dockerfile class instance
|
|
||||||
*/
|
|
||||||
export let buildDockerfiles = async (sortedArrayArg: Dockerfile[]) => {
|
|
||||||
for (let dockerfileArg of sortedArrayArg) {
|
|
||||||
await dockerfileArg.build()
|
|
||||||
}
|
|
||||||
return sortedArrayArg
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* pushes the real Dockerfile images to a Docker registry
|
|
||||||
*/
|
|
||||||
export let pushDockerfiles = async (sortedArrayArg: Dockerfile[]) => {
|
|
||||||
let stageArg = (function () {
|
|
||||||
if (modArgvArg._ && modArgvArg._.length >= 3) {
|
|
||||||
return modArgvArg._[ 2 ]
|
|
||||||
} else {
|
|
||||||
return NpmciEnv.buildStage
|
|
||||||
}
|
|
||||||
})()
|
|
||||||
for (let dockerfileArg of sortedArrayArg) {
|
|
||||||
await dockerfileArg.push(stageArg)
|
|
||||||
}
|
|
||||||
return sortedArrayArg
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
export let pullDockerfileImages = async (sortableArrayArg: Dockerfile[], registryArg = 'registry.gitlab.com') => {
|
|
||||||
for (let dockerfileArg of sortableArrayArg) {
|
|
||||||
await dockerfileArg.pull(registryArg)
|
|
||||||
}
|
|
||||||
return sortableArrayArg
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* tests all Dockerfiles in by calling class Dockerfile.test();
|
|
||||||
* @param sortedArrayArg Dockerfile[] that contains all Dockerfiles in cwd
|
|
||||||
*/
|
|
||||||
export let testDockerfiles = async (sortedArrayArg: Dockerfile[]) => {
|
|
||||||
for (let dockerfileArg of sortedArrayArg) {
|
|
||||||
await dockerfileArg.test()
|
|
||||||
}
|
|
||||||
return sortedArrayArg
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* class Dockerfile represents a Dockerfile on disk in npmci
|
|
||||||
*/
|
|
||||||
export class Dockerfile {
|
|
||||||
filePath: string
|
|
||||||
repo: string
|
|
||||||
version: string
|
|
||||||
cleanTag: string
|
|
||||||
buildTag: string
|
|
||||||
gitlabTestTag: string
|
|
||||||
gitlabReleaseTag: string
|
|
||||||
releaseTag: string
|
|
||||||
containerName: string
|
|
||||||
content: string
|
|
||||||
baseImage: string
|
|
||||||
localBaseImageDependent: boolean
|
|
||||||
localBaseDockerfile: Dockerfile
|
|
||||||
constructor(options: { filePath?: string, fileContents?: string | Buffer, read?: boolean }) {
|
|
||||||
this.filePath = options.filePath
|
|
||||||
this.repo = NpmciEnv.repo.user + '/' + NpmciEnv.repo.repo
|
|
||||||
this.version = dockerFileVersion(plugins.path.parse(options.filePath).base)
|
|
||||||
this.cleanTag = this.repo + ':' + this.version
|
|
||||||
this.buildTag = this.cleanTag
|
|
||||||
this.gitlabTestTag = getDockerTagString('docker.io', this.repo, this.version, 'test') // TODO: using docker.io until gitlab is fixed
|
|
||||||
this.gitlabReleaseTag = getDockerTagString('docker.io', this.repo, this.version) // TODO: using docker.io until gitlab is fixed
|
|
||||||
|
|
||||||
// the releaseTag determines where the image gets released
|
|
||||||
this.releaseTag = getDockerTagString('docker.io', this.repo, this.version)
|
|
||||||
|
|
||||||
this.containerName = 'dockerfile-' + this.version
|
|
||||||
if (options.filePath && options.read) {
|
|
||||||
this.content = plugins.smartfile.fs.toStringSync(plugins.path.resolve(options.filePath))
|
|
||||||
}
|
|
||||||
this.baseImage = dockerBaseImage(this.content)
|
|
||||||
this.localBaseImageDependent = false
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* builds the Dockerfile
|
|
||||||
*/
|
|
||||||
async build () {
|
|
||||||
plugins.beautylog.info('now building Dockerfile for ' + this.cleanTag)
|
|
||||||
let buildCommand = `docker build -t ${this.buildTag} -f ${this.filePath} .`
|
|
||||||
await bash(buildCommand)
|
|
||||||
NpmciEnv.dockerFilesBuilt.push(this)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* pushes the Dockerfile to a registry
|
|
||||||
*/
|
|
||||||
async push (stageArg) {
|
|
||||||
await bash(`docker tag ${this.buildTag} ${this.releaseTag}`)
|
|
||||||
await bash(`docker tag ${this.buildTag} ${this.gitlabReleaseTag}`)
|
|
||||||
await bash(`docker tag ${this.buildTag} ${this.gitlabTestTag}`)
|
|
||||||
switch (stageArg) {
|
|
||||||
case 'release':
|
|
||||||
await bash(`docker push ${this.gitlabReleaseTag}`)
|
|
||||||
await bash(`docker push ${this.releaseTag}`)
|
|
||||||
break
|
|
||||||
case 'test':
|
|
||||||
default:
|
|
||||||
await bash(`docker push ${this.gitlabTestTag}`)
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* pulls the Dockerfile from a registry
|
|
||||||
*/
|
|
||||||
async pull (registryArg: string) {
|
|
||||||
await bash(`docker pull ${this.gitlabTestTag}`)
|
|
||||||
await bash(`docker tag ${this.gitlabTestTag} ${this.buildTag}`)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* tests the Dockerfile;
|
|
||||||
*/
|
|
||||||
async test () {
|
|
||||||
let testFile: string = plugins.path.join(paths.NpmciTestDir, 'test_' + this.version + '.sh')
|
|
||||||
let testFileExists: boolean = plugins.smartfile.fs.fileExistsSync(testFile)
|
|
||||||
if (testFileExists) {
|
|
||||||
// run tests
|
|
||||||
await bash('docker run --name npmci_test_container ' + this.buildTag + ' mkdir /npmci_test')
|
|
||||||
await bash('docker cp ' + testFile + ' npmci_test_container:/npmci_test/test.sh')
|
|
||||||
await bash('docker commit npmci_test_container npmci_test_image')
|
|
||||||
await bash('docker run npmci_test_image sh /npmci_test/test.sh')
|
|
||||||
await bash('docker rm npmci_test_container')
|
|
||||||
await bash('docker rmi --force npmci_test_image')
|
|
||||||
} else {
|
|
||||||
plugins.beautylog.warn('skipping tests for ' + this.cleanTag + ' because no testfile was found!')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gets the id of a Dockerfile
|
|
||||||
*/
|
|
||||||
async getId () {
|
|
||||||
let containerId = await bash('docker inspect --type=image --format=\"{{.Id}}\" ' + this.buildTag)
|
|
||||||
return containerId
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* returns a version for a docker file
|
|
||||||
* @execution SYNC
|
|
||||||
*/
|
|
||||||
export let dockerFileVersion = (dockerfileNameArg: string): string => {
|
|
||||||
let versionString: string
|
|
||||||
let versionRegex = /Dockerfile_([a-zA-Z0-9\.]*)$/
|
|
||||||
let regexResultArray = versionRegex.exec(dockerfileNameArg)
|
|
||||||
if (regexResultArray && regexResultArray.length === 2) {
|
|
||||||
versionString = regexResultArray[ 1 ]
|
|
||||||
} else {
|
|
||||||
versionString = 'latest'
|
|
||||||
}
|
|
||||||
return versionString
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* returns the docker base image for a Dockerfile
|
|
||||||
*/
|
|
||||||
export let dockerBaseImage = function (dockerfileContentArg: string) {
|
|
||||||
let baseImageRegex = /FROM\s([a-zA-z0-9\/\-\:]*)\n?/
|
|
||||||
let regexResultArray = baseImageRegex.exec(dockerfileContentArg)
|
|
||||||
return regexResultArray[ 1 ]
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* returns the docker tag
|
|
||||||
*/
|
|
||||||
export let getDockerTagString = function (registryArg: string, repoArg: string, versionArg: string, suffixArg?: string): string {
|
|
||||||
// determine wether the suffix is needed
|
|
||||||
let version = versionArg
|
|
||||||
if (suffixArg) {
|
|
||||||
version = versionArg + '_' + suffixArg
|
|
||||||
}
|
|
||||||
let tagString = `${registryArg}/${repoArg}:${version}`
|
|
||||||
return tagString
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
export let cleanTagsArrayFunction = function (dockerfileArrayArg: Dockerfile[], trackingArrayArg: Dockerfile[]): string[] {
|
|
||||||
let cleanTagsArray: string[] = []
|
|
||||||
dockerfileArrayArg.forEach(function (dockerfileArg) {
|
|
||||||
if (trackingArrayArg.indexOf(dockerfileArg) === -1) {
|
|
||||||
cleanTagsArray.push(dockerfileArg.cleanTag)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
return cleanTagsArray
|
|
||||||
}
|
}
|
||||||
|
92
ts/mod_docker/mod.classes.dockerfile.ts
Normal file
92
ts/mod_docker/mod.classes.dockerfile.ts
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
import * as plugins from './mod.plugins'
|
||||||
|
import * as NpmciEnv from '../npmci.env'
|
||||||
|
import { bash } from '../npmci.bash'
|
||||||
|
import * as paths from '../npmci.paths'
|
||||||
|
|
||||||
|
import { DockerRegistry } from './mod.classes.dockerregistry'
|
||||||
|
import * as helpers from './mod.helpers'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* class Dockerfile represents a Dockerfile on disk in npmci
|
||||||
|
*/
|
||||||
|
export class Dockerfile {
|
||||||
|
filePath: string
|
||||||
|
repo: string
|
||||||
|
version: string
|
||||||
|
cleanTag: string
|
||||||
|
buildTag: string
|
||||||
|
containerName: string
|
||||||
|
content: string
|
||||||
|
baseImage: string
|
||||||
|
localBaseImageDependent: boolean
|
||||||
|
localBaseDockerfile: Dockerfile
|
||||||
|
constructor (options: { filePath?: string, fileContents?: string | Buffer, read?: boolean }) {
|
||||||
|
this.filePath = options.filePath
|
||||||
|
this.repo = NpmciEnv.repo.user + '/' + NpmciEnv.repo.repo
|
||||||
|
this.version = helpers.dockerFileVersion(plugins.path.parse(options.filePath).base)
|
||||||
|
this.cleanTag = this.repo + ':' + this.version
|
||||||
|
this.buildTag = this.cleanTag
|
||||||
|
|
||||||
|
this.containerName = 'dockerfile-' + this.version
|
||||||
|
if (options.filePath && options.read) {
|
||||||
|
this.content = plugins.smartfile.fs.toStringSync(plugins.path.resolve(options.filePath))
|
||||||
|
}
|
||||||
|
this.baseImage = helpers.dockerBaseImage(this.content)
|
||||||
|
this.localBaseImageDependent = false
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* builds the Dockerfile
|
||||||
|
*/
|
||||||
|
async build () {
|
||||||
|
plugins.beautylog.info('now building Dockerfile for ' + this.cleanTag)
|
||||||
|
let buildCommand = `docker build -t ${this.buildTag} -f ${this.filePath} .`
|
||||||
|
await bash(buildCommand)
|
||||||
|
NpmciEnv.dockerFilesBuilt.push(this)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* pushes the Dockerfile to a registry
|
||||||
|
*/
|
||||||
|
async push (dockerRegistryArg: DockerRegistry, versionSuffix: string = null) {
|
||||||
|
let pushTag = helpers.getDockerTagString(dockerRegistryArg.registryUrl, this.repo, this.version, versionSuffix)
|
||||||
|
await bash(`docker tag ${this.buildTag} ${pushTag}`)
|
||||||
|
await bash(`docker push ${pushTag}`)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* pulls the Dockerfile from a registry
|
||||||
|
*/
|
||||||
|
async pull (registryArg: DockerRegistry, versionSuffixArg: string = null) {
|
||||||
|
let pullTag = helpers.getDockerTagString(registryArg.registryUrl,this.repo, this.version, versionSuffixArg)
|
||||||
|
await bash(`docker tag ${pullTag} ${this.buildTag}`)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* tests the Dockerfile;
|
||||||
|
*/
|
||||||
|
async test () {
|
||||||
|
let testFile: string = plugins.path.join(paths.NpmciTestDir, 'test_' + this.version + '.sh')
|
||||||
|
let testFileExists: boolean = plugins.smartfile.fs.fileExistsSync(testFile)
|
||||||
|
if (testFileExists) {
|
||||||
|
// run tests
|
||||||
|
await bash('docker run --name npmci_test_container ' + this.buildTag + ' mkdir /npmci_test')
|
||||||
|
await bash('docker cp ' + testFile + ' npmci_test_container:/npmci_test/test.sh')
|
||||||
|
await bash('docker commit npmci_test_container npmci_test_image')
|
||||||
|
await bash('docker run npmci_test_image sh /npmci_test/test.sh')
|
||||||
|
await bash('docker rm npmci_test_container')
|
||||||
|
await bash('docker rmi --force npmci_test_image')
|
||||||
|
} else {
|
||||||
|
plugins.beautylog.warn('skipping tests for ' + this.cleanTag + ' because no testfile was found!')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gets the id of a Dockerfile
|
||||||
|
*/
|
||||||
|
async getId () {
|
||||||
|
let containerId = await bash('docker inspect --type=image --format=\"{{.Id}}\" ' + this.buildTag)
|
||||||
|
return containerId
|
||||||
|
}
|
||||||
|
}
|
46
ts/mod_docker/mod.classes.dockerregistry.ts
Normal file
46
ts/mod_docker/mod.classes.dockerregistry.ts
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
import * as plugins from './mod.plugins'
|
||||||
|
import { bash } from '../npmci.bash'
|
||||||
|
|
||||||
|
export interface IDockerRegistryConstructorOptions {
|
||||||
|
registryUrl: string,
|
||||||
|
username: string,
|
||||||
|
password: string
|
||||||
|
}
|
||||||
|
|
||||||
|
export class DockerRegistry {
|
||||||
|
registryUrl: string
|
||||||
|
username: string
|
||||||
|
password: string
|
||||||
|
constructor (optionsArg: IDockerRegistryConstructorOptions) {
|
||||||
|
this.registryUrl = optionsArg.registryUrl
|
||||||
|
this.username = optionsArg.username
|
||||||
|
this.password = optionsArg.password
|
||||||
|
}
|
||||||
|
|
||||||
|
static fromEnvString (envString: string): DockerRegistry {
|
||||||
|
let dockerRegexResultArray = envString.split('|')
|
||||||
|
if (dockerRegexResultArray.length !== 3) {
|
||||||
|
plugins.beautylog.error('malformed docker env var...')
|
||||||
|
process.exit(1)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
let registryUrl = dockerRegexResultArray[0]
|
||||||
|
let username = dockerRegexResultArray[1]
|
||||||
|
let password = dockerRegexResultArray[2]
|
||||||
|
return new DockerRegistry({
|
||||||
|
registryUrl: registryUrl,
|
||||||
|
username: username,
|
||||||
|
password: password
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
async login () {
|
||||||
|
if (this.registryUrl === 'docker.io') {
|
||||||
|
await bash(`docker login -u ${this.username} -p ${this.password}`)
|
||||||
|
plugins.beautylog.info('Logged in to standard docker hub')
|
||||||
|
} else {
|
||||||
|
await bash(`docker login -u ${this.username} -p ${this.password} ${this.registryUrl}`)
|
||||||
|
}
|
||||||
|
plugins.beautylog.success(`docker authenticated for ${this.registryUrl}!`)
|
||||||
|
}
|
||||||
|
}
|
27
ts/mod_docker/mod.classes.registrystorage.ts
Normal file
27
ts/mod_docker/mod.classes.registrystorage.ts
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
import * as plugins from './mod.plugins'
|
||||||
|
import { Objectmap } from 'lik'
|
||||||
|
|
||||||
|
import { DockerRegistry } from './mod.classes.dockerregistry'
|
||||||
|
|
||||||
|
export class RegistryStorage {
|
||||||
|
objectMap = new Objectmap<DockerRegistry>()
|
||||||
|
constructor () {
|
||||||
|
// Nothing here
|
||||||
|
}
|
||||||
|
|
||||||
|
addRegistry (registryArg: DockerRegistry) {
|
||||||
|
this.objectMap.add(registryArg)
|
||||||
|
}
|
||||||
|
|
||||||
|
getRegistryByUrl (registryUrlArg: string) {
|
||||||
|
return this.objectMap.find(registryArg => {
|
||||||
|
return registryArg.registryUrl === registryUrlArg
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
async loginAll () {
|
||||||
|
await this.objectMap.forEach(async registryArg => {
|
||||||
|
await registryArg.login()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
154
ts/mod_docker/mod.helpers.ts
Normal file
154
ts/mod_docker/mod.helpers.ts
Normal file
@ -0,0 +1,154 @@
|
|||||||
|
import * as plugins from './mod.plugins'
|
||||||
|
import * as paths from '../npmci.paths'
|
||||||
|
import * as NpmciEnv from '../npmci.env'
|
||||||
|
import { bash } from '../npmci.bash'
|
||||||
|
|
||||||
|
import { Dockerfile } from './mod.classes.dockerfile'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* creates instance of class Dockerfile for all Dockerfiles in cwd
|
||||||
|
* @returns Promise<Dockerfile[]>
|
||||||
|
*/
|
||||||
|
export let readDockerfiles = async (): Promise<Dockerfile[]> => {
|
||||||
|
let fileTree = await plugins.smartfile.fs.listFileTree(paths.cwd, 'Dockerfile*')
|
||||||
|
|
||||||
|
// create the Dockerfile array
|
||||||
|
let readDockerfilesArray: Dockerfile[] = []
|
||||||
|
plugins.beautylog.info(`found ${fileTree.length} Dockerfiles:`)
|
||||||
|
console.log(fileTree)
|
||||||
|
for (let dockerfilePath of fileTree) {
|
||||||
|
let myDockerfile = new Dockerfile({
|
||||||
|
filePath: dockerfilePath,
|
||||||
|
read: true
|
||||||
|
})
|
||||||
|
readDockerfilesArray.push(myDockerfile)
|
||||||
|
}
|
||||||
|
|
||||||
|
return readDockerfilesArray
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* sorts Dockerfiles into a dependency chain
|
||||||
|
* @param sortableArrayArg an array of instances of class Dockerfile
|
||||||
|
* @returns Promise<Dockerfile[]>
|
||||||
|
*/
|
||||||
|
export let sortDockerfiles = (sortableArrayArg: Dockerfile[]): Promise<Dockerfile[]> => {
|
||||||
|
let done = plugins.q.defer<Dockerfile[]>()
|
||||||
|
plugins.beautylog.info('sorting Dockerfiles:')
|
||||||
|
let sortedArray: Dockerfile[] = []
|
||||||
|
let cleanTagsOriginal = cleanTagsArrayFunction(sortableArrayArg, sortedArray)
|
||||||
|
let sorterFunctionCounter: number = 0
|
||||||
|
let sorterFunction = function () {
|
||||||
|
sortableArrayArg.forEach((dockerfileArg) => {
|
||||||
|
let cleanTags = cleanTagsArrayFunction(sortableArrayArg, sortedArray)
|
||||||
|
if (cleanTags.indexOf(dockerfileArg.baseImage) === -1 && sortedArray.indexOf(dockerfileArg) === -1) {
|
||||||
|
sortedArray.push(dockerfileArg)
|
||||||
|
}
|
||||||
|
if (cleanTagsOriginal.indexOf(dockerfileArg.baseImage) !== -1) {
|
||||||
|
dockerfileArg.localBaseImageDependent = true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
if (sortableArrayArg.length === sortedArray.length) {
|
||||||
|
let counter = 1
|
||||||
|
for (let dockerfile of sortedArray) {
|
||||||
|
plugins.beautylog.log(`tag ${counter}: -> ${dockerfile.cleanTag}`)
|
||||||
|
counter++
|
||||||
|
}
|
||||||
|
done.resolve(sortedArray)
|
||||||
|
} else if (sorterFunctionCounter < 10) {
|
||||||
|
sorterFunctionCounter++
|
||||||
|
sorterFunction()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sorterFunction()
|
||||||
|
return done.promise
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* maps local Dockerfiles dependencies to the correspoding Dockerfile class instances
|
||||||
|
*/
|
||||||
|
export let mapDockerfiles = async (sortedArray: Dockerfile[]): Promise<Dockerfile[]> => {
|
||||||
|
sortedArray.forEach((dockerfileArg) => {
|
||||||
|
if (dockerfileArg.localBaseImageDependent) {
|
||||||
|
sortedArray.forEach((dockfile2: Dockerfile) => {
|
||||||
|
if (dockfile2.cleanTag === dockerfileArg.baseImage) {
|
||||||
|
dockerfileArg.localBaseDockerfile = dockfile2
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return sortedArray
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* builds the correspoding real docker image for each Dockerfile class instance
|
||||||
|
*/
|
||||||
|
export let buildDockerfiles = async (sortedArrayArg: Dockerfile[]) => {
|
||||||
|
for (let dockerfileArg of sortedArrayArg) {
|
||||||
|
await dockerfileArg.build()
|
||||||
|
}
|
||||||
|
return sortedArrayArg
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* tests all Dockerfiles in by calling class Dockerfile.test();
|
||||||
|
* @param sortedArrayArg Dockerfile[] that contains all Dockerfiles in cwd
|
||||||
|
*/
|
||||||
|
export let testDockerfiles = async (sortedArrayArg: Dockerfile[]) => {
|
||||||
|
for (let dockerfileArg of sortedArrayArg) {
|
||||||
|
await dockerfileArg.test()
|
||||||
|
}
|
||||||
|
return sortedArrayArg
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns a version for a docker file
|
||||||
|
* @execution SYNC
|
||||||
|
*/
|
||||||
|
export let dockerFileVersion = (dockerfileNameArg: string): string => {
|
||||||
|
let versionString: string
|
||||||
|
let versionRegex = /Dockerfile_([a-zA-Z0-9\.]*)$/
|
||||||
|
let regexResultArray = versionRegex.exec(dockerfileNameArg)
|
||||||
|
if (regexResultArray && regexResultArray.length === 2) {
|
||||||
|
versionString = regexResultArray[ 1 ]
|
||||||
|
} else {
|
||||||
|
versionString = 'latest'
|
||||||
|
}
|
||||||
|
return versionString
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the docker base image for a Dockerfile
|
||||||
|
*/
|
||||||
|
export let dockerBaseImage = function (dockerfileContentArg: string) {
|
||||||
|
let baseImageRegex = /FROM\s([a-zA-z0-9\/\-\:]*)\n?/
|
||||||
|
let regexResultArray = baseImageRegex.exec(dockerfileContentArg)
|
||||||
|
return regexResultArray[ 1 ]
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the docker tag
|
||||||
|
*/
|
||||||
|
export let getDockerTagString = function (registryArg: string, repoArg: string, versionArg: string, suffixArg?: string): string {
|
||||||
|
// determine wether the suffix is needed
|
||||||
|
let version = versionArg
|
||||||
|
if (suffixArg) {
|
||||||
|
version = versionArg + '_' + suffixArg
|
||||||
|
}
|
||||||
|
let tagString = `${registryArg}/${repoArg}:${version}`
|
||||||
|
return tagString
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
export let cleanTagsArrayFunction = function (dockerfileArrayArg: Dockerfile[], trackingArrayArg: Dockerfile[]): string[] {
|
||||||
|
let cleanTagsArray: string[] = []
|
||||||
|
dockerfileArrayArg.forEach(function (dockerfileArg) {
|
||||||
|
if (trackingArrayArg.indexOf(dockerfileArg) === -1) {
|
||||||
|
cleanTagsArray.push(dockerfileArg.cleanTag)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return cleanTagsArray
|
||||||
|
}
|
@ -1501,9 +1501,9 @@ liftoff@^2.1.0:
|
|||||||
rechoir "^0.6.2"
|
rechoir "^0.6.2"
|
||||||
resolve "^1.1.7"
|
resolve "^1.1.7"
|
||||||
|
|
||||||
lik@^1.0.30, lik@^1.0.38:
|
lik@^1.0.30, lik@^1.0.38, lik@^1.0.39:
|
||||||
version "1.0.38"
|
version "1.0.39"
|
||||||
resolved "https://registry.yarnpkg.com/lik/-/lik-1.0.38.tgz#ccff0abd3d9236a5e4b7d80d514c5c210f18469b"
|
resolved "https://registry.yarnpkg.com/lik/-/lik-1.0.39.tgz#20eeaa93167a19f03ba2c9650939145326051ee6"
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/lodash" "^4.14.67"
|
"@types/lodash" "^4.14.67"
|
||||||
"@types/minimatch" "2.x.x"
|
"@types/minimatch" "2.x.x"
|
||||||
|
Loading…
Reference in New Issue
Block a user