@eclipse-che/che-devworkspace-generator
Advanced tools
Comparing version 0.0.1-638fadc to 0.0.1-6ef61ae
@@ -12,6 +12,6 @@ /********************************************************************** | ||
export declare class Generate { | ||
static readonly MERGE_CONTRIBUTION = "controller.devfile.io/merge-contribution"; | ||
private devContainerComponentFinder; | ||
generate(devfileContent: string, editorContent: string, outputFile?: string, injectDefaultComponent?: string, defaultComponentImage?: string): Promise<DevfileContext>; | ||
generateContent(devfileContent: string, editorContent: string, injectDefaultComponent?: string, defaultComponentImage?: string): Promise<DevfileContext>; | ||
private createDevWorkspaceMetadata; | ||
} |
@@ -81,3 +81,2 @@ "use strict"; | ||
} | ||
Generate_1 = Generate; | ||
Generate.prototype.generate = function (devfileContent, editorContent, outputFile, injectDefaultComponent, defaultComponentImage) { | ||
@@ -108,3 +107,3 @@ return __awaiter(this, void 0, void 0, function () { | ||
return __awaiter(this, void 0, void 0, function () { | ||
var devfile, suffix, editorDevfile, metadata, editorDevWorkspaceTemplate, devfileMetadata, devfileCopy, editorSpecContribution, devWorkspace, devWorkspaceTemplates, context, devContainer, devContainerAttributes; | ||
var devfile, suffix, editorDevfile, metadata, editorDevWorkspaceTemplate, devfileMetadata, devfileCopy, editorSpecContribution, devWorkspace, devWorkspaceTemplates, context; | ||
return __generator(this, function (_a) { | ||
@@ -116,3 +115,3 @@ switch (_a.label) { | ||
editorDevfile = jsYaml.load(editorContent); | ||
metadata = editorDevfile.metadata; | ||
metadata = this.createDevWorkspaceMetadata(editorDevfile); | ||
// add sufix | ||
@@ -128,3 +127,3 @@ metadata.name = metadata.name + "-" + suffix; | ||
}; | ||
devfileMetadata = devfile.metadata; | ||
devfileMetadata = this.createDevWorkspaceMetadata(devfile, true); | ||
devfileCopy = Object.assign({}, devfile); | ||
@@ -157,17 +156,7 @@ delete devfileCopy.schemaVersion; | ||
}; | ||
// find devContainer component, add a default one if not found | ||
return [4 /*yield*/, this.devContainerComponentFinder.find(context, injectDefaultComponent, defaultComponentImage)]; | ||
case 1: | ||
devContainer = _a.sent(); | ||
if (!devContainer) { | ||
return [2 /*return*/, context]; | ||
} | ||
devContainerAttributes = devContainer.attributes; | ||
if (!devContainerAttributes) { | ||
devContainerAttributes = {}; | ||
devContainerAttributes[Generate_1.MERGE_CONTRIBUTION] = true; | ||
devContainer.attributes = devContainerAttributes; | ||
} | ||
else { | ||
devContainerAttributes[Generate_1.MERGE_CONTRIBUTION] = true; | ||
} | ||
// find devContainer component, add a default one if not found | ||
_a.sent(); | ||
return [2 /*return*/, context]; | ||
@@ -178,8 +167,23 @@ } | ||
}; | ||
var Generate_1; | ||
Generate.MERGE_CONTRIBUTION = 'controller.devfile.io/merge-contribution'; | ||
Generate.prototype.createDevWorkspaceMetadata = function (devfile, addDevfileContent) { | ||
if (addDevfileContent === void 0) { addDevfileContent = false; } | ||
var devWorkspaceMetadata = {}; | ||
var devfileMetadata = devfile.metadata; | ||
if (devfileMetadata.name) { | ||
devWorkspaceMetadata.name = devfileMetadata.name; | ||
} | ||
if (devfileMetadata.generateName) { | ||
devWorkspaceMetadata.generateName = devfileMetadata.generateName; | ||
} | ||
if (addDevfileContent) { | ||
devWorkspaceMetadata.annotations = { | ||
'che.eclipse.org/devfile': jsYaml.dump(devfile) | ||
}; | ||
} | ||
return devWorkspaceMetadata; | ||
}; | ||
__decorate([ | ||
(0, inversify_1.inject)(dev_container_component_finder_1.DevContainerComponentFinder) | ||
], Generate.prototype, "devContainerComponentFinder"); | ||
Generate = Generate_1 = __decorate([ | ||
Generate = __decorate([ | ||
(0, inversify_1.injectable)() | ||
@@ -186,0 +190,0 @@ ], Generate); |
@@ -15,6 +15,8 @@ "use strict"; | ||
var github_resolver_1 = require("./github-resolver"); | ||
var types_1 = require("../types"); | ||
var Resolver = types_1.TYPES.Resolver; | ||
var githubModule = new inversify_1.ContainerModule(function (bind) { | ||
bind(github_resolver_1.GithubResolver).toSelf().inSingletonScope(); | ||
bind(Resolver).to(github_resolver_1.GithubResolver).inSingletonScope(); | ||
}); | ||
exports.githubModule = githubModule; | ||
//# sourceMappingURL=github-module.js.map |
@@ -10,10 +10,9 @@ /********************************************************************** | ||
***********************************************************************/ | ||
import { GithubUrl } from './github-url'; | ||
/** | ||
* Provides a github URL object allowing to interact | ||
*/ | ||
export declare class GithubResolver { | ||
import { Url } from '../resolve/url'; | ||
import { Resolver } from '../resolve/resolver'; | ||
export declare class GithubResolver implements Resolver { | ||
static readonly GITHUB_URL_PATTERN: RegExp; | ||
resolve(link: string): GithubUrl; | ||
getGroup(match: RegExpExecArray, groupName: string, defaultValue?: string): string; | ||
isValid(url: string): boolean; | ||
resolve(link: string): Url; | ||
private getGroup; | ||
} |
@@ -21,5 +21,2 @@ "use strict"; | ||
var inversify_1 = require("inversify"); | ||
/** | ||
* Provides a github URL object allowing to interact | ||
*/ | ||
var GithubResolver = /** @class */ (function () { | ||
@@ -29,2 +26,5 @@ function GithubResolver() { | ||
GithubResolver_1 = GithubResolver; | ||
GithubResolver.prototype.isValid = function (url) { | ||
return GithubResolver_1.GITHUB_URL_PATTERN.test(url); | ||
}; | ||
GithubResolver.prototype.resolve = function (link) { | ||
@@ -39,2 +39,5 @@ var match = GithubResolver_1.GITHUB_URL_PATTERN.exec(link); | ||
var repoName = this.getGroup(match, 'repoName'); | ||
if (/^[\w-][\w.-]*?\.git$/.test(repoName)) { | ||
repoName = repoName.substring(0, repoName.length - 4); | ||
} | ||
var branchName = this.getGroup(match, 'branchName', 'HEAD'); | ||
@@ -41,0 +44,0 @@ var subFolder = this.getGroup(match, 'subFolder'); |
@@ -10,6 +10,4 @@ /********************************************************************** | ||
***********************************************************************/ | ||
/** | ||
* Provides helper methods on top of github URL to get for example raw content of get relative links | ||
*/ | ||
export declare class GithubUrl { | ||
import { Url } from '../resolve/url'; | ||
export declare class GithubUrl implements Url { | ||
private readonly scheme; | ||
@@ -16,0 +14,0 @@ private readonly hostName; |
@@ -13,5 +13,2 @@ "use strict"; | ||
exports.GithubUrl = void 0; | ||
/** | ||
* Provides helper methods on top of github URL to get for example raw content of get relative links | ||
*/ | ||
var GithubUrl = /** @class */ (function () { | ||
@@ -18,0 +15,0 @@ function GithubUrl(scheme, hostName, repoUser, repoName, branchName, subFolder) { |
@@ -54,3 +54,6 @@ "use strict"; | ||
var github_module_1 = require("../github/github-module"); | ||
var resolve_module_1 = require("../resolve/resolve-module"); | ||
var plugin_registry_module_1 = require("../plugin-registry/plugin-registry-module"); | ||
var bitbucket_module_1 = require("../bitbucket/bitbucket-module"); | ||
var bitbucket_server_module_1 = require("../bitbucket-server/bitbucket-server-module"); | ||
/** | ||
@@ -69,2 +72,5 @@ * Manage all bindings for inversify | ||
this.container.load(github_module_1.githubModule); | ||
this.container.load(bitbucket_module_1.bitbucketModule); | ||
this.container.load(bitbucket_server_module_1.bitbucketServerModule); | ||
this.container.load(resolve_module_1.resolveModule); | ||
this.container.load(plugin_registry_module_1.pluginRegistryModule); | ||
@@ -71,0 +77,0 @@ this.container.bind(Symbol["for"]('AxiosInstance')).toConstantValue(options.axiosInstance); |
@@ -71,3 +71,2 @@ "use strict"; | ||
var generate_1 = require("./generate"); | ||
var github_resolver_1 = require("./github/github-resolver"); | ||
var jsYaml = __importStar(require("js-yaml")); | ||
@@ -77,2 +76,3 @@ var inversify_binding_1 = require("./inversify/inversify-binding"); | ||
var plugin_registry_resolver_1 = require("./plugin-registry/plugin-registry-resolver"); | ||
var git_url_resolver_1 = require("./resolve/git-url-resolver"); | ||
var Main = /** @class */ (function () { | ||
@@ -88,3 +88,3 @@ /** | ||
return __awaiter(this, void 0, void 0, function () { | ||
var pluginRegistryUrl, inversifyBinbding, container, devfileContent, editorContent, githubResolver, githubUrl, devfileParsed, editorDevfile, generate; | ||
var pluginRegistryUrl, inversifyBinbding, container, devfileContent, editorContent, resolver, url, devfileParsed, editorDevfile, generate; | ||
return __generator(this, function (_a) { | ||
@@ -115,5 +115,5 @@ switch (_a.label) { | ||
if (!params.devfileUrl) return [3 /*break*/, 3]; | ||
githubResolver = container.get(github_resolver_1.GithubResolver); | ||
githubUrl = githubResolver.resolve(params.devfileUrl); | ||
return [4 /*yield*/, container.get(url_fetcher_1.UrlFetcher).fetchText(githubUrl.getContentUrl('devfile.yaml'))]; | ||
resolver = container.get(git_url_resolver_1.GitUrlResolver); | ||
url = resolver.resolve(params.devfileUrl); | ||
return [4 /*yield*/, container.get(url_fetcher_1.UrlFetcher).fetchText(url.getContentUrl('devfile.yaml'))]; | ||
case 2: | ||
@@ -128,6 +128,6 @@ // user devfile | ||
{ | ||
name: githubUrl.getRepoName(), | ||
name: url.getRepoName(), | ||
git: { | ||
remotes: { origin: githubUrl.getCloneUrl() }, | ||
checkoutFrom: { revision: githubUrl.getBranchName() } | ||
remotes: { origin: url.getCloneUrl() }, | ||
checkoutFrom: { revision: url.getBranchName() } | ||
} | ||
@@ -134,0 +134,0 @@ }, |
{ | ||
"name": "@eclipse-che/che-devworkspace-generator", | ||
"version": "0.0.1-638fadc", | ||
"version": "0.0.1-6ef61ae", | ||
"private": false, | ||
@@ -5,0 +5,0 @@ "description": "Generates DevWorkspaces by transforming existing devfiles", |
@@ -12,5 +12,7 @@ /********************************************************************** | ||
import { | ||
V221Devfile, | ||
V221DevfileMetadata, | ||
V1alpha2DevWorkspace, | ||
V1alpha2DevWorkspaceMetadata, | ||
V1alpha2DevWorkspaceSpecContributions, | ||
V1alpha2DevWorkspaceSpecTemplateComponents, | ||
V1alpha2DevWorkspaceTemplate, | ||
@@ -25,6 +27,10 @@ V1alpha2DevWorkspaceTemplateSpec, | ||
type DevfileLike = V221Devfile & { | ||
metadata: V221DevfileMetadata & { | ||
generateName?: string; | ||
}; | ||
}; | ||
@injectable() | ||
export class Generate { | ||
static readonly MERGE_CONTRIBUTION = 'controller.devfile.io/merge-contribution'; | ||
@inject(DevContainerComponentFinder) | ||
@@ -78,3 +84,3 @@ private devContainerComponentFinder: DevContainerComponentFinder; | ||
// transform it into a devWorkspace template | ||
const metadata = editorDevfile.metadata; | ||
const metadata = this.createDevWorkspaceMetadata(editorDevfile); | ||
// add sufix | ||
@@ -92,3 +98,3 @@ metadata.name = `${metadata.name}-${suffix}`; | ||
// transform it into a devWorkspace | ||
const devfileMetadata = devfile.metadata; | ||
const devfileMetadata = this.createDevWorkspaceMetadata(devfile, true); | ||
const devfileCopy = Object.assign({}, devfile); | ||
@@ -125,22 +131,26 @@ delete devfileCopy.schemaVersion; | ||
// grab container where to inject controller.devfile.io/merge-contribution attribute | ||
let devContainer: V1alpha2DevWorkspaceSpecTemplateComponents | undefined = | ||
await this.devContainerComponentFinder.find(context, injectDefaultComponent, defaultComponentImage); | ||
// find devContainer component, add a default one if not found | ||
await this.devContainerComponentFinder.find(context, injectDefaultComponent, defaultComponentImage); | ||
if (!devContainer) { | ||
return context; | ||
} | ||
return context; | ||
} | ||
// add attributes | ||
let devContainerAttributes = devContainer.attributes; | ||
if (!devContainerAttributes) { | ||
devContainerAttributes = {}; | ||
devContainerAttributes[Generate.MERGE_CONTRIBUTION] = true; | ||
devContainer.attributes = devContainerAttributes; | ||
} else { | ||
devContainerAttributes[Generate.MERGE_CONTRIBUTION] = true; | ||
private createDevWorkspaceMetadata(devfile: DevfileLike, addDevfileContent = false): V1alpha2DevWorkspaceMetadata { | ||
const devWorkspaceMetadata = {} as V1alpha2DevWorkspaceMetadata; | ||
const devfileMetadata = devfile.metadata; | ||
if (devfileMetadata.name) { | ||
devWorkspaceMetadata.name = devfileMetadata.name; | ||
} | ||
if (devfileMetadata.generateName) { | ||
devWorkspaceMetadata.generateName = devfileMetadata.generateName; | ||
} | ||
if (addDevfileContent) { | ||
devWorkspaceMetadata.annotations = { | ||
'che.eclipse.org/devfile': jsYaml.dump(devfile), | ||
}; | ||
} | ||
return context; | ||
return devWorkspaceMetadata; | ||
} | ||
} |
@@ -13,7 +13,10 @@ /********************************************************************** | ||
import { GithubResolver } from './github-resolver'; | ||
import { TYPES } from '../types'; | ||
const { Resolver } = TYPES; | ||
const githubModule = new ContainerModule((bind: interfaces.Bind) => { | ||
bind(GithubResolver).toSelf().inSingletonScope(); | ||
bind(Resolver).to(GithubResolver).inSingletonScope(); | ||
}); | ||
export { githubModule }; |
@@ -13,8 +13,7 @@ /********************************************************************** | ||
import { injectable } from 'inversify'; | ||
import { Url } from '../resolve/url'; | ||
import { Resolver } from '../resolve/resolver'; | ||
/** | ||
* Provides a github URL object allowing to interact | ||
*/ | ||
@injectable() | ||
export class GithubResolver { | ||
export class GithubResolver implements Resolver { | ||
// eslint-disable-next-line max-len | ||
@@ -24,3 +23,7 @@ static readonly GITHUB_URL_PATTERN = | ||
resolve(link: string): GithubUrl { | ||
isValid(url: string): boolean { | ||
return GithubResolver.GITHUB_URL_PATTERN.test(url); | ||
} | ||
resolve(link: string): Url { | ||
const match = GithubResolver.GITHUB_URL_PATTERN.exec(link); | ||
@@ -33,3 +36,6 @@ if (!match) { | ||
const repoUser = this.getGroup(match, 'repoUser'); | ||
const repoName = this.getGroup(match, 'repoName'); | ||
let repoName = this.getGroup(match, 'repoName'); | ||
if (/^[\w-][\w.-]*?\.git$/.test(repoName)) { | ||
repoName = repoName.substring(0, repoName.length - 4); | ||
} | ||
const branchName = this.getGroup(match, 'branchName', 'HEAD'); | ||
@@ -40,3 +46,3 @@ const subFolder = this.getGroup(match, 'subFolder'); | ||
getGroup(match: RegExpExecArray, groupName: string, defaultValue?: string) { | ||
private getGroup(match: RegExpExecArray, groupName: string, defaultValue?: string) { | ||
if (match.groups && match.groups[groupName]) { | ||
@@ -43,0 +49,0 @@ return match.groups[groupName]; |
@@ -11,6 +11,5 @@ /********************************************************************** | ||
/** | ||
* Provides helper methods on top of github URL to get for example raw content of get relative links | ||
*/ | ||
export class GithubUrl { | ||
import { Url } from '../resolve/url'; | ||
export class GithubUrl implements Url { | ||
constructor( | ||
@@ -17,0 +16,0 @@ private readonly scheme: string, |
@@ -17,3 +17,6 @@ /********************************************************************** | ||
import { githubModule } from '../github/github-module'; | ||
import { resolveModule } from '../resolve/resolve-module'; | ||
import { pluginRegistryModule } from '../plugin-registry/plugin-registry-module'; | ||
import { bitbucketModule } from '../bitbucket/bitbucket-module'; | ||
import { bitbucketServerModule } from '../bitbucket-server/bitbucket-server-module'; | ||
@@ -32,2 +35,5 @@ /** | ||
this.container.load(githubModule); | ||
this.container.load(bitbucketModule); | ||
this.container.load(bitbucketServerModule); | ||
this.container.load(resolveModule); | ||
this.container.load(pluginRegistryModule); | ||
@@ -34,0 +40,0 @@ |
@@ -14,3 +14,2 @@ /********************************************************************** | ||
import { Generate } from './generate'; | ||
import { GithubResolver } from './github/github-resolver'; | ||
import * as jsYaml from 'js-yaml'; | ||
@@ -22,2 +21,3 @@ import { InversifyBinding } from './inversify/inversify-binding'; | ||
import { DevfileContext } from './api/devfile-context'; | ||
import { GitUrlResolver } from './resolve/git-url-resolver'; | ||
@@ -74,8 +74,8 @@ export class Main { | ||
// gets the github URL | ||
// gets the repo URL | ||
if (params.devfileUrl) { | ||
const githubResolver = container.get(GithubResolver); | ||
const githubUrl = githubResolver.resolve(params.devfileUrl); | ||
const resolver = container.get(GitUrlResolver); | ||
const url = resolver.resolve(params.devfileUrl); | ||
// user devfile | ||
devfileContent = await container.get(UrlFetcher).fetchText(githubUrl.getContentUrl('devfile.yaml')); | ||
devfileContent = await container.get(UrlFetcher).fetchText(url.getContentUrl('devfile.yaml')); | ||
@@ -90,6 +90,6 @@ // load content | ||
{ | ||
name: githubUrl.getRepoName(), | ||
name: url.getRepoName(), | ||
git: { | ||
remotes: { origin: githubUrl.getCloneUrl() }, | ||
checkoutFrom: { revision: githubUrl.getBranchName() }, | ||
remotes: { origin: url.getCloneUrl() }, | ||
checkoutFrom: { revision: url.getBranchName() }, | ||
}, | ||
@@ -96,0 +96,0 @@ }, |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Unidentified License
License(Experimental) Something that seems like a license was found, but its contents could not be matched with a known license.
Found 4 instances in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Unidentified License
License(Experimental) Something that seems like a license was found, but its contents could not be matched with a known license.
Found 2 instances in 1 package
174210
106
3067
6