@firestartr/cli 0.1.25 → 0.1.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/index.js CHANGED
@@ -228011,8 +228011,8 @@ var envVars;
228011
228011
  // ---- CDKTF/LOCAL VARIABLES -----------------------------------------------
228012
228012
  envVars["cdktfConfigFiles"] = "CDKTF_CONFIG_FILES";
228013
228013
  envVars["exclusionsYamlPath"] = "EXCLUSIONS_PATH";
228014
- envVars["cdktfEntity"] = "FIRESTARTR_CDKTF_ENTITY";
228015
- envVars["cdktfDeps"] = "FIRESTARTR_CDKTF_DEPS";
228014
+ envVars["cdktfEntityPath"] = "FIRESTARTR_CDKTF_ENTITY_PATH";
228015
+ envVars["cdktfDepsPath"] = "FIRESTARTR_CDKTF_DEPS_PATH";
228016
228016
  envVars["cdktfIsImport"] = "FIRESTARTR_CDKTF_IS_IMPORT";
228017
228017
  // ---- GITHUB APP VARIABLES -----------------------------------------------
228018
228018
  envVars["githubAppId"] = "GITHUB_APP_ID";
@@ -232567,6 +232567,7 @@ async function getAffectedRepositories(claimPathFromMain, claimPathFromPR, wetRe
232567
232567
  const compareResult = compareCRs(renderFromMainBranch[key], renderFromPRBranch[key]);
232568
232568
  if (compareResult.changed) {
232569
232569
  const affectedRepo = (0, utils_1.getAffectedWetRepository)(providers, wetRepositoriesConfig, kind);
232570
+ console.dir(affectedRepo, { depth: null });
232570
232571
  affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify;
232571
232572
  affectedResources[key] = {
232572
232573
  changes: compareResult.changes,
@@ -232642,7 +232643,7 @@ async function runComparer(claimPathFromMain, claimPathFromPR, claimsDefaultsPat
232642
232643
  writeWetAffectedRepositoriesFile(result.repos, pathForAffectedReposFile);
232643
232644
  }
232644
232645
  exports.runComparer = runComparer;
232645
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/comparer/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { App, YamlOutputType } from \"cdk8s\";\nimport * as fs from \"fs\";\nimport * as yaml from \"js-yaml\";\nimport * as fastJsonPatch  from \"fast-json-patch\"\nimport { configurePathsForRendering, getAffectedWetRepository } from \"./utils\";\nimport { setPath } from \"../config\";\nimport { render } from \"../renderer/renderer\";\nimport { emptyRenderedClaims } from \"../refresolver\";\n\n/**\n * @description Type with the affected wet repositories\n */\ntype AffectedResource = {\n\n    // Changes in the resource with the format of fast-json-patch\n    changes: fastJsonPatch.Operation[],\n\n    // The reason why the resource is affected\n    reason: \"MODIFIED\" | \"DELETED_FROM_PR\"  | \"ADDED_TO_PR\"\n\n}\n\n/**\n * @description Object with the affected wet repositories\n */\ntype AffectedResources = {\n\n    [key: string]: AffectedResource\n\n}\n\nconst MAIN_BRANCH_OUTPUT_DIR: string = \"/tmp/resources_from_main_branch\";\nconst PR_BRANCH_OUTPUT_DIR: string = \"/tmp/resources_from_pr_branch\";\n\n\n\n/**\n * @description Get the affected wet repositories by a PR\n * @param claimPathFromMain Path to the claims from the main branch\n * @param claimPathFromPR Path to the claims from the PR branch\n * @param wetRepositoriesConfigPath Path to the wet repositories config\n * */\nexport async function getAffectedRepositories(\n\n    claimPathFromMain: string,\n\n    claimPathFromPR: string,\n\n    wetRepositoriesConfigPath: string\n\n) : Promise<{ repos: { [key: string]: string}, changedResources: AffectedResources }> {\n\n    /*\n     * We need this folder to exist, so we create it beforehand\n     *\n     */\n    if(!fs.existsSync(MAIN_BRANCH_OUTPUT_DIR)) {\n\n      fs.mkdirSync(MAIN_BRANCH_OUTPUT_DIR);\n\n    }\n\n    /**\n     * Object with the affected wet repositories\n     * This will be returned in order to trigger\n     * the pipelines of the affected wet repositories\n     */\n    const affectedWetRepositories:  { [key: string]: string} = {}\n\n    /**\n     * Object with the affected resources\n     * This will be returned for a summary of the changes,\n     * and the user will be able to see the changes in the\n     * pipeline logs.\n     */\n    const affectedResources: AffectedResources = {}\n\n    // Load the wet repositories config\n    const wetRepositoriesConfig: any = yaml.load(fs.readFileSync(wetRepositoriesConfigPath, \"utf-8\"));\n\n    // Get the providers from the wet repositories config\n    const providers = Object.keys(wetRepositoriesConfig.states)\n\n    // Set the claims path to the main branch\n    setPath(\"claims\", claimPathFromMain);\n\n    // Configure the renderer\n    configurePathsForRendering();\n\n    const mainBranchFirestartrApp = new App({\n        outdir: MAIN_BRANCH_OUTPUT_DIR,\n        outputFileExtension: \".yaml\",\n        yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n    })\n\n    const mainBranchCatalogApp = new App({\n        outdir: \"/tmp/.catalog\",\n        outputFileExtension: \".yaml\",\n        yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n    })\n\n    // Render the main branch\n    let renderFromMainBranch: any = await render(mainBranchCatalogApp, mainBranchFirestartrApp)\n\n    mainBranchFirestartrApp.synth();\n\n    emptyRenderedClaims();\n\n    // Change the claims path to the PR branch\n    setPath(\"claims\", claimPathFromPR)\n\n    const app2 = new App({\n        outdir: PR_BRANCH_OUTPUT_DIR,\n        outputFileExtension: \".yaml\",\n        yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n    })\n    // Render the PR branch\n    const renderFromPRBranch: any = await render(new App(), app2)\n\n    app2.synth();\n\n    // Iterate over the resources from the main branch\n    for(const key of Object.keys(renderFromMainBranch)){\n\n        const kind = renderFromMainBranch[key].kind\n\n        //Check if the resource is present in the PR branch\n        if(renderFromPRBranch[key]){\n\n            //Check if the resources are different\n            const compareResult = compareCRs(\n\n                renderFromMainBranch[key],\n\n                renderFromPRBranch[key]\n\n            )\n\n            if(compareResult.changed){\n\n                const affectedRepo = getAffectedWetRepository(\n                    providers,\n                    wetRepositoriesConfig,\n                    kind\n                )\n\n                affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify\n\n                affectedResources[key] = {\n\n                    changes: compareResult.changes,\n\n                    reason: \"MODIFIED\"\n                }\n\n            }\n\n        } else {\n\n            /**\n             * If the resource is not present in the PR branch,\n             * it means that it has been deleted, so it is affected\n            **/\n            const affectedRepo = getAffectedWetRepository(\n                providers,\n                wetRepositoriesConfig,\n                kind\n            )\n\n            affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify\n\n            affectedResources[key] = {\n\n                changes: [],\n\n                reason: \"DELETED_FROM_PR\"\n            }\n\n        }\n    }\n\n    /**\n     * Iterate over the resources from the PR branch in\n     * case there are resources that are not present in the main branch,\n     * that means that they have been added to the PR branch.\n     */\n    for(const key of Object.keys(renderFromPRBranch)){\n\n        const kind = renderFromPRBranch[key].kind\n\n        //Check if the resource is not present in the main branch\n        if(!renderFromMainBranch[key]){\n\n            const affectedRepo = getAffectedWetRepository(\n                providers,\n                wetRepositoriesConfig,\n                kind\n            )\n\n            affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify\n\n            affectedResources[key] = {\n\n                changes: [],\n\n                reason: \"ADDED_TO_PR\"\n\n            }\n        }\n\n    }\n\n    return {\n\n        repos: affectedWetRepositories,\n\n        changedResources: affectedResources\n    }\n}\n\n/**\n * @description Check if two crs are different\n * @param crV1 First cr\n * @param crV2 Second cr\n * */\nfunction compareCRs(crV1: any, crV2: any) : { changed: boolean, changes: fastJsonPatch.Operation[] } {\n\n    if(crV1.kind !== crV2.kind){\n\n        throw new Error(`Kind mismatch on compare: ${crV1.kind} !== ${crV2.kind}`)\n\n    }\n\n    const compareResult = fastJsonPatch\n\n    .compare(crV1, crV2)\n\n    .filter(\n\n        /**\n         * This is a fake render, so we don't want to compare\n         * the tfStateKey, because in the claims repo we don't\n         * have the previous CRs.\n         */\n        (op: any) =>\n          op.path !== \"/spec/firestartr/tfStateKey\" &&\n          op.path !== \"/metadata/name\" &&\n          op.path !== \"/spec/writeConnectionSecretToRef/name\"\n\n    )\n\n    return { changed: compareResult.length !== 0, changes: compareResult }\n\n}\n\n\nexport function writeWetAffectedRepositoriesFile(repos: { [key: string]: string }, path: string) {\n\n    fs.writeFileSync(\n\n        path,\n\n        JSON.stringify(repos, null, 4)\n\n    )\n\n}\n\n\nexport async function runComparer(\n    claimPathFromMain: string,\n    claimPathFromPR: string,\n    claimsDefaultsPath: string,\n    wetRepositoriesConfigPath: string,\n    pathForAffectedReposFile: string\n) {\n\n\n    setPath(\"claimsDefaults\", claimsDefaultsPath);\n\n    const result = await getAffectedRepositories(\n\n        claimPathFromMain,\n\n        claimPathFromPR,\n\n        wetRepositoriesConfigPath\n    );\n\n    writeWetAffectedRepositoriesFile(result.repos, pathForAffectedReposFile);\n\n}\n"]}
232646
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/comparer/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { App, YamlOutputType } from \"cdk8s\";\nimport * as fs from \"fs\";\nimport * as yaml from \"js-yaml\";\nimport * as fastJsonPatch  from \"fast-json-patch\"\nimport { configurePathsForRendering, getAffectedWetRepository } from \"./utils\";\nimport { setPath } from \"../config\";\nimport { render } from \"../renderer/renderer\";\nimport { emptyRenderedClaims } from \"../refresolver\";\n\n/**\n * @description Type with the affected wet repositories\n */\ntype AffectedResource = {\n\n    // Changes in the resource with the format of fast-json-patch\n    changes: fastJsonPatch.Operation[],\n\n    // The reason why the resource is affected\n    reason: \"MODIFIED\" | \"DELETED_FROM_PR\"  | \"ADDED_TO_PR\"\n\n}\n\n/**\n * @description Object with the affected wet repositories\n */\ntype AffectedResources = {\n\n    [key: string]: AffectedResource\n\n}\n\nconst MAIN_BRANCH_OUTPUT_DIR: string = \"/tmp/resources_from_main_branch\";\nconst PR_BRANCH_OUTPUT_DIR: string = \"/tmp/resources_from_pr_branch\";\n\n\n\n/**\n * @description Get the affected wet repositories by a PR\n * @param claimPathFromMain Path to the claims from the main branch\n * @param claimPathFromPR Path to the claims from the PR branch\n * @param wetRepositoriesConfigPath Path to the wet repositories config\n * */\nexport async function getAffectedRepositories(\n\n    claimPathFromMain: string,\n\n    claimPathFromPR: string,\n\n    wetRepositoriesConfigPath: string\n\n) : Promise<{ repos: { [key: string]: string}, changedResources: AffectedResources }> {\n\n    /*\n     * We need this folder to exist, so we create it beforehand\n     *\n     */\n    if(!fs.existsSync(MAIN_BRANCH_OUTPUT_DIR)) {\n\n      fs.mkdirSync(MAIN_BRANCH_OUTPUT_DIR);\n\n    }\n\n    /**\n     * Object with the affected wet repositories\n     * This will be returned in order to trigger\n     * the pipelines of the affected wet repositories\n     */\n    const affectedWetRepositories:  { [key: string]: string} = {}\n\n    /**\n     * Object with the affected resources\n     * This will be returned for a summary of the changes,\n     * and the user will be able to see the changes in the\n     * pipeline logs.\n     */\n    const affectedResources: AffectedResources = {}\n\n    // Load the wet repositories config\n    const wetRepositoriesConfig: any = yaml.load(fs.readFileSync(wetRepositoriesConfigPath, \"utf-8\"));\n\n    // Get the providers from the wet repositories config\n    const providers = Object.keys(wetRepositoriesConfig.states)\n\n    // Set the claims path to the main branch\n    setPath(\"claims\", claimPathFromMain);\n\n    // Configure the renderer\n    configurePathsForRendering();\n\n    const mainBranchFirestartrApp = new App({\n        outdir: MAIN_BRANCH_OUTPUT_DIR,\n        outputFileExtension: \".yaml\",\n        yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n    })\n\n    const mainBranchCatalogApp = new App({\n        outdir: \"/tmp/.catalog\",\n        outputFileExtension: \".yaml\",\n        yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n    })\n\n    // Render the main branch\n    let renderFromMainBranch: any = await render(mainBranchCatalogApp, mainBranchFirestartrApp)\n\n    mainBranchFirestartrApp.synth();\n\n    emptyRenderedClaims();\n\n    // Change the claims path to the PR branch\n    setPath(\"claims\", claimPathFromPR)\n\n    const app2 = new App({\n        outdir: PR_BRANCH_OUTPUT_DIR,\n        outputFileExtension: \".yaml\",\n        yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n    })\n    // Render the PR branch\n    const renderFromPRBranch: any = await render(new App(), app2)\n\n    app2.synth();\n\n    // Iterate over the resources from the main branch\n    for(const key of Object.keys(renderFromMainBranch)){\n\n        const kind = renderFromMainBranch[key].kind\n\n        //Check if the resource is present in the PR branch\n        if(renderFromPRBranch[key]){\n\n            //Check if the resources are different\n            const compareResult = compareCRs(\n\n                renderFromMainBranch[key],\n\n                renderFromPRBranch[key]\n\n            )\n\n            if(compareResult.changed){\n\n                const affectedRepo = getAffectedWetRepository(\n                    providers,\n                    wetRepositoriesConfig,\n                    kind\n                )\n\n                console.dir(affectedRepo, { depth: null })\n\n                affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify\n\n                affectedResources[key] = {\n\n                    changes: compareResult.changes,\n\n                    reason: \"MODIFIED\"\n                }\n\n            }\n\n        } else {\n\n            /**\n             * If the resource is not present in the PR branch,\n             * it means that it has been deleted, so it is affected\n            **/\n            const affectedRepo = getAffectedWetRepository(\n                providers,\n                wetRepositoriesConfig,\n                kind\n            )\n\n            affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify\n\n            affectedResources[key] = {\n\n                changes: [],\n\n                reason: \"DELETED_FROM_PR\"\n            }\n\n        }\n    }\n\n    /**\n     * Iterate over the resources from the PR branch in\n     * case there are resources that are not present in the main branch,\n     * that means that they have been added to the PR branch.\n     */\n    for(const key of Object.keys(renderFromPRBranch)){\n\n        const kind = renderFromPRBranch[key].kind\n\n        //Check if the resource is not present in the main branch\n        if(!renderFromMainBranch[key]){\n\n            const affectedRepo = getAffectedWetRepository(\n                providers,\n                wetRepositoriesConfig,\n                kind\n            )\n\n            affectedWetRepositories[affectedRepo.repo] = affectedRepo.workflows.notify\n\n            affectedResources[key] = {\n\n                changes: [],\n\n                reason: \"ADDED_TO_PR\"\n\n            }\n        }\n\n    }\n\n    return {\n\n        repos: affectedWetRepositories,\n\n        changedResources: affectedResources\n    }\n}\n\n/**\n * @description Check if two crs are different\n * @param crV1 First cr\n * @param crV2 Second cr\n * */\nfunction compareCRs(crV1: any, crV2: any) : { changed: boolean, changes: fastJsonPatch.Operation[] } {\n\n    if(crV1.kind !== crV2.kind){\n\n        throw new Error(`Kind mismatch on compare: ${crV1.kind} !== ${crV2.kind}`)\n\n    }\n\n    const compareResult = fastJsonPatch\n\n    .compare(crV1, crV2)\n\n    .filter(\n\n        /**\n         * This is a fake render, so we don't want to compare\n         * the tfStateKey, because in the claims repo we don't\n         * have the previous CRs.\n         */\n        (op: any) =>\n          op.path !== \"/spec/firestartr/tfStateKey\" &&\n          op.path !== \"/metadata/name\" &&\n          op.path !== \"/spec/writeConnectionSecretToRef/name\"\n\n    )\n\n    return { changed: compareResult.length !== 0, changes: compareResult }\n\n}\n\n\nexport function writeWetAffectedRepositoriesFile(repos: { [key: string]: string }, path: string) {\n\n    fs.writeFileSync(\n\n        path,\n\n        JSON.stringify(repos, null, 4)\n\n    )\n\n}\n\n\nexport async function runComparer(\n    claimPathFromMain: string,\n    claimPathFromPR: string,\n    claimsDefaultsPath: string,\n    wetRepositoriesConfigPath: string,\n    pathForAffectedReposFile: string\n) {\n\n\n    setPath(\"claimsDefaults\", claimsDefaultsPath);\n\n    const result = await getAffectedRepositories(\n\n        claimPathFromMain,\n\n        claimPathFromPR,\n\n        wetRepositoriesConfigPath\n    );\n\n    writeWetAffectedRepositoriesFile(result.repos, pathForAffectedReposFile);\n\n}\n"]}
232646
232647
 
232647
232648
  /***/ }),
232648
232649
 
@@ -234593,6 +234594,64 @@ function getOrg() {
234593
234594
 
234594
234595
  /***/ }),
234595
234596
 
234597
+ /***/ 71756:
234598
+ /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
234599
+
234600
+ "use strict";
234601
+
234602
+ Object.defineProperty(exports, "__esModule", ({ value: true }));
234603
+ exports.RevisionNormalizer = void 0;
234604
+ const base_1 = __nccwpck_require__(1440);
234605
+ class RevisionNormalizer extends base_1.Normalizer {
234606
+ constructor() {
234607
+ super(...arguments);
234608
+ this.applicableProviders = ['all'];
234609
+ }
234610
+ async __validate(_schema) {
234611
+ return true;
234612
+ }
234613
+ async __patches(_claim, previousCR) {
234614
+ const revisionKey = 'firestartr.dev/revision';
234615
+ return [
234616
+ {
234617
+ validate(_cr) {
234618
+ return true;
234619
+ },
234620
+ apply(cr) {
234621
+ var _a;
234622
+ if (previousCR &&
234623
+ previousCR.metadata.annotations &&
234624
+ previousCR.metadata.annotations[revisionKey]) {
234625
+ cr.metadata.annotations = (_a = cr.metadata.annotations) !== null && _a !== void 0 ? _a : {};
234626
+ let currentRevision = parseInt(previousCR.metadata.annotations[revisionKey], 10);
234627
+ if (isNaN(currentRevision)) {
234628
+ throw new base_1.NormalizerError(`INVALID_REVISION: '${cr.metadata.annotations[revisionKey]}'`);
234629
+ }
234630
+ currentRevision += 1;
234631
+ cr.metadata.annotations[revisionKey] = currentRevision.toString();
234632
+ }
234633
+ else {
234634
+ cr.metadata.annotations[revisionKey] = '1';
234635
+ }
234636
+ return cr;
234637
+ },
234638
+ identify() {
234639
+ return 'normalizer/revision';
234640
+ },
234641
+ applicable() {
234642
+ return {
234643
+ applicableProviders: ['terraform'],
234644
+ };
234645
+ },
234646
+ },
234647
+ ];
234648
+ }
234649
+ }
234650
+ exports.RevisionNormalizer = RevisionNormalizer;
234651
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmV2aXNpb25Ob3JtYWxpemVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL25vcm1hbGl6ZXJzL1JldmlzaW9uTm9ybWFsaXplci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSxpQ0FBcUQ7QUFFckQsTUFBYSxrQkFBbUIsU0FBUSxpQkFBVTtJQUFsRDs7UUFDRSx3QkFBbUIsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBcUVoQyxDQUFDO0lBbkVDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBWTtRQUMzQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLE1BQVcsRUFBRSxVQUFlO1FBRTFDLE1BQU0sV0FBVyxHQUFHLHlCQUF5QixDQUFDO1FBRTlDLE9BQU87WUFDTDtnQkFDRSxRQUFRLENBQUMsR0FBUTtvQkFDZixPQUFPLElBQUksQ0FBQztnQkFDZCxDQUFDO2dCQUVELEtBQUssQ0FBQyxFQUFPOztvQkFFWCxJQUNHLFVBQVU7d0JBRVYsVUFBVSxDQUFDLFFBQVEsQ0FBQyxXQUFXO3dCQUUvQixVQUFVLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsRUFFM0M7d0JBRUYsRUFBRSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEdBQUcsTUFBQSxFQUFFLENBQUMsUUFBUSxDQUFDLFdBQVcsbUNBQUksRUFBRSxDQUFDO3dCQUV4RCxJQUFJLGVBQWUsR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7d0JBRWpGLElBQUksS0FBSyxDQUFDLGVBQWUsQ0FBQyxFQUFFOzRCQUUxQixNQUFNLElBQUksc0JBQWUsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO3lCQUUxRjt3QkFFRCxlQUFlLElBQUksQ0FBQyxDQUFDO3dCQUVyQixFQUFFLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsR0FBRyxlQUFlLENBQUMsUUFBUSxFQUFFLENBQUM7cUJBRW5FO3lCQUFNO3dCQUVMLEVBQUUsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxHQUFHLEdBQUcsQ0FBQztxQkFFNUM7b0JBRUQsT0FBTyxFQUFFLENBQUM7Z0JBRVosQ0FBQztnQkFFRCxRQUFRO29CQUVOLE9BQU8scUJBQXFCLENBQUM7Z0JBRS9CLENBQUM7Z0JBRUQsVUFBVTtvQkFFUixPQUFPO3dCQUVMLG1CQUFtQixFQUFFLENBQUMsV0FBVyxDQUFDO3FCQUVuQyxDQUFDO2dCQUVKLENBQUM7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUF0RUQsZ0RBc0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUN1c3RvbVJlc291cmNlUGF0Y2ggfSBmcm9tICcuLi9wYXRjaGVzJztcbmltcG9ydCB7IE5vcm1hbGl6ZXIsIE5vcm1hbGl6ZXJFcnJvciB9IGZyb20gJy4vYmFzZSc7XG5cbmV4cG9ydCBjbGFzcyBSZXZpc2lvbk5vcm1hbGl6ZXIgZXh0ZW5kcyBOb3JtYWxpemVyIHtcbiAgYXBwbGljYWJsZVByb3ZpZGVycyA9IFsnYWxsJ107XG5cbiAgYXN5bmMgX192YWxpZGF0ZShfc2NoZW1hOiBhbnkpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGFzeW5jIF9fcGF0Y2hlcyhfY2xhaW06IGFueSwgcHJldmlvdXNDUjogYW55KTogUHJvbWlzZTxJQ3VzdG9tUmVzb3VyY2VQYXRjaFtdPiB7XG4gICAgXG4gICAgY29uc3QgcmV2aXNpb25LZXkgPSAnZmlyZXN0YXJ0ci5kZXYvcmV2aXNpb24nO1xuXG4gICAgcmV0dXJuIFtcbiAgICAgIHtcbiAgICAgICAgdmFsaWRhdGUoX2NyOiBhbnkpIHtcbiAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSxcblxuICAgICAgICBhcHBseShjcjogYW55KSB7XG5cbiAgICAgICAgICBpZihcbiAgICAgICAgICAgICBwcmV2aW91c0NSICYmIFxuXG4gICAgICAgICAgICAgcHJldmlvdXNDUi5tZXRhZGF0YS5hbm5vdGF0aW9ucyAmJiBcbiAgICAgICAgICAgICBcbiAgICAgICAgICAgICBwcmV2aW91c0NSLm1ldGFkYXRhLmFubm90YXRpb25zW3JldmlzaW9uS2V5XVxuICAgICAgICAgICAgXG4gICAgICAgICAgICApIHtcblxuICAgICAgICAgICAgY3IubWV0YWRhdGEuYW5ub3RhdGlvbnMgPSBjci5tZXRhZGF0YS5hbm5vdGF0aW9ucyA/PyB7fTtcbiAgICAgICAgICAgIFxuICAgICAgICAgICAgbGV0IGN1cnJlbnRSZXZpc2lvbiA9IHBhcnNlSW50KHByZXZpb3VzQ1IubWV0YWRhdGEuYW5ub3RhdGlvbnNbcmV2aXNpb25LZXldLCAxMCk7XG5cbiAgICAgICAgICAgIGlmIChpc05hTihjdXJyZW50UmV2aXNpb24pKSB7XG4gICAgICAgICAgICBcbiAgICAgICAgICAgICAgdGhyb3cgbmV3IE5vcm1hbGl6ZXJFcnJvcihgSU5WQUxJRF9SRVZJU0lPTjogJyR7Y3IubWV0YWRhdGEuYW5ub3RhdGlvbnNbcmV2aXNpb25LZXldfSdgKTtcbiAgICAgICAgICAgIFxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBjdXJyZW50UmV2aXNpb24gKz0gMTtcbiAgICAgICAgICAgIFxuICAgICAgICAgICAgY3IubWV0YWRhdGEuYW5ub3RhdGlvbnNbcmV2aXNpb25LZXldID0gY3VycmVudFJldmlzaW9uLnRvU3RyaW5nKCk7XG5cbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgXG4gICAgICAgICAgICBjci5tZXRhZGF0YS5hbm5vdGF0aW9uc1tyZXZpc2lvbktleV0gPSAnMSc7XG4gICAgICAgICAgXG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcmV0dXJuIGNyO1xuICAgICAgICBcbiAgICAgICAgfSxcblxuICAgICAgICBpZGVudGlmeSgpIHtcbiAgICAgICAgXG4gICAgICAgICAgcmV0dXJuICdub3JtYWxpemVyL3JldmlzaW9uJztcbiAgICAgICAgXG4gICAgICAgIH0sXG5cbiAgICAgICAgYXBwbGljYWJsZSgpIHtcbiAgICAgICAgICBcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIFxuICAgICAgICAgICAgYXBwbGljYWJsZVByb3ZpZGVyczogWyd0ZXJyYWZvcm0nXSxcbiAgICAgICAgICBcbiAgICAgICAgICB9O1xuICAgICAgICBcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgXTtcbiAgfVxufVxuIl19
234652
+
234653
+ /***/ }),
234654
+
234596
234655
  /***/ 1440:
234597
234656
  /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
234598
234657
 
@@ -234631,11 +234690,12 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
234631
234690
  exports.NORMALIZERS = exports.normalizeModuleContent = void 0;
234632
234691
  const name_1 = __nccwpck_require__(32095);
234633
234692
  const refValues_1 = __nccwpck_require__(46654);
234693
+ const RevisionNormalizer_1 = __nccwpck_require__(71756);
234634
234694
  const tfworkspace_1 = __nccwpck_require__(99986);
234635
234695
  var tfworkspace_2 = __nccwpck_require__(99986);
234636
234696
  Object.defineProperty(exports, "normalizeModuleContent", ({ enumerable: true, get: function () { return tfworkspace_2.normalizeModuleContent; } }));
234637
- exports.NORMALIZERS = [name_1.NameNormalizer, refValues_1.RefValuesNormalizer, tfworkspace_1.TFWorkspaceNormalizer];
234638
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbm9ybWFsaXplcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQXdDO0FBQ3hDLDJDQUFrRDtBQUNsRCwrQ0FBc0Q7QUFDdEQsNkNBQXVEO0FBQTlDLHFIQUFBLHNCQUFzQixPQUFBO0FBRWxCLFFBQUEsV0FBVyxHQUFVLENBQUMscUJBQWMsRUFBRSwrQkFBbUIsRUFBRSxtQ0FBcUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmFtZU5vcm1hbGl6ZXIgfSBmcm9tIFwiLi9uYW1lXCI7XG5pbXBvcnQgeyBSZWZWYWx1ZXNOb3JtYWxpemVyIH0gZnJvbSBcIi4vcmVmVmFsdWVzXCI7XG5pbXBvcnQgeyBURldvcmtzcGFjZU5vcm1hbGl6ZXIgfSBmcm9tIFwiLi90ZndvcmtzcGFjZVwiO1xuZXhwb3J0IHsgbm9ybWFsaXplTW9kdWxlQ29udGVudCB9IGZyb20gXCIuL3Rmd29ya3NwYWNlXCI7XG5cbmV4cG9ydCBjb25zdCBOT1JNQUxJWkVSUzogYW55W10gPSBbTmFtZU5vcm1hbGl6ZXIsIFJlZlZhbHVlc05vcm1hbGl6ZXIsIFRGV29ya3NwYWNlTm9ybWFsaXplcl07XG4iXX0=
234697
+ exports.NORMALIZERS = [name_1.NameNormalizer, refValues_1.RefValuesNormalizer, tfworkspace_1.TFWorkspaceNormalizer, RevisionNormalizer_1.RevisionNormalizer];
234698
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbm9ybWFsaXplcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQXdDO0FBQ3hDLDJDQUFrRDtBQUNsRCw2REFBMEQ7QUFDMUQsK0NBQXNEO0FBQ3RELDZDQUF1RDtBQUE5QyxxSEFBQSxzQkFBc0IsT0FBQTtBQUVsQixRQUFBLFdBQVcsR0FBVSxDQUFDLHFCQUFjLEVBQUUsK0JBQW1CLEVBQUUsbUNBQXFCLEVBQUUsdUNBQWtCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5hbWVOb3JtYWxpemVyIH0gZnJvbSBcIi4vbmFtZVwiO1xuaW1wb3J0IHsgUmVmVmFsdWVzTm9ybWFsaXplciB9IGZyb20gXCIuL3JlZlZhbHVlc1wiO1xuaW1wb3J0IHsgUmV2aXNpb25Ob3JtYWxpemVyIH0gZnJvbSBcIi4vUmV2aXNpb25Ob3JtYWxpemVyXCI7XG5pbXBvcnQgeyBURldvcmtzcGFjZU5vcm1hbGl6ZXIgfSBmcm9tIFwiLi90ZndvcmtzcGFjZVwiO1xuZXhwb3J0IHsgbm9ybWFsaXplTW9kdWxlQ29udGVudCB9IGZyb20gXCIuL3Rmd29ya3NwYWNlXCI7XG5cbmV4cG9ydCBjb25zdCBOT1JNQUxJWkVSUzogYW55W10gPSBbTmFtZU5vcm1hbGl6ZXIsIFJlZlZhbHVlc05vcm1hbGl6ZXIsIFRGV29ya3NwYWNlTm9ybWFsaXplciwgUmV2aXNpb25Ob3JtYWxpemVyXTtcbiJdfQ==
234639
234699
 
234640
234700
  /***/ }),
234641
234701
 
@@ -239648,6 +239708,7 @@ const fs = __importStar(__nccwpck_require__(57147));
239648
239708
  const provisioner_1 = __importDefault(__nccwpck_require__(88456));
239649
239709
  const debug_1 = __importDefault(__nccwpck_require__(67984));
239650
239710
  const _1 = __nccwpck_require__(79622);
239711
+ const user_feedback_ops_1 = __nccwpck_require__(704);
239651
239712
  const log = (0, debug_1.default)('firestartr:operator:cdktf');
239652
239713
  function processOperation(item, op, handler) {
239653
239714
  try {
@@ -239755,6 +239816,7 @@ async function* markedToDeletion(item, op, handler) {
239755
239816
  delete: true
239756
239817
  });
239757
239818
  const output = destroyOutput.output;
239819
+ await (0, user_feedback_ops_1.tryPublishDestroy)(item, output);
239758
239820
  yield {
239759
239821
  item,
239760
239822
  reason: op,
@@ -239788,7 +239850,6 @@ async function* nothing(item, op, handler) {
239788
239850
  };
239789
239851
  }
239790
239852
  /**
239791
- *
239792
239853
  * @param {any} item - CR to be applied
239793
239854
  * @param op - Operation type
239794
239855
  * @param handler -
@@ -239833,6 +239894,7 @@ async function* doApply(item, op, handler) {
239833
239894
  mainCr: item,
239834
239895
  deps,
239835
239896
  }, opts);
239897
+ await (0, user_feedback_ops_1.tryPublishApply)(item, applyOutput?.data?.output, item.kind);
239836
239898
  const terraformOutputJson = await provisioner_1.default.runTerraform(item, [
239837
239899
  "output",
239838
239900
  "-json"
@@ -239867,6 +239929,10 @@ async function* doApply(item, op, handler) {
239867
239929
  handler.success();
239868
239930
  }
239869
239931
  catch (e) {
239932
+ if (typeof e === "object" && "output" in e) {
239933
+ e = e.output;
239934
+ }
239935
+ await (0, user_feedback_ops_1.tryPublishApply)(item, e, item.kind);
239870
239936
  log("Error applying item %s: %O", item.metadata.name, e);
239871
239937
  yield {
239872
239938
  item,
@@ -242996,7 +243062,7 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
242996
243062
  exports.errorPolicyCompatibility = exports.policyAllowsOp = void 0;
242997
243063
  const informer_1 = __nccwpck_require__(41151);
242998
243064
  const debug_1 = __importDefault(__nccwpck_require__(67984));
242999
- const user_feedback_ops_1 = __nccwpck_require__(36322);
243065
+ const user_feedback_ops_1 = __nccwpck_require__(704);
243000
243066
  const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
243001
243067
  const log = (0, debug_1.default)("firestartr:operator:tfworkspaces:policies");
243002
243068
  function policyAllowsOp(policy, op, item) {
@@ -243111,7 +243177,7 @@ const debug_1 = __importDefault(__nccwpck_require__(67984));
243111
243177
  const terraform_provisioner_1 = __nccwpck_require__(6777);
243112
243178
  const fs = __importStar(__nccwpck_require__(57147));
243113
243179
  const path = __importStar(__nccwpck_require__(71017));
243114
- const user_feedback_ops_1 = __nccwpck_require__(36322);
243180
+ const user_feedback_ops_1 = __nccwpck_require__(704);
243115
243181
  const policies_1 = __nccwpck_require__(31058);
243116
243182
  const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
243117
243183
  const log = (0, debug_1.default)('firestartr:operator:terraform');
@@ -243505,7 +243571,7 @@ async function* doApply(item, op, handler) {
243505
243571
  log('Item %s has the following dependencies: %O', item.metadata.name, deps);
243506
243572
  const context = buildProvisionerContext(item, deps);
243507
243573
  const applyOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "apply");
243508
- await (0, user_feedback_ops_1.tryPublishApply)(item, applyOutput);
243574
+ await (0, user_feedback_ops_1.tryPublishApply)(item, applyOutput, "TFWorkspace");
243509
243575
  const terraformOutputJson = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "output");
243510
243576
  if (!terraformOutputJson) {
243511
243577
  throw new Error(`Terraform output is empty for ${item.kind}/${item.metadata.name}`);
@@ -243538,7 +243604,7 @@ async function* doApply(item, op, handler) {
243538
243604
  }
243539
243605
  catch (e) {
243540
243606
  console.error(e);
243541
- await (0, user_feedback_ops_1.tryPublishApply)(item, e);
243607
+ await (0, user_feedback_ops_1.tryPublishApply)(item, e, "TFWorkspace");
243542
243608
  log("Error applying item %s: %O", item.metadata.name, e);
243543
243609
  yield {
243544
243610
  item,
@@ -243817,7 +243883,7 @@ function getErrorOutputMessage(cr, key, ref) {
243817
243883
 
243818
243884
  /***/ }),
243819
243885
 
243820
- /***/ 36322:
243886
+ /***/ 704:
243821
243887
  /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
243822
243888
 
243823
243889
  "use strict";
@@ -243830,13 +243896,13 @@ exports.publishError = exports.tryPublishError = exports.publishApply = exports.
243830
243896
  const github_1 = __importDefault(__nccwpck_require__(39759));
243831
243897
  const debug_1 = __importDefault(__nccwpck_require__(67984));
243832
243898
  const log = (0, debug_1.default)('firestartr:operator:terraform');
243833
- async function tryPublishApply(item, planOutput) {
243899
+ async function tryPublishApply(item, planOutput, kind) {
243834
243900
  try {
243835
243901
  if (!("firestartr.dev/last-state-pr" in item.metadata.annotations)) {
243836
243902
  log(`CR ${item.metadata.name} has no last state PR. Skipping terraform apply publish.`);
243837
243903
  return;
243838
243904
  }
243839
- await publishApply(item, planOutput);
243905
+ await publishApply(item, planOutput, kind);
243840
243906
  }
243841
243907
  catch (e) {
243842
243908
  log(`Error publishing apply: ${e}`);
@@ -243881,12 +243947,12 @@ async function tryPublishDestroy(item, destroyOutput) {
243881
243947
  }
243882
243948
  }
243883
243949
  exports.tryPublishDestroy = tryPublishDestroy;
243884
- async function publishApply(item, applyOutput) {
243950
+ async function publishApply(item, applyOutput, kind) {
243885
243951
  const { prNumber, repo, org } = extractPrInfo(item);
243886
243952
  const comment = `<h1>
243887
243953
  <img width="25" src="https://static-00.iconduck.com/assets.00/file-type-terraform-icon-1821x2048-mbxeegff.png"> Terraform apply
243888
243954
  </h1>
243889
- <p><b>TFWorkspace: </b>${item.metadata.name}</p>
243955
+ <p><b>${kind}: </b>${item.metadata.name}</p>
243890
243956
 
243891
243957
  <details id=github>
243892
243958
  <summary>APPLY LOGS</summary>
@@ -244042,11 +244108,10 @@ exports.runCDKTF = void 0;
244042
244108
  const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
244043
244109
  const child_process_1 = __nccwpck_require__(32081);
244044
244110
  const path = __importStar(__nccwpck_require__(71017));
244045
- async function runCDKTF(entity, action, deps) {
244111
+ async function runCDKTF(entityPath, action, depsPath) {
244046
244112
  // ! If we are into a compiled environmet, the folder must be set to current dir plus /provisioner because everything is on the same file at projects root
244047
244113
  // ? Is there a better way to check compiled env than look for packages directory in path ?
244048
244114
  let workDir = __dirname.split(path.sep).includes('packages') ? path.join(__dirname, '..') : path.join(__dirname, 'provisioner');
244049
- const isImport = entity?.metadata?.annotations[catalog_common_1.default.generic.getFirestartrAnnotation("import")];
244050
244115
  workDir = workDir.split("/dist")[0];
244051
244116
  return new Promise((ok, ko) => {
244052
244117
  const cdktfProcess = (0, child_process_1.spawn)("cdktf", [action, "--log-level", "DEBUG", "--auto-approve"], {
@@ -244054,26 +244119,13 @@ async function runCDKTF(entity, action, deps) {
244054
244119
  env: {
244055
244120
  ...process.env,
244056
244121
  PATH: process.env.PATH,
244057
- FIRESTARTR_CDKTF_ENTITY: JSON.stringify(entity),
244058
- FIRESTARTR_CDKTF_DEPS: JSON.stringify(deps),
244059
- CATALOG_MAIN_STATE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.catalogMainSate),
244060
- CATALOG_DESIRED_STATE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.catalogDesiredState),
244061
- CATALOG_DELETIONS_STATE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.catalogDeletionsState),
244062
- CDKTF_CONFIG_FILES: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfConfigFiles),
244063
- FIRESTARTR_CDKTF_IS_IMPORT: isImport ? "true" : "false",
244064
- EXCLUSIONS_YAML_PATH: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.exclusionsYamlPath),
244065
- FIRESTARTR_CDKTF_ENTITY_KIND: entity.kind,
244122
+ FIRESTARTR_CDKTF_ENTITY_PATH: entityPath,
244123
+ FIRESTARTR_CDKTF_DEPS_PATH: depsPath ? depsPath : "",
244066
244124
  GITHUB_APP_ID: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppId),
244067
244125
  GITHUB_APP_INSTALLATION_ID: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppInstallationId),
244068
244126
  GITHUB_APP_INSTALLATION_ID_PREFAPP: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppInstallationIdPrefapp),
244069
244127
  GITHUB_APP_PEM_FILE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppPemFile),
244070
- S3_BUCKET: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Bucket),
244071
- S3_REGION: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Region),
244072
- S3_LOCK: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Lock),
244073
- AWS_ACCESS_KEY_ID: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.awsAccesKey),
244074
- AWS_SECRET_ACCESS_KEY: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.awsAccesSecretKey),
244075
244128
  ORG: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.org),
244076
- TOKEN: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.token),
244077
244129
  KUBERNETES_SERVICE_HOST: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.kubernetesServiceHost),
244078
244130
  KUBERNETES_SERVICE_PORT: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.kubernetesServicePort),
244079
244131
  CDKTF_LOG_LEVEL: "OFF",
@@ -244084,7 +244136,10 @@ async function runCDKTF(entity, action, deps) {
244084
244136
  });
244085
244137
  let output = '';
244086
244138
  cdktfProcess.stdout.on("data", (log) => {
244087
- output += catalog_common_1.default.io.stripAnsi(log.toString());
244139
+ const logparsed = log.toString();
244140
+ if (!logparsed.includes("Synthesizing")) {
244141
+ output += catalog_common_1.default.io.stripAnsi(logparsed);
244142
+ }
244088
244143
  });
244089
244144
  cdktfProcess.stderr.on("data", (log) => {
244090
244145
  output += catalog_common_1.default.io.stripAnsi(log.toString());
@@ -244307,12 +244362,37 @@ function dumpArtifactYaml(component) {
244307
244362
 
244308
244363
  "use strict";
244309
244364
 
244365
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
244366
+ if (k2 === undefined) k2 = k;
244367
+ var desc = Object.getOwnPropertyDescriptor(m, k);
244368
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
244369
+ desc = { enumerable: true, get: function() { return m[k]; } };
244370
+ }
244371
+ Object.defineProperty(o, k2, desc);
244372
+ }) : (function(o, m, k, k2) {
244373
+ if (k2 === undefined) k2 = k;
244374
+ o[k2] = m[k];
244375
+ }));
244376
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
244377
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
244378
+ }) : function(o, v) {
244379
+ o["default"] = v;
244380
+ });
244381
+ var __importStar = (this && this.__importStar) || function (mod) {
244382
+ if (mod && mod.__esModule) return mod;
244383
+ var result = {};
244384
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
244385
+ __setModuleDefault(result, mod);
244386
+ return result;
244387
+ };
244310
244388
  var __importDefault = (this && this.__importDefault) || function (mod) {
244311
244389
  return (mod && mod.__esModule) ? mod : { "default": mod };
244312
244390
  };
244313
244391
  Object.defineProperty(exports, "__esModule", ({ value: true }));
244314
244392
  exports.untrackManagedFiles = void 0;
244393
+ const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
244315
244394
  const debug_1 = __importDefault(__nccwpck_require__(67984));
244395
+ const path = __importStar(__nccwpck_require__(71017));
244316
244396
  const cdktf_1 = __nccwpck_require__(48619);
244317
244397
  const terraform_1 = __nccwpck_require__(31926);
244318
244398
  const messageLog = (0, debug_1.default)('firestartr:provisioner:features:uninstaller');
@@ -244321,7 +244401,11 @@ async function untrackManagedFiles(feature, deps) {
244321
244401
  return;
244322
244402
  messageLog(`Removing managed files from the Terraform State`);
244323
244403
  messageLog(`Synthing the project...`);
244324
- await (0, cdktf_1.runCDKTF)(feature, "synth", deps);
244404
+ const randomFilenameFeature = `${catalog_common_1.default.generic.randomString(20)}.yaml`;
244405
+ const randomFilenameDeps = `${catalog_common_1.default.generic.randomString(20)}_deps.yaml`;
244406
+ catalog_common_1.default.io.writeYamlFile(randomFilenameFeature, feature, "/tmp");
244407
+ catalog_common_1.default.io.writeYamlFile(randomFilenameDeps, deps, "/tmp");
244408
+ await (0, cdktf_1.runCDKTF)(path.join("/tmp", randomFilenameFeature), "synth", path.join("/tmp", randomFilenameDeps));
244325
244409
  await (0, terraform_1.runTerraform)(feature, ['init']);
244326
244410
  for (const file of feature.spec.files.filter((file) => file.userManaged === true)) {
244327
244411
  messageLog(`Removing from the state file ${file.path}`);
@@ -244627,14 +244711,42 @@ exports["default"] = {
244627
244711
  /***/ }),
244628
244712
 
244629
244713
  /***/ 44317:
244630
- /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
244714
+ /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
244631
244715
 
244632
244716
  "use strict";
244633
244717
 
244718
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
244719
+ if (k2 === undefined) k2 = k;
244720
+ var desc = Object.getOwnPropertyDescriptor(m, k);
244721
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
244722
+ desc = { enumerable: true, get: function() { return m[k]; } };
244723
+ }
244724
+ Object.defineProperty(o, k2, desc);
244725
+ }) : (function(o, m, k, k2) {
244726
+ if (k2 === undefined) k2 = k;
244727
+ o[k2] = m[k];
244728
+ }));
244729
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
244730
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
244731
+ }) : function(o, v) {
244732
+ o["default"] = v;
244733
+ });
244734
+ var __importStar = (this && this.__importStar) || function (mod) {
244735
+ if (mod && mod.__esModule) return mod;
244736
+ var result = {};
244737
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
244738
+ __setModuleDefault(result, mod);
244739
+ return result;
244740
+ };
244741
+ var __importDefault = (this && this.__importDefault) || function (mod) {
244742
+ return (mod && mod.__esModule) ? mod : { "default": mod };
244743
+ };
244634
244744
  Object.defineProperty(exports, "__esModule", ({ value: true }));
244635
244745
  exports.Resource = void 0;
244636
244746
  const cdktf_1 = __nccwpck_require__(48619);
244637
244747
  const terraform_1 = __nccwpck_require__(31926);
244748
+ const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
244749
+ const path = __importStar(__nccwpck_require__(71017));
244638
244750
  class Resource {
244639
244751
  data = {};
244640
244752
  output = '';
@@ -244654,14 +244766,18 @@ class Resource {
244654
244766
  await this.runTerraform();
244655
244767
  }
244656
244768
  catch (err) {
244657
- throw `error: ${JSON.stringify(err, null, 4)}`;
244769
+ throw err;
244658
244770
  }
244659
244771
  }
244660
244772
  artifact() {
244661
244773
  return this.get('main_artifact');
244662
244774
  }
244663
244775
  async synth() {
244664
- await (0, cdktf_1.runCDKTF)(this.get('main_artifact'), "synth", this.get('deps'));
244776
+ const randomFilenameArtifact = `${catalog_common_1.default.generic.randomString(20)}.yaml`;
244777
+ const randomFilenameDeps = `${catalog_common_1.default.generic.randomString(20)}_deps.yaml`;
244778
+ catalog_common_1.default.io.writeYamlFile(randomFilenameArtifact, this.get('main_artifact'), "/tmp");
244779
+ catalog_common_1.default.io.writeYamlFile(randomFilenameDeps, this.get('deps'), "/tmp");
244780
+ await (0, cdktf_1.runCDKTF)(path.join("/tmp", randomFilenameArtifact), "synth", path.join("/tmp", randomFilenameDeps));
244665
244781
  }
244666
244782
  log(msg) {
244667
244783
  this.logFn(msg);
@@ -244794,21 +244910,9 @@ async function runTerraform(entity, command) {
244794
244910
  cwd: workDir,
244795
244911
  env: {
244796
244912
  PATH: process.env.PATH,
244797
- FIRESTARTR_CDKTF_ENTITY_NAME: entity.metadata.name,
244798
- CATALOG_MAIN_STATE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.catalogMainSate),
244799
- CATALOG_DESIRED_STATE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.catalogDesiredState),
244800
- CATALOG_DELETIONS_STATE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.catalogDeletionsState),
244801
- CDKTF_CONFIG_FILES: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfConfigFiles),
244802
- EXCLUSIONS_YAML_PATH: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.exclusionsYamlPath),
244803
- FIRESTARTR_CDKTF_ENTITY_KIND: entity.kind,
244804
244913
  GITHUB_APP_ID: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppId),
244805
244914
  GITHUB_APP_INSTALLATION_ID: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppInstallationId),
244806
244915
  GITHUB_APP_PEM_FILE: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.githubAppPemFile),
244807
- S3_BUCKET: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Bucket),
244808
- S3_REGION: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Region),
244809
- S3_LOCK: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Lock),
244810
- AWS_ACCESS_KEY_ID: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.awsAccesKey),
244811
- AWS_SECRET_ACCESS_KEY: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.awsAccesSecretKey),
244812
244916
  ORG: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.org),
244813
244917
  TOKEN: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.token),
244814
244918
  KUBERNETES_SERVICE_HOST: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.kubernetesServiceHost),
@@ -1,4 +1,27 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
2
25
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
27
  };
@@ -8,11 +31,14 @@ const catalog_common_1 = __importDefault(require("catalog_common"));
8
31
  const cdktf_1 = require("cdktf");
9
32
  const loader_1 = require("./src/loader");
10
33
  const debug_1 = __importDefault(require("debug"));
34
+ const fs = __importStar(require("fs"));
11
35
  const messageLog = (0, debug_1.default)('firestartr:provisioner:main');
12
36
  async function deploy(app) {
13
- const entity = JSON.parse(catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfEntity));
14
- const deps = JSON.parse(catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfDeps));
15
- const isImport = catalog_common_1.default.environment.getFromEnvironmentAsBoolean(catalog_common_1.default.types.envVars.cdktfIsImport);
37
+ const entity = catalog_common_1.default.io.fromYaml(fs.readFileSync(catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfEntityPath), 'utf8'));
38
+ const deps = catalog_common_1.default.io.fromYaml(fs.readFileSync(catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfDepsPath), 'utf8'));
39
+ const isImport = entity?.metadata?.annotations[catalog_common_1.default.generic.getFirestartrAnnotation("import")] ? true : false;
40
+ catalog_common_1.default.io.removeFile(catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfEntityPath));
41
+ catalog_common_1.default.io.removeFile(catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.cdktfDepsPath));
16
42
  messageLog("Entity to provision: %O", entity);
17
43
  const orgConfig = {
18
44
  bucket: catalog_common_1.default.environment.getFromEnvironment(catalog_common_1.default.types.envVars.s3Bucket),