@firestartr/cli 0.1.10 â 0.1.11
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 +534 -191
- package/build/provisioner/dist-cdktf/index.js +34 -2
- package/build/provisioner/dist-cdktf/index.js.map +1 -1
- package/build/provisioner/dist-cdktf/src/handlers/index.d.ts +1 -1
- package/build/provisioner/dist-cdktf/tsconfig.cdktf.tsbuildinfo +1 -1
- package/package.json +1 -1
package/build/index.js
CHANGED
|
@@ -232157,6 +232157,10 @@ exports["default"] = {
|
|
|
232157
232157
|
{
|
|
232158
232158
|
"type": "object",
|
|
232159
232159
|
"properties": {
|
|
232160
|
+
"policy": {
|
|
232161
|
+
"type": "string",
|
|
232162
|
+
"enum": ["apply", "create-only", "create-update-only", "full-control", "observe", "observe-only"]
|
|
232163
|
+
},
|
|
232160
232164
|
"name": {
|
|
232161
232165
|
"type": "string",
|
|
232162
232166
|
},
|
|
@@ -232211,7 +232215,7 @@ exports["default"] = {
|
|
|
232211
232215
|
}
|
|
232212
232216
|
}
|
|
232213
232217
|
};
|
|
232214
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
232218
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLnNjaGVtYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jbGFpbXMvdGZ3b3Jrc3BhY2VzL3RlcnJhZm9ybS5zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxrQkFBZTtJQUVYLFNBQVMsRUFBRSx5Q0FBeUM7SUFFcEQsS0FBSyxFQUFFLG1CQUFtQjtJQUUxQixhQUFhLEVBQUU7UUFFYixtQkFBbUIsRUFBRTtZQUVuQixLQUFLLEVBQUUsOENBQThDO1lBRXJELE1BQU0sRUFBRSxRQUFRO1lBRWhCLGFBQWEsRUFBRSx1QkFBdUI7WUFFdEMsT0FBTyxFQUFFO2dCQUVQLEVBQUMsTUFBTSxFQUFFLCtDQUErQyxFQUFDO2dCQUV6RDtvQkFDRSxNQUFNLEVBQUUsUUFBUTtvQkFFaEIsWUFBWSxFQUFFO3dCQUVaLFFBQVEsRUFBRTs0QkFFUixNQUFNLEVBQUUsUUFBUTs0QkFFaEIsTUFBTSxFQUFFLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxvQkFBb0IsRUFBRSxjQUFjLEVBQUUsU0FBUyxFQUFFLGNBQWMsQ0FBQzt5QkFFbEc7d0JBRUQsTUFBTSxFQUFFOzRCQUVOLE1BQU0sRUFBRSxRQUFRO3lCQUNqQjt3QkFFRCxRQUFRLEVBQUU7NEJBRVIsTUFBTSxFQUFFLFFBQVE7NEJBRWhCLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFFBQVEsQ0FBQzt5QkFFakQ7d0JBRUQsY0FBYyxFQUFFOzRCQUVkLE1BQU0sRUFBRSxRQUFROzRCQUVoQixhQUFhLEVBQUUsZ0RBQWdEO3lCQUVoRTt3QkFFRCxRQUFRLEVBQUM7NEJBRVAsTUFBTSxFQUFFLFFBQVE7NEJBRWhCLFlBQVksRUFBRSxFQUFFOzRCQUVoQixzQkFBc0IsRUFBRSxJQUFJO3lCQUU3Qjt3QkFFRCxRQUFRLEVBQUU7NEJBRVIsTUFBTSxFQUFFLFFBQVE7eUJBRWpCO3dCQUVELFNBQVMsRUFBRTs0QkFFVCxNQUFNLEVBQUUsUUFBUTs0QkFFaEIsWUFBWSxFQUFFO2dDQUVaLFdBQVcsRUFBRTtvQ0FFWCxNQUFNLEVBQUUsT0FBTztvQ0FFZixPQUFPLEVBQUU7d0NBRVAsTUFBTSxFQUFFLFFBQVE7d0NBRWhCLFlBQVksRUFBRTs0Q0FFWixNQUFNLEVBQUU7Z0RBRU4sTUFBTSxFQUFFLFFBQVE7NkNBQ2pCO3lDQUVGO3dDQUVELHNCQUFzQixFQUFFLEtBQUs7cUNBRTlCO2lDQUVGO2dDQUVELFNBQVMsRUFBRTtvQ0FFVCxNQUFNLEVBQUUsUUFBUTtvQ0FFaEIsWUFBWSxFQUFFO3dDQUVaLE1BQU0sRUFBRTs0Q0FFTixNQUFNLEVBQUUsUUFBUTt5Q0FDakI7cUNBRUY7b0NBRUQsc0JBQXNCLEVBQUUsS0FBSztpQ0FDOUI7NkJBRUY7NEJBRUQsVUFBVSxFQUFFLENBQUMsV0FBVyxDQUFDOzRCQUV6QixzQkFBc0IsRUFBRSxLQUFLO3lCQUU5QjtxQkFFRjtvQkFFRCxVQUFVLEVBQUUsQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLENBQUM7aUJBRXBEO2FBRUY7U0FFRjtLQUNGO0NBQ0osQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IHtcblxuICAgIFwiJHNjaGVtYVwiOiBcImh0dHA6Ly9qc29uLXNjaGVtYS5vcmcvZHJhZnQtMDcvc2NoZW1hI1wiLFxuXG4gICAgXCIkaWRcIjogXCJUZXJyYWZvcm1Qcm92aWRlclwiLFxuXG4gICAgXCJkZWZpbml0aW9uc1wiOiB7XG5cbiAgICAgIFwiVGVycmFmb3JtUHJvdmlkZXJcIjoge1xuXG4gICAgICAgIFwiJGlkXCI6IFwiZmlyZXN0YXJ0ci5kZXY6Ly90ZXJyYWZvcm0vVGVycmFmb3JtUHJvdmlkZXJcIixcblxuICAgICAgICBcInR5cGVcIjogXCJvYmplY3RcIixcblxuICAgICAgICBcImRlc2NyaXB0aW9uXCI6IFwiQSB0ZXJyYWZvcm0gd29ya3NwYWNlXCIsXG5cbiAgICAgICAgXCJhbGxPZlwiOiBbXG5cbiAgICAgICAgICB7XCIkcmVmXCI6IFwiZmlyZXN0YXJ0ci5kZXY6Ly9jb21tb24vQ2xhaW1Qcm92aWRlckVudmVsb3BlXCJ9LFxuXG4gICAgICAgICAge1xuICAgICAgICAgICAgXCJ0eXBlXCI6IFwib2JqZWN0XCIsXG5cbiAgICAgICAgICAgIFwicHJvcGVydGllc1wiOiB7XG5cbiAgICAgICAgICAgICAgXCJwb2xpY3lcIjoge1xuXG4gICAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCIsXG5cbiAgICAgICAgICAgICAgICBcImVudW1cIjogW1wiYXBwbHlcIiwgXCJjcmVhdGUtb25seVwiLCBcImNyZWF0ZS11cGRhdGUtb25seVwiLCBcImZ1bGwtY29udHJvbFwiLCBcIm9ic2VydmVcIiwgXCJvYnNlcnZlLW9ubHlcIl1cblxuICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgIFwibmFtZVwiOiB7XG4gICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgIFwic291cmNlXCI6IHtcblxuICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuXG4gICAgICAgICAgICAgICAgXCJlbnVtXCI6IFtcInJlbW90ZVwiLCBcImlubGluZVwiLCBcIlJlbW90ZVwiLCBcIklubGluZVwiXVxuXG4gICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgXCJ2YWx1ZXNTY2hlbWFcIjoge1xuICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcblxuICAgICAgICAgICAgICAgIFwiZGVzY3JpcHRpb25cIjogXCJhIGxvY2F0b3IgZm9yIGEganNvbiBzY2hlbWEgdG8gdmFsaWRhdGUgdmFsdWVzXCJcbiAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgXCJ2YWx1ZXNcIjp7XG5cbiAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJvYmplY3RcIixcblxuICAgICAgICAgICAgICAgIFwicHJvcGVydGllc1wiOiB7fSxcblxuICAgICAgICAgICAgICAgIFwiYWRkaXRpb25hbFByb3BlcnRpZXNcIjogdHJ1ZVxuXG4gICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgXCJtb2R1bGVcIjoge1xuICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIlxuICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgfSxcblxuICAgICAgICAgICAgICBcImNvbnRleHRcIjoge1xuXG4gICAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwib2JqZWN0XCIsXG5cbiAgICAgICAgICAgICAgICBcInByb3BlcnRpZXNcIjoge1xuICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgXCJwcm92aWRlcnNcIjoge1xuICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcImFycmF5XCIsXG5cbiAgICAgICAgICAgICAgICAgICAgXCJpdGVtc1wiOiB7XG4gICAgICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuXG4gICAgICAgICAgICAgICAgICAgICAgXCJwcm9wZXJ0aWVzXCI6IHtcbiAgICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgICAgIFwibmFtZVwiOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgICAgICAgICAgXCJhZGRpdGlvbmFsUHJvcGVydGllc1wiOiBmYWxzZVxuICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgICAgICBcImJhY2tlbmRcIjoge1xuICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuXG4gICAgICAgICAgICAgICAgICAgIFwicHJvcGVydGllc1wiOiB7XG4gICAgICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgICAgIFwibmFtZVwiOiB7XG4gICAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIlxuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgICAgICAgXCJhZGRpdGlvbmFsUHJvcGVydGllc1wiOiBmYWxzZVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgICBcInJlcXVpcmVkXCI6IFtcInByb3ZpZGVyc1wiXSxcblxuICAgICAgICAgICAgICAgIFwiYWRkaXRpb25hbFByb3BlcnRpZXNcIjogZmFsc2VcblxuICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgIFwicmVxdWlyZWRcIjogW1widmFsdWVzXCIsIFwiY29udGV4dFwiLCBcInNvdXJjZVwiLCBcIm5hbWVcIl1cblxuICAgICAgICAgIH1cblxuICAgICAgICBdXG5cbiAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
232215
232219
|
|
|
232216
232220
|
/***/ }),
|
|
232217
232221
|
|
|
@@ -235333,6 +235337,7 @@ const crawler_1 = __nccwpck_require__(26675);
|
|
|
235333
235337
|
const fs_1 = __importDefault(__nccwpck_require__(57147));
|
|
235334
235338
|
const path_1 = __importDefault(__nccwpck_require__(71017));
|
|
235335
235339
|
const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
|
|
235340
|
+
const github_1 = __importDefault(__nccwpck_require__(39759));
|
|
235336
235341
|
const CLAIM_REF_ANNOTATION = "firestartr.dev/claim-ref";
|
|
235337
235342
|
const log = (0, debug_1.default)("firestartr:renderer");
|
|
235338
235343
|
/*
|
|
@@ -235390,7 +235395,21 @@ exports.render = render;
|
|
|
235390
235395
|
* Function called when rendering Terraform workspaces Plans
|
|
235391
235396
|
* based on the previous renderer Terraform workspaces
|
|
235392
235397
|
*/
|
|
235393
|
-
async function renderWorkspacePlans(source, destiny, prLink, sha) {
|
|
235398
|
+
async function renderWorkspacePlans(source, destiny, prLink, sha, ghCli = github_1.default) {
|
|
235399
|
+
const [orgRepo, prNumber] = prLink.split("#");
|
|
235400
|
+
const [org, repo] = orgRepo.split("/");
|
|
235401
|
+
const { data: files } = await ghCli.pulls.getPrFiles(parseInt(prNumber), repo, org);
|
|
235402
|
+
if (files && files.length > 0 && files[0].status == "removed") {
|
|
235403
|
+
const content = await ghCli.repo.getContent(files[0].filename, repo, org);
|
|
235404
|
+
const workspace = catalog_common_1.default.io.fromYaml(content);
|
|
235405
|
+
workspace.kind = "FirestartrTerraformWorkspacePlan";
|
|
235406
|
+
workspace.metadata.annotations = Object.assign(Object.assign({}, workspace.metadata.annotations), { [catalog_common_1.default.generic.getFirestartrAnnotation("pull-request-plan")]: prLink, [catalog_common_1.default.generic.getFirestartrAnnotation("plan-sha")]: sha });
|
|
235407
|
+
workspace.metadata.annotations[catalog_common_1.default.generic.getFirestartrAnnotation("policy")] = "destroy";
|
|
235408
|
+
const workspacePlan = catalog_common_1.default.io.toYaml(Object.assign({}, workspace), { quotingType: '"', lineWidth: -1 });
|
|
235409
|
+
const fileName = path_1.default.join(destiny, path_1.default.basename(files[0].filename));
|
|
235410
|
+
fs_1.default.writeFileSync(fileName, workspacePlan);
|
|
235411
|
+
return;
|
|
235412
|
+
}
|
|
235394
235413
|
// Iterate over the source folder and get the list of Terraform workspaces
|
|
235395
235414
|
await (0, crawler_1.crawl)(source, () => true, (entry, data) => {
|
|
235396
235415
|
const fileName = path_1.default.join(destiny, path_1.default.basename(entry));
|
|
@@ -235582,7 +235601,7 @@ function getPreviousCRfromClaim(claim, previousCRs) {
|
|
|
235582
235601
|
function isExcludedFromPreviousCR(crKind) {
|
|
235583
235602
|
return ["FirestartrGithubRepositoryFeature"].includes(crKind);
|
|
235584
235603
|
}
|
|
235585
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../src/renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { IRenameResult, loadAll } from \"./loader\";\nimport * as charts from \"./charts\"\nimport Debug from \"debug\";\nimport { BaseChart } from \"./charts/base\";\nimport { ApiObject, App, YamlOutputType } from \"cdk8s\";\nimport { GlobalSection } from \"./globals/base\";\nimport { generateFeaturesPatches } from \"./charts/github/featureRenderer\";\nimport { OverriderPatches } from \"./overriders/base\";\nimport { ICustomResourcePatch } from \"./patches\";\nimport { isCatalogEntity, validateReferentialIntegrity, validateTfStateKeyUniqueness } from \"./validations/references\";\nimport {  setRenderedClaim } from \"./refresolver\";\nimport { AllowedProviders, getConfiguredProvider } from \"./config\";\nimport { Normalizer } from \"./normalizers/base\";\nimport { sortRenderClaimsByKind } from \"./refsSorter/refsSorter\";\nimport { crawl } from \"./crawler\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport common from \"catalog_common\";\nconst CLAIM_REF_ANNOTATION = \"firestartr.dev/claim-ref\"\n\n\nconst log = Debug(\"firestartr:renderer\")\n\nexport type RenderClaimData = {\n\n  claim: any\n\n  claimPath?: string\n\n  initializers: any []\n\n  overrides: OverriderPatches[]\n\n  globals: GlobalSection[],\n\n  normalizers: Normalizer[]\n\n}\n\ntype ClaimKind = string;\ntype ClaimName = string;\nexport type RenderClaimKey = `${ClaimKind}-${ClaimName}`\n\ntype CRKind = string;\ntype CRName = string;\ntype RenderCRKey = `${CRKind}-${CRName}`\n\nexport type RenderedCrMap = {\n\n  [key: RenderCRKey]: ApiObject\n}\n\nexport type RenderClaims = {\n\n  [key: RenderClaimKey]: RenderClaimData\n\n}\n\n/*\n * Function called when rendering from the importer class.\n *\n * Input:\n * - renderClaims: a RenderClaims object, which contains the list of claims\n *   we want to render\n *\n * Return:\n * - The result of rendering the renderClaims object, plus the\n *   rendered firestartr-all group\n *\n */\nexport async function renderFromImports(\n\n  renderClaims: RenderClaims,\n\n  crs: any = {},\n\n  catalogOutputDir: string = \"/tmp/.catalog\",\n\n  crOutputDir: string = \"/tmp/.resources\",\n\n) {\n\n  const catalogScope = new App({\n\n    outdir: catalogOutputDir,\n\n    outputFileExtension: \".yaml\",\n\n    yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n\n  })\n\n  const firestartrScope = new App({\n\n    outdir: crOutputDir,\n\n    outputFileExtension: \".yaml\",\n\n    yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n\n  })\n\n  const result: any = await fRenderClaims(\n\n    catalogScope,\n\n    firestartrScope,\n\n    {\n      renderClaims,\n\n      crs,\n\n      renames: []\n    },\n  )\n\n  firestartrScope.synth()\n\n  return result\n\n}\n\n\n/*\n * Function called when rendering but not importing\n *\n * Input:\n * - scope: an object, used to represent CDKTF's execution scope\n *\n * Return:\n * - The result of rendering the renderClaims object, plus the\n *   rendered firestartr-all group\n *\n */\nexport async function render(\n\n  catalogScope: Construct,\n\n  firestartrScope: Construct,\n\n  ): Promise<RenderedCrMap> {\n\n  const data: {\n\n    renderClaims: RenderClaims,\n\n    crs: any,\n\n    renames?: IRenameResult[]\n\n  } = await loadAll()\n\n  const result: any = await fRenderClaims(catalogScope, firestartrScope, data)\n\n  validateReferentialIntegrity(result)\n\n  validateTfStateKeyUniqueness(result)\n\n  return result\n\n}\n\n/*\n * Function called when rendering Terraform workspaces Plans\n * based on the previous renderer Terraform workspaces\n*/\nexport async function renderWorkspacePlans(source: string, destiny: string, prLink: string, sha: string) {\n\n  // Iterate over the source folder and get the list of Terraform workspaces\n\n  await crawl(source, () => true, (entry: string, data: any) => {\n\n    const fileName = path.join(destiny, path.basename(entry))\n\n    const workspace: any = common.io.fromYaml(data)\n\n    workspace.kind = \"FirestartrTerraformWorkspacePlan\"\n    workspace.metadata.annotations = {\n      ...workspace.metadata.annotations,\n      [common.generic.getFirestartrAnnotation(\"pull-request-plan\")]: prLink,\n      [common.generic.getFirestartrAnnotation(\"plan-sha\")]: sha\n    }\n\n    const workspacePlan = common.io.toYaml({\n      ...workspace\n    }, { quotingType: '\"', lineWidth: -1 })\n\n    fs.writeFileSync(fileName, workspacePlan)\n\n  })\n\n}\n\nexport async function addLastStateAndLastClaimAnnotations(\n  filePath: string, lastStatePRLink: string, lastClaimPRLink: string\n) {\n\n  // Iterate over the source folder and get the list of Terraform workspaces\n\n  const workspace: any = common.io.fromYaml(fs.readFileSync(filePath, \"utf-8\"));\n\n  const stateLinkAsArray: string[] = lastStatePRLink.split(\"/\");\n  const stateAnnotationValue: string = `${stateLinkAsArray[3]}/${stateLinkAsArray[4]}#${stateLinkAsArray[6]}`\n\n  const claimLinkAsArray: string[] = lastClaimPRLink.split(\"/\");\n  const claimAnnotationValue: string = `${claimLinkAsArray[3]}/${claimLinkAsArray[4]}#${claimLinkAsArray[6]}`\n\n  workspace.metadata.annotations = {\n    ...workspace.metadata.annotations,\n    [common.generic.getFirestartrAnnotation(\"last-state-pr\")]: stateAnnotationValue,\n    [common.generic.getFirestartrAnnotation(\"last-claim-pr\")]: claimAnnotationValue\n  }\n\n  fs.writeFileSync(filePath, common.io.toYaml(\n    { ...workspace }, { quotingType: '\"', lineWidth: -1 }\n  ))\n\n}\n\nasync function fRenderClaims(\n\n  catalogScope: Construct,\n\n  firestartrScope: Construct,\n\n  data: {\n\n    renderClaims: RenderClaims,\n\n    crs: any,\n\n    renames?: IRenameResult[]\n\n  },\n\n): Promise<RenderedCrMap> {\n\n  const result: RenderedCrMap = {}\n\n  const { renderClaims, crs } = data\n\n  const sortedKinds = sortKinds([\"UserClaim\", \"GroupClaim\", \"ComponentClaim\", \"DomainClaim\", \"SystemClaim\", \"TFWorkspaceClaim\", \"ArgoDeployClaim\"], renderClaims)\n\n  for (const renderClaims of sortedKinds) {\n\n    for (const claimKey of Object.keys(renderClaims)) {\n\n      const claim = renderClaims[claimKey as RenderClaimKey].claim\n\n      const configuredProvider = getConfiguredProvider().toString()\n\n      let providers = Object.keys(claim.providers)\n\n      if(configuredProvider != AllowedProviders.all.toString()){\n\n        providers = providers.filter(\n\n          (provider: string) => provider === configuredProvider\n\n        )\n\n      }\n\n\n      const previousCR = getPreviousCRfromClaim(claim, crs)\n\n      const patches = await extractPatches(renderClaims[claimKey as RenderClaimKey], previousCR)\n\n      if (!previousCR) {\n\n        log(`No CR found for claim ${claimKey}, it will be rendered from scratch`)\n\n      }\n\n      const {firestartrEntity, extraCharts, catalogEntity}  = await renderClaim(\n\n        catalogScope,\n\n        firestartrScope,\n\n        claim,\n\n        patches,\n\n        previousCR,\n\n      )\n\n      if(catalogEntity) {\n\n        result[`${catalogEntity.kind}-${catalogEntity.metadata.name}`] = catalogEntity.toJson()\n      \n      }\n\n      /**\n\n      * If there is no provider don't store the CR in the map\n\n      */\n\n      if (!firestartrEntity) continue;\n\n      const firestartrEntityJson = firestartrEntity.toJson()\n\n      setRenderedClaim(claim, firestartrEntityJson)\n\n      for(const extraChart of extraCharts){\n\n        const {claim, chart} = extraChart\n\n        setRenderedClaim(claim, chart.toJson())\n\n        result[`${chart.kind}-${chart.metadata.name}`] = chart.toJson()\n\n      }\n\n      if(!firestartrEntityJson.metadata.annotations || !firestartrEntityJson.metadata.name) throw firestartrEntityJson\n\n      result[`${firestartrEntity.kind}-${firestartrEntityJson.metadata.name}`] = firestartrEntityJson\n\n    }\n\n  }\n\n  return result\n\n}\n\nasync function extractPatches(\n\n  claimToRenderData: RenderClaimData, previousCR: any\n\n): Promise<ICustomResourcePatch[]> {\n\n  let totalPatches: ICustomResourcePatch[] = []\n\n\n  for (const normalizer of claimToRenderData.normalizers) {\n\n    const patches = await normalizer.patches(claimToRenderData[\"claim\"], previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n  for (const initializer of claimToRenderData.initializers) {\n\n    const patches = await initializer.patches(claimToRenderData[\"claim\"], previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n  for (const overrider of claimToRenderData.overrides) {\n\n    const patches = await overrider.patches(claimToRenderData[\"claim\"], previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n\n  if (claimToRenderData.claim.kind === \"ComponentClaim\") {\n\n    totalPatches = totalPatches.concat((await generateFeaturesPatches(claimToRenderData.claim))).flat()\n\n  }\n\n\n  for (const global of claimToRenderData.globals) {\n\n    const patches = await global.patches(claimToRenderData.claim, previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n  return totalPatches\n\n}\n\nexport interface IRenderClaimResult {\n  catalogEntity?: ApiObject;\n  firestartrEntity?: ApiObject;\n  extraCharts: { claim: {kind: string, name: string}, chart: ApiObject}[];\n}\n\nasync function renderClaim(\n\n  catalogScope: Construct,\n\n  firestartrScope: Construct,\n\n  claim: any,\n\n  patches: ICustomResourcePatch[],\n\n  previousCR: any | null = null\n\n  ): Promise<IRenderClaimResult> {\n\n  let catalogEntity: BaseChart | undefined = undefined;\n  let firestartrEntity: BaseChart | undefined = undefined;\n\n  const chartId = `${claim.kind}-${claim.name}`.toLowerCase();\n\n  let firestartrId: string | null = null;\n\n  if (previousCR) {\n\n    firestartrId = previousCR?.spec?.firestartr?.tfStateKey || null;\n\n  }\n\n  const renderPatches = patches.filter((patch: any) => !patch.isPostPatch)\n  const postPatches = patches.filter((patch:any) => patch.isPostPatch)\n\n  const provider = getConfiguredProvider()\n\n  switch (claim.kind) {\n\n    case \"DomainClaim\":\n\n      catalogEntity = new charts.default.CatalogDomainChart(\n        catalogScope, \n        `catalog-${chartId}`, \n        firestartrId, \n        claim, \n        renderPatches\n      );\n\n      break;\n\n    case \"SystemClaim\":\n\n      catalogEntity = new charts.default.CatalogSystemChart(\n        catalogScope, \n        `catalog-${chartId}`, \n        firestartrId, \n        claim, \n        renderPatches\n      );\n\n      break;\n\n    case \"GroupClaim\":\n\n      catalogEntity = new charts.default.CatalogGroupChart(catalogScope, `catalog-${chartId}`, firestartrId, claim, renderPatches);\n\n      if (claim.providers.github && (provider === AllowedProviders.github || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.GithubGroupChart(\n          firestartrScope,\n          `github-${chartId}`,\n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n\n      break;\n\n    case \"UserClaim\":\n\n      catalogEntity = new charts.default.CatalogUserChart(catalogScope, chartId, firestartrId, claim, renderPatches);\n\n      if (claim.providers.github && (provider === AllowedProviders.github || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.GithubMembershipChart(\n          firestartrScope,\n          `github-${chartId}`,\n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n\n      break;\n\n    case \"ComponentClaim\":\n\n      if (claim.providers.github && (provider === AllowedProviders.github || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.GithubRepositoryChart(\n          firestartrScope,\n          `github-${chartId}`,\n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n      catalogEntity = new charts.default.CatalogComponentChart(\n        catalogScope, chartId, firestartrId, claim, renderPatches\n      );\n\n      break;\n\n    case \"TFWorkspaceClaim\":\n\n      if (claim.providers.terraform && (provider === AllowedProviders.terraform || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.TFWorkspaceChart(\n          firestartrScope, \n          `terraform-${chartId}`, \n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n      catalogEntity = new charts.default.CatalogTFWorkspaceChart(\n        catalogScope, chartId, firestartrId, claim, renderPatches\n      );\n\n      break;\n\n    case \"ArgoDeployClaim\":\n\n      if (claim.providers.argocd && (provider === AllowedProviders.argocd || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.ArgoDeployChart(\n          firestartrScope, \n          `argocd-${chartId}`, \n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n      \n      catalogEntity = new charts.default.CatalogArgoDeployChart(\n        catalogScope, chartId, firestartrId, claim, renderPatches\n      );\n\n      break;\n\n\n    default:\n\n      console.error(`Unknown claim kind: ${claim.kind}`);\n\n      break;\n  }\n\n  /**\n   * There is the possibility to only render the catalog entity, but not the other way around\n   */\n  if (!catalogEntity) {\n\n    throw new Error(`Unable to render claim ${claim.kind}-${claim.name}`);\n\n  }\n\n  /*\n   *\n   * Render phase\n   *\n   */\n  const [catalogChart, firestartrEntityChart] = await Promise.all(\n\n    [\n      provider === AllowedProviders.all ? catalogEntity.render() : Promise.resolve(undefined),\n\n      firestartrEntity?.render(),\n\n    ]\n\n  )\n\n  /*\n   *\n   * Post render phase (and return)\n   *\n   */\n  return {\n\n    catalogEntity: catalogChart ? await catalogChart.postRenderer(postPatches) : undefined,\n\n    firestartrEntity: await (firestartrEntityChart ? firestartrEntityChart.postRenderer(postPatches) : undefined),\n\n    extraCharts: await firestartrEntity?.extraCharts() || []\n  };\n\n}\n\n\n\nfunction sortKinds(orderedKinds: string[], claims: RenderClaims) {\n\n  const result: RenderClaims[] = []\n\n  for (const kind of orderedKinds) {\n\n    const kindRenderClaims: any = sortRenderClaimsByKind(claims, [kind])\n\n    result.push(kindRenderClaims)\n\n  }\n\n  return result\n\n}\n\n\n\n\n\nfunction getPreviousCRfromClaim(claim: any, previousCRs: any) {\n\n  const previousCRsKeys = Object.keys(previousCRs)\n\n  for(const previousCRKey of previousCRsKeys){\n\n    const previousCR = previousCRs[previousCRKey]\n\n    if(isCatalogEntity(previousCR)) continue\n\n    if(isExcludedFromPreviousCR(previousCR.kind)) continue\n\n    if(previousCR.metadata.annotations[CLAIM_REF_ANNOTATION] === `${claim.kind}/${claim.name}`){\n\n      return previousCR\n\n    }\n\n  }\n\n  return false\n\n}\n\n\nfunction isExcludedFromPreviousCR(crKind: string){\n\n\n  return [\"FirestartrGithubRepositoryFeature\"].includes(crKind)\n\n\n}\n"]}
|
|
235604
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../src/renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { IRenameResult, loadAll } from \"./loader\";\nimport * as charts from \"./charts\"\nimport Debug from \"debug\";\nimport { BaseChart } from \"./charts/base\";\nimport { ApiObject, App, YamlOutputType } from \"cdk8s\";\nimport { GlobalSection } from \"./globals/base\";\nimport { generateFeaturesPatches } from \"./charts/github/featureRenderer\";\nimport { OverriderPatches } from \"./overriders/base\";\nimport { ICustomResourcePatch } from \"./patches\";\nimport { isCatalogEntity, validateReferentialIntegrity, validateTfStateKeyUniqueness } from \"./validations/references\";\nimport {  setRenderedClaim } from \"./refresolver\";\nimport { AllowedProviders, getConfiguredProvider } from \"./config\";\nimport { Normalizer } from \"./normalizers/base\";\nimport { sortRenderClaimsByKind } from \"./refsSorter/refsSorter\";\nimport { crawl } from \"./crawler\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport common from \"catalog_common\";\nimport github from \"github\";\nconst CLAIM_REF_ANNOTATION = \"firestartr.dev/claim-ref\"\n\n\nconst log = Debug(\"firestartr:renderer\")\n\nexport type RenderClaimData = {\n\n  claim: any\n\n  claimPath?: string\n\n  initializers: any []\n\n  overrides: OverriderPatches[]\n\n  globals: GlobalSection[],\n\n  normalizers: Normalizer[]\n\n}\n\ntype ClaimKind = string;\ntype ClaimName = string;\nexport type RenderClaimKey = `${ClaimKind}-${ClaimName}`\n\ntype CRKind = string;\ntype CRName = string;\ntype RenderCRKey = `${CRKind}-${CRName}`\n\nexport type RenderedCrMap = {\n\n  [key: RenderCRKey]: ApiObject\n}\n\nexport type RenderClaims = {\n\n  [key: RenderClaimKey]: RenderClaimData\n\n}\n\n/*\n * Function called when rendering from the importer class.\n *\n * Input:\n * - renderClaims: a RenderClaims object, which contains the list of claims\n *   we want to render\n *\n * Return:\n * - The result of rendering the renderClaims object, plus the\n *   rendered firestartr-all group\n *\n */\nexport async function renderFromImports(\n\n  renderClaims: RenderClaims,\n\n  crs: any = {},\n\n  catalogOutputDir: string = \"/tmp/.catalog\",\n\n  crOutputDir: string = \"/tmp/.resources\",\n\n) {\n\n  const catalogScope = new App({\n\n    outdir: catalogOutputDir,\n\n    outputFileExtension: \".yaml\",\n\n    yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n\n  })\n\n  const firestartrScope = new App({\n\n    outdir: crOutputDir,\n\n    outputFileExtension: \".yaml\",\n\n    yamlOutputType: YamlOutputType.FILE_PER_RESOURCE,\n\n  })\n\n  const result: any = await fRenderClaims(\n\n    catalogScope,\n\n    firestartrScope,\n\n    {\n      renderClaims,\n\n      crs,\n\n      renames: []\n    },\n  )\n\n  firestartrScope.synth()\n\n  return result\n\n}\n\n\n/*\n * Function called when rendering but not importing\n *\n * Input:\n * - scope: an object, used to represent CDKTF's execution scope\n *\n * Return:\n * - The result of rendering the renderClaims object, plus the\n *   rendered firestartr-all group\n *\n */\nexport async function render(\n\n  catalogScope: Construct,\n\n  firestartrScope: Construct,\n\n  ): Promise<RenderedCrMap> {\n\n  const data: {\n\n    renderClaims: RenderClaims,\n\n    crs: any,\n\n    renames?: IRenameResult[]\n\n  } = await loadAll()\n\n  const result: any = await fRenderClaims(catalogScope, firestartrScope, data)\n\n  validateReferentialIntegrity(result)\n\n  validateTfStateKeyUniqueness(result)\n\n  return result\n\n}\n\n/*\n * Function called when rendering Terraform workspaces Plans\n * based on the previous renderer Terraform workspaces\n*/\nexport async function renderWorkspacePlans(source: string, destiny: string, prLink: string, sha: string, ghCli: any = github) {\n\n  const [orgRepo, prNumber] = prLink.split(\"#\")\n\n  const [ org, repo ] = orgRepo.split(\"/\")\n\n  const { data: files } = await ghCli.pulls.getPrFiles(\n    parseInt(prNumber),\n    repo,\n    org\n  )\n\n  if(files && files.length > 0 && files[0].status == \"removed\"){\n\n    const content = await ghCli.repo.getContent(\n    \n      files[0].filename,\n    \n      repo,\n    \n      org,\n    \n    )\n\n    const workspace: any = common.io.fromYaml(content)\n\n    workspace.kind = \"FirestartrTerraformWorkspacePlan\"\n    \n    workspace.metadata.annotations = {\n    \n      ...workspace.metadata.annotations,\n      \n      [common.generic.getFirestartrAnnotation(\"pull-request-plan\")]: prLink,\n      \n      [common.generic.getFirestartrAnnotation(\"plan-sha\")]: sha,\n    \n    }\n    \n    workspace.metadata.annotations[\n    \n      common.generic.getFirestartrAnnotation(\"policy\")\n    \n    ] = \"destroy\"\n\n    const workspacePlan = common.io.toYaml(\n    \n      {...workspace}, \n    \n      { quotingType: '\"', lineWidth: -1 }\n    \n    )\n    \n    const fileName = path.join(destiny, path.basename(files[0].filename))\n    \n    fs.writeFileSync(fileName, workspacePlan)\n    \n    return\n  }\n\n  // Iterate over the source folder and get the list of Terraform workspaces\n  await crawl(source, () => true, (entry: string, data: any) => {\n\n    const fileName = path.join(destiny, path.basename(entry))\n\n    const workspace: any = common.io.fromYaml(data)\n\n    workspace.kind = \"FirestartrTerraformWorkspacePlan\"\n    workspace.metadata.annotations = {\n      ...workspace.metadata.annotations,\n      [common.generic.getFirestartrAnnotation(\"pull-request-plan\")]: prLink,\n      [common.generic.getFirestartrAnnotation(\"plan-sha\")]: sha\n    }\n    \n    const workspacePlan = common.io.toYaml({\n      ...workspace\n    }, { quotingType: '\"', lineWidth: -1 })\n\n    fs.writeFileSync(fileName, workspacePlan)\n\n  })\n\n}\n\nexport async function addLastStateAndLastClaimAnnotations(\n  filePath: string, lastStatePRLink: string, lastClaimPRLink: string\n) {\n\n  // Iterate over the source folder and get the list of Terraform workspaces\n\n  const workspace: any = common.io.fromYaml(fs.readFileSync(filePath, \"utf-8\"));\n\n  const stateLinkAsArray: string[] = lastStatePRLink.split(\"/\");\n  const stateAnnotationValue: string = `${stateLinkAsArray[3]}/${stateLinkAsArray[4]}#${stateLinkAsArray[6]}`\n\n  const claimLinkAsArray: string[] = lastClaimPRLink.split(\"/\");\n  const claimAnnotationValue: string = `${claimLinkAsArray[3]}/${claimLinkAsArray[4]}#${claimLinkAsArray[6]}`\n\n  workspace.metadata.annotations = {\n    ...workspace.metadata.annotations,\n    [common.generic.getFirestartrAnnotation(\"last-state-pr\")]: stateAnnotationValue,\n    [common.generic.getFirestartrAnnotation(\"last-claim-pr\")]: claimAnnotationValue\n  }\n\n  fs.writeFileSync(filePath, common.io.toYaml(\n    { ...workspace }, { quotingType: '\"', lineWidth: -1 }\n  ))\n\n}\n\nasync function fRenderClaims(\n\n  catalogScope: Construct,\n\n  firestartrScope: Construct,\n\n  data: {\n\n    renderClaims: RenderClaims,\n\n    crs: any,\n\n    renames?: IRenameResult[]\n\n  },\n\n): Promise<RenderedCrMap> {\n\n  const result: RenderedCrMap = {}\n\n  const { renderClaims, crs } = data\n\n  const sortedKinds = sortKinds([\"UserClaim\", \"GroupClaim\", \"ComponentClaim\", \"DomainClaim\", \"SystemClaim\", \"TFWorkspaceClaim\", \"ArgoDeployClaim\"], renderClaims)\n\n  for (const renderClaims of sortedKinds) {\n\n    for (const claimKey of Object.keys(renderClaims)) {\n\n      const claim = renderClaims[claimKey as RenderClaimKey].claim\n\n      const configuredProvider = getConfiguredProvider().toString()\n\n      let providers = Object.keys(claim.providers)\n\n      if(configuredProvider != AllowedProviders.all.toString()){\n\n        providers = providers.filter(\n\n          (provider: string) => provider === configuredProvider\n\n        )\n\n      }\n\n\n      const previousCR = getPreviousCRfromClaim(claim, crs)\n\n      const patches = await extractPatches(renderClaims[claimKey as RenderClaimKey], previousCR)\n\n      if (!previousCR) {\n\n        log(`No CR found for claim ${claimKey}, it will be rendered from scratch`)\n\n      }\n\n      const {firestartrEntity, extraCharts, catalogEntity}  = await renderClaim(\n\n        catalogScope,\n\n        firestartrScope,\n\n        claim,\n\n        patches,\n\n        previousCR,\n\n      )\n\n      if(catalogEntity) {\n\n        result[`${catalogEntity.kind}-${catalogEntity.metadata.name}`] = catalogEntity.toJson()\n      \n      }\n\n      /**\n\n      * If there is no provider don't store the CR in the map\n\n      */\n\n      if (!firestartrEntity) continue;\n\n      const firestartrEntityJson = firestartrEntity.toJson()\n\n      setRenderedClaim(claim, firestartrEntityJson)\n\n      for(const extraChart of extraCharts){\n\n        const {claim, chart} = extraChart\n\n        setRenderedClaim(claim, chart.toJson())\n\n        result[`${chart.kind}-${chart.metadata.name}`] = chart.toJson()\n\n      }\n\n      if(!firestartrEntityJson.metadata.annotations || !firestartrEntityJson.metadata.name) throw firestartrEntityJson\n\n      result[`${firestartrEntity.kind}-${firestartrEntityJson.metadata.name}`] = firestartrEntityJson\n\n    }\n\n  }\n\n  return result\n\n}\n\nasync function extractPatches(\n\n  claimToRenderData: RenderClaimData, previousCR: any\n\n): Promise<ICustomResourcePatch[]> {\n\n  let totalPatches: ICustomResourcePatch[] = []\n\n\n  for (const normalizer of claimToRenderData.normalizers) {\n\n    const patches = await normalizer.patches(claimToRenderData[\"claim\"], previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n  for (const initializer of claimToRenderData.initializers) {\n\n    const patches = await initializer.patches(claimToRenderData[\"claim\"], previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n  for (const overrider of claimToRenderData.overrides) {\n\n    const patches = await overrider.patches(claimToRenderData[\"claim\"], previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n\n  if (claimToRenderData.claim.kind === \"ComponentClaim\") {\n\n    totalPatches = totalPatches.concat((await generateFeaturesPatches(claimToRenderData.claim))).flat()\n\n  }\n\n\n  for (const global of claimToRenderData.globals) {\n\n    const patches = await global.patches(claimToRenderData.claim, previousCR)\n\n    totalPatches = totalPatches.concat(patches).flat()\n\n  }\n\n  return totalPatches\n\n}\n\nexport interface IRenderClaimResult {\n  catalogEntity?: ApiObject;\n  firestartrEntity?: ApiObject;\n  extraCharts: { claim: {kind: string, name: string}, chart: ApiObject}[];\n}\n\nasync function renderClaim(\n\n  catalogScope: Construct,\n\n  firestartrScope: Construct,\n\n  claim: any,\n\n  patches: ICustomResourcePatch[],\n\n  previousCR: any | null = null\n\n  ): Promise<IRenderClaimResult> {\n\n  let catalogEntity: BaseChart | undefined = undefined;\n  let firestartrEntity: BaseChart | undefined = undefined;\n\n  const chartId = `${claim.kind}-${claim.name}`.toLowerCase();\n\n  let firestartrId: string | null = null;\n\n  if (previousCR) {\n\n    firestartrId = previousCR?.spec?.firestartr?.tfStateKey || null;\n\n  }\n\n  const renderPatches = patches.filter((patch: any) => !patch.isPostPatch)\n  const postPatches = patches.filter((patch:any) => patch.isPostPatch)\n\n  const provider = getConfiguredProvider()\n\n  switch (claim.kind) {\n\n    case \"DomainClaim\":\n\n      catalogEntity = new charts.default.CatalogDomainChart(\n        catalogScope, \n        `catalog-${chartId}`, \n        firestartrId, \n        claim, \n        renderPatches\n      );\n\n      break;\n\n    case \"SystemClaim\":\n\n      catalogEntity = new charts.default.CatalogSystemChart(\n        catalogScope, \n        `catalog-${chartId}`, \n        firestartrId, \n        claim, \n        renderPatches\n      );\n\n      break;\n\n    case \"GroupClaim\":\n\n      catalogEntity = new charts.default.CatalogGroupChart(catalogScope, `catalog-${chartId}`, firestartrId, claim, renderPatches);\n\n      if (claim.providers.github && (provider === AllowedProviders.github || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.GithubGroupChart(\n          firestartrScope,\n          `github-${chartId}`,\n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n\n      break;\n\n    case \"UserClaim\":\n\n      catalogEntity = new charts.default.CatalogUserChart(catalogScope, chartId, firestartrId, claim, renderPatches);\n\n      if (claim.providers.github && (provider === AllowedProviders.github || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.GithubMembershipChart(\n          firestartrScope,\n          `github-${chartId}`,\n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n\n      break;\n\n    case \"ComponentClaim\":\n\n      if (claim.providers.github && (provider === AllowedProviders.github || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.GithubRepositoryChart(\n          firestartrScope,\n          `github-${chartId}`,\n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n      catalogEntity = new charts.default.CatalogComponentChart(\n        catalogScope, chartId, firestartrId, claim, renderPatches\n      );\n\n      break;\n\n    case \"TFWorkspaceClaim\":\n\n      if (claim.providers.terraform && (provider === AllowedProviders.terraform || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.TFWorkspaceChart(\n          firestartrScope, \n          `terraform-${chartId}`, \n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n      catalogEntity = new charts.default.CatalogTFWorkspaceChart(\n        catalogScope, chartId, firestartrId, claim, renderPatches\n      );\n\n      break;\n\n    case \"ArgoDeployClaim\":\n\n      if (claim.providers.argocd && (provider === AllowedProviders.argocd || provider === AllowedProviders.all)) {\n\n        firestartrEntity = new charts.default.ArgoDeployChart(\n          firestartrScope, \n          `argocd-${chartId}`, \n          firestartrId,\n          claim,\n          renderPatches\n        );\n\n      }\n      \n      catalogEntity = new charts.default.CatalogArgoDeployChart(\n        catalogScope, chartId, firestartrId, claim, renderPatches\n      );\n\n      break;\n\n\n    default:\n\n      console.error(`Unknown claim kind: ${claim.kind}`);\n\n      break;\n  }\n\n  /**\n   * There is the possibility to only render the catalog entity, but not the other way around\n   */\n  if (!catalogEntity) {\n\n    throw new Error(`Unable to render claim ${claim.kind}-${claim.name}`);\n\n  }\n\n  /*\n   *\n   * Render phase\n   *\n   */\n  const [catalogChart, firestartrEntityChart] = await Promise.all(\n\n    [\n      provider === AllowedProviders.all ? catalogEntity.render() : Promise.resolve(undefined),\n\n      firestartrEntity?.render(),\n\n    ]\n\n  )\n\n  /*\n   *\n   * Post render phase (and return)\n   *\n   */\n  return {\n\n    catalogEntity: catalogChart ? await catalogChart.postRenderer(postPatches) : undefined,\n\n    firestartrEntity: await (firestartrEntityChart ? firestartrEntityChart.postRenderer(postPatches) : undefined),\n\n    extraCharts: await firestartrEntity?.extraCharts() || []\n  };\n\n}\n\n\n\nfunction sortKinds(orderedKinds: string[], claims: RenderClaims) {\n\n  const result: RenderClaims[] = []\n\n  for (const kind of orderedKinds) {\n\n    const kindRenderClaims: any = sortRenderClaimsByKind(claims, [kind])\n\n    result.push(kindRenderClaims)\n\n  }\n\n  return result\n\n}\n\n\n\n\n\nfunction getPreviousCRfromClaim(claim: any, previousCRs: any) {\n\n  const previousCRsKeys = Object.keys(previousCRs)\n\n  for(const previousCRKey of previousCRsKeys){\n\n    const previousCR = previousCRs[previousCRKey]\n\n    if(isCatalogEntity(previousCR)) continue\n\n    if(isExcludedFromPreviousCR(previousCR.kind)) continue\n\n    if(previousCR.metadata.annotations[CLAIM_REF_ANNOTATION] === `${claim.kind}/${claim.name}`){\n\n      return previousCR\n\n    }\n\n  }\n\n  return false\n\n}\n\n\nfunction isExcludedFromPreviousCR(crKind: string){\n\n\n  return [\"FirestartrGithubRepositoryFeature\"].includes(crKind)\n\n\n}\n"]}
|
|
235586
235605
|
|
|
235587
235606
|
/***/ }),
|
|
235588
235607
|
|
|
@@ -237086,7 +237105,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
237086
237105
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
237087
237106
|
};
|
|
237088
237107
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
237089
|
-
exports.commentInPR = void 0;
|
|
237108
|
+
exports.getPrFiles = exports.commentInPR = void 0;
|
|
237090
237109
|
const auth_1 = __nccwpck_require__(7745);
|
|
237091
237110
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
237092
237111
|
const messageLog = (0, debug_1.default)('firestartr:github:pull_request');
|
|
@@ -237098,7 +237117,39 @@ async function commentInPR(comment, pr_number, repo, owner = "prefapp") {
|
|
|
237098
237117
|
});
|
|
237099
237118
|
}
|
|
237100
237119
|
exports.commentInPR = commentInPR;
|
|
237101
|
-
|
|
237120
|
+
async function getPrFiles(pr_number, repo, owner = "prefapp") {
|
|
237121
|
+
messageLog(`Getting PR details of PR ${pr_number} of ${owner}/${repo}`);
|
|
237122
|
+
const octokit = await (0, auth_1.getOctokitForOrg)(owner);
|
|
237123
|
+
return await octokit.rest.pulls.listFiles({
|
|
237124
|
+
owner, repo, pull_number: pr_number
|
|
237125
|
+
});
|
|
237126
|
+
}
|
|
237127
|
+
exports.getPrFiles = getPrFiles;
|
|
237128
|
+
async function filterPrBy(filter, opts) {
|
|
237129
|
+
let foundPr = null;
|
|
237130
|
+
let retries = 0;
|
|
237131
|
+
const { title, state, repo, owner, userType } = filter;
|
|
237132
|
+
const { maxRetries } = opts;
|
|
237133
|
+
const octokit = await (0, auth_1.getOctokitForOrg)(owner);
|
|
237134
|
+
while (retries < maxRetries) {
|
|
237135
|
+
const resp = await octokit.rest.pulls.list({
|
|
237136
|
+
owner,
|
|
237137
|
+
repo,
|
|
237138
|
+
state,
|
|
237139
|
+
per_page: 100,
|
|
237140
|
+
page: retries
|
|
237141
|
+
});
|
|
237142
|
+
foundPr = resp.data.find(pr => {
|
|
237143
|
+
return pr.title
|
|
237144
|
+
.includes(title) &&
|
|
237145
|
+
pr?.user?.type === userType;
|
|
237146
|
+
});
|
|
237147
|
+
if (foundPr)
|
|
237148
|
+
return foundPr;
|
|
237149
|
+
retries++;
|
|
237150
|
+
}
|
|
237151
|
+
}
|
|
237152
|
+
exports["default"] = { commentInPR, getPrFiles, filterPrBy };
|
|
237102
237153
|
|
|
237103
237154
|
|
|
237104
237155
|
/***/ }),
|
|
@@ -239100,7 +239151,7 @@ const informer_1 = __nccwpck_require__(41151);
|
|
|
239100
239151
|
const dummy_1 = __nccwpck_require__(73490);
|
|
239101
239152
|
const processItem_1 = __nccwpck_require__(84766);
|
|
239102
239153
|
const cdktf_1 = __nccwpck_require__(10805);
|
|
239103
|
-
const
|
|
239154
|
+
const process_operation_1 = __nccwpck_require__(3937);
|
|
239104
239155
|
const leader_election_1 = __nccwpck_require__(29856);
|
|
239105
239156
|
const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
|
|
239106
239157
|
const processOperationPlan_1 = __nccwpck_require__(79980);
|
|
@@ -239164,7 +239215,7 @@ function getProvisionImplementation(plural) {
|
|
|
239164
239215
|
let implementation = undefined;
|
|
239165
239216
|
switch (plural) {
|
|
239166
239217
|
case "terraformworkspaces":
|
|
239167
|
-
implementation =
|
|
239218
|
+
implementation = process_operation_1.processOperation;
|
|
239168
239219
|
break;
|
|
239169
239220
|
case "terraformworkspaceplans":
|
|
239170
239221
|
implementation = processOperationPlan_1.processOperationPlan;
|
|
@@ -240193,7 +240244,7 @@ async function inform(pluralKind, item, op, lastWorkItem = null) {
|
|
|
240193
240244
|
};
|
|
240194
240245
|
return workItem;
|
|
240195
240246
|
case "onRename":
|
|
240196
|
-
if (await (0, status_1.needsProvisioningOnCreate)(
|
|
240247
|
+
if (await (0, status_1.needsProvisioningOnCreate)(item)) {
|
|
240197
240248
|
log("onRename - needsProvisioningOnCreate true %s", item.metadata.name);
|
|
240198
240249
|
workItem = {
|
|
240199
240250
|
operation: OperationType.RENAMED,
|
|
@@ -240217,7 +240268,7 @@ async function inform(pluralKind, item, op, lastWorkItem = null) {
|
|
|
240217
240268
|
return workItem;
|
|
240218
240269
|
case "onAdd":
|
|
240219
240270
|
log("onAdd %s", item.metadata.name);
|
|
240220
|
-
if (await (0, status_1.needsProvisioningOnCreate)(
|
|
240271
|
+
if (await (0, status_1.needsProvisioningOnCreate)(item)) {
|
|
240221
240272
|
workItem = {
|
|
240222
240273
|
operation: OperationType.CREATED,
|
|
240223
240274
|
item,
|
|
@@ -240734,11 +240785,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
240734
240785
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
240735
240786
|
exports.observe = void 0;
|
|
240736
240787
|
const ctl_1 = __nccwpck_require__(46679);
|
|
240737
|
-
const fast_json_patch_1 = __importDefault(__nccwpck_require__(75177));
|
|
240738
240788
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
240739
240789
|
const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
|
|
240740
240790
|
const log = (0, debug_1.default)('firestartr:operator:reflector');
|
|
240741
240791
|
const k8s = __importStar(__nccwpck_require__(54851));
|
|
240792
|
+
const store_1 = __nccwpck_require__(87432);
|
|
240742
240793
|
/**
|
|
240743
240794
|
* Execute the callbacks for each item in the store
|
|
240744
240795
|
* @param {string} kind - Kind to observe
|
|
@@ -240749,7 +240800,7 @@ const k8s = __importStar(__nccwpck_require__(54851));
|
|
|
240749
240800
|
* @param {Function} onRename - Function to call when an item is renamed
|
|
240750
240801
|
*/
|
|
240751
240802
|
async function observe(kind, namespace, onAdd, onChange, onDelete, _onRename) {
|
|
240752
|
-
const store = new Store(kind);
|
|
240803
|
+
const store = new store_1.Store(kind);
|
|
240753
240804
|
const { kc } = await (0, ctl_1.getConnection)();
|
|
240754
240805
|
try {
|
|
240755
240806
|
const k8sApi = kc.makeApiClient(k8s.CustomObjectsApi);
|
|
@@ -240761,29 +240812,37 @@ async function observe(kind, namespace, onAdd, onChange, onDelete, _onRename) {
|
|
|
240761
240812
|
};
|
|
240762
240813
|
const informer = k8s.makeInformer(kc, apiPaths, listFn);
|
|
240763
240814
|
informer.on('add', (obj) => {
|
|
240764
|
-
log(`informer: ADDED ${obj.metadata.name}`);
|
|
240765
240815
|
store.add(obj);
|
|
240766
|
-
|
|
240816
|
+
if (store.hasDeletionTimestamp(obj)) {
|
|
240817
|
+
log(`informer (on add): The item ${obj.metadata.name} has a deletion timestamp, marking for deletion`);
|
|
240818
|
+
store.markToDelete(obj);
|
|
240819
|
+
onDelete(obj);
|
|
240820
|
+
}
|
|
240821
|
+
else {
|
|
240822
|
+
log(`informer (on add): The item ${obj.metadata.name} has been added`);
|
|
240823
|
+
onAdd(obj);
|
|
240824
|
+
}
|
|
240767
240825
|
});
|
|
240768
240826
|
informer.on('update', (obj) => {
|
|
240769
|
-
log(`informer:
|
|
240770
|
-
if (store.getItem(obj).markedToDelete
|
|
240771
|
-
|
|
240772
|
-
|
|
240827
|
+
log(`informer (on update): The item ${obj.kind}: ${obj.metadata.name} has been updated`);
|
|
240828
|
+
if (!store.getItem(obj).markedToDelete &&
|
|
240829
|
+
store.hasDeletionTimestamp(obj) &&
|
|
240830
|
+
(store.hasBeenMarkedToDelete(obj) || store.modified(obj))) {
|
|
240831
|
+
log(`informer (on update): The item ${obj.kind}: ${obj.metadata.name} has a deletion timestamp, marking for deletion`);
|
|
240773
240832
|
store.markToDelete(obj);
|
|
240774
240833
|
onDelete(obj);
|
|
240775
240834
|
}
|
|
240776
240835
|
else if (store.modified(obj)) {
|
|
240836
|
+
log(`informer (on update): The item ${obj.kind}: ${obj.metadata.name} has been modified`);
|
|
240777
240837
|
onChange(obj);
|
|
240778
240838
|
}
|
|
240779
240839
|
});
|
|
240780
240840
|
informer.on('delete', (obj) => {
|
|
240781
|
-
log(`informer:
|
|
240841
|
+
log(`informer (on delete): The item ${obj.metadata.name} :${obj.metadata.name} has been deleted from etcd`);
|
|
240782
240842
|
store.remove(obj);
|
|
240783
240843
|
});
|
|
240784
240844
|
informer.on('error', (err) => {
|
|
240785
|
-
|
|
240786
|
-
// Restart informer after 5sec
|
|
240845
|
+
log(`informer (on error): ERROR %O`, err);
|
|
240787
240846
|
setTimeout(() => {
|
|
240788
240847
|
informer.start();
|
|
240789
240848
|
}, 5000);
|
|
@@ -240797,52 +240856,6 @@ async function observe(kind, namespace, onAdd, onChange, onDelete, _onRename) {
|
|
|
240797
240856
|
}
|
|
240798
240857
|
}
|
|
240799
240858
|
exports.observe = observe;
|
|
240800
|
-
class Store {
|
|
240801
|
-
kind;
|
|
240802
|
-
store = {};
|
|
240803
|
-
constructor(kind) {
|
|
240804
|
-
this.kind = kind;
|
|
240805
|
-
}
|
|
240806
|
-
add(item) {
|
|
240807
|
-
this.store[itemPath(this.kind, item)] = {
|
|
240808
|
-
item
|
|
240809
|
-
};
|
|
240810
|
-
}
|
|
240811
|
-
isMarkedToDelete(item) {
|
|
240812
|
-
return "deletionTimestamp" in item.metadata;
|
|
240813
|
-
}
|
|
240814
|
-
markToDelete(item) {
|
|
240815
|
-
this.store[itemPath(this.kind, item)] = {
|
|
240816
|
-
item,
|
|
240817
|
-
markedToDelete: true
|
|
240818
|
-
};
|
|
240819
|
-
}
|
|
240820
|
-
modified(item) {
|
|
240821
|
-
const oldItem = this.getItem(item).item;
|
|
240822
|
-
const patches = fast_json_patch_1.default.compare(item, oldItem);
|
|
240823
|
-
let updated = false;
|
|
240824
|
-
for (const patch of patches) {
|
|
240825
|
-
if (patch.path.match(/^\/spec/) || patch.path.match(/\/metadata.*annotations/)) {
|
|
240826
|
-
updated = true;
|
|
240827
|
-
break;
|
|
240828
|
-
}
|
|
240829
|
-
}
|
|
240830
|
-
this.store[itemPath(this.kind, item)] = {
|
|
240831
|
-
item
|
|
240832
|
-
};
|
|
240833
|
-
console.log(Object.keys(this.store));
|
|
240834
|
-
return updated;
|
|
240835
|
-
}
|
|
240836
|
-
remove(item) {
|
|
240837
|
-
delete this.store[itemPath(this.kind, item)];
|
|
240838
|
-
}
|
|
240839
|
-
getItem(item) {
|
|
240840
|
-
return this.store[itemPath(this.kind, item)];
|
|
240841
|
-
}
|
|
240842
|
-
}
|
|
240843
|
-
function itemPath(kind, item) {
|
|
240844
|
-
return `${item.metadata.namespace}/${kind}/${item.metadata.name}`;
|
|
240845
|
-
}
|
|
240846
240859
|
|
|
240847
240860
|
|
|
240848
240861
|
/***/ }),
|
|
@@ -240991,7 +241004,7 @@ const ctl_1 = __nccwpck_require__(46679);
|
|
|
240991
241004
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
240992
241005
|
const log = (0, debug_1.default)('firestartr:operator:retry');
|
|
240993
241006
|
const NEXT_RETRY_SECS = 1000 * 60;
|
|
240994
|
-
const MAXRETRY =
|
|
241007
|
+
const MAXRETRY = 5;
|
|
240995
241008
|
const retryWatchers = {};
|
|
240996
241009
|
async function initRetry(enqueue) {
|
|
240997
241010
|
loop(enqueue);
|
|
@@ -241011,6 +241024,9 @@ exports.initRetry = initRetry;
|
|
|
241011
241024
|
function retry(itemPath) {
|
|
241012
241025
|
if (retryWatchers[itemPath]) {
|
|
241013
241026
|
retryWatchers[itemPath].retryCounter++;
|
|
241027
|
+
log(`đ Retrying failed for: ${itemPath}, increasing retry counter to ${retryWatchers[itemPath].retryCounter}`);
|
|
241028
|
+
log(`đ Remaining retries for ${itemPath}: ${MAXRETRY - retryWatchers[itemPath].retryCounter}`);
|
|
241029
|
+
log(`đ Next retry for ${itemPath} in ${NEXT_RETRY_SECS * retryWatchers[itemPath].retryCounter} seconds`);
|
|
241014
241030
|
retryWatchers[itemPath].retry = false;
|
|
241015
241031
|
retryWatchers[itemPath].nextRetry = setTimeout(() => {
|
|
241016
241032
|
if (itemPath in retryWatchers)
|
|
@@ -241090,67 +241106,47 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
241090
241106
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
241091
241107
|
};
|
|
241092
241108
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
241093
|
-
exports.updateTransition = exports.
|
|
241109
|
+
exports.updateTransition = exports.needsProvisioningOnCreate = void 0;
|
|
241094
241110
|
const ctl_1 = __nccwpck_require__(46679);
|
|
241095
241111
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
241096
241112
|
const log = (0, debug_1.default)('firestartr:operator:status');
|
|
241097
|
-
|
|
241098
|
-
|
|
241099
|
-
|
|
241100
|
-
if (!("status" in
|
|
241101
|
-
|
|
241102
|
-
try {
|
|
241103
|
-
const errorCondition = getConditionByType(k8sItem.status.conditions, "ERROR");
|
|
241104
|
-
if (errorCondition.status === "True" &&
|
|
241105
|
-
errorCondition.observedGeneration >= k8sItem.metadata.generation) {
|
|
241106
|
-
return true;
|
|
241107
|
-
}
|
|
241108
|
-
}
|
|
241109
|
-
catch (e) {
|
|
241110
|
-
catalog_common_1.default.io.writeFunctionLog("needsProvisioningOnCreate", `Error getting error condition: ${e}`);
|
|
241111
|
-
}
|
|
241112
|
-
try {
|
|
241113
|
-
const provisionedCondition = getConditionByType(k8sItem.status.conditions, "PROVISIONED");
|
|
241114
|
-
if (provisionedCondition.status === "True" &&
|
|
241115
|
-
provisionedCondition.observedGeneration >= k8sItem.metadata.generation) {
|
|
241116
|
-
return false;
|
|
241117
|
-
}
|
|
241113
|
+
async function needsProvisioningOnCreate(cr) {
|
|
241114
|
+
const fCrLog = (cr) => `The item ${cr.kind}: ${cr.metadata.name}`;
|
|
241115
|
+
// NO STATUS
|
|
241116
|
+
if (!("status" in cr) || !("conditions" in cr.status)) {
|
|
241117
|
+
log(`${fCrLog(cr)} has no status or conditions, provisioning...`);
|
|
241118
241118
|
return true;
|
|
241119
241119
|
}
|
|
241120
|
-
|
|
241121
|
-
|
|
241122
|
-
|
|
241120
|
+
// ERROR
|
|
241121
|
+
const errCond = getConditionByType(cr.status.conditions, "ERROR");
|
|
241122
|
+
if (errCond && errCond.status === "True") {
|
|
241123
|
+
log(`${fCrLog(cr)} has an error condition, skipping provisioning...`);
|
|
241124
|
+
return false;
|
|
241123
241125
|
}
|
|
241124
|
-
|
|
241125
|
-
|
|
241126
|
-
|
|
241127
|
-
|
|
241128
|
-
|
|
241129
|
-
return true;
|
|
241130
|
-
try {
|
|
241131
|
-
const errorCondition = getConditionByType(k8sItem.status.conditions, "ERROR");
|
|
241132
|
-
if (errorCondition.status === "True" &&
|
|
241133
|
-
errorCondition.observedGeneration >= k8sItem.metadata.generation) {
|
|
241134
|
-
return true;
|
|
241135
|
-
}
|
|
241126
|
+
// PROVISIONED
|
|
241127
|
+
const provCond = getConditionByType(cr.status.conditions, "PROVISIONED");
|
|
241128
|
+
if (provCond && provCond.status === "True" && provCond.observedGeneration >= cr.metadata.generation) {
|
|
241129
|
+
log(`${fCrLog(cr)} has already been provisioned, skipping provisioning...`);
|
|
241130
|
+
return false;
|
|
241136
241131
|
}
|
|
241137
|
-
|
|
241138
|
-
|
|
241139
|
-
|
|
241140
|
-
|
|
241141
|
-
|
|
241142
|
-
return false;
|
|
241143
|
-
}
|
|
241144
|
-
const provisioningCondition = getConditionByType(k8sItem.status.conditions, "PROVISIONING");
|
|
241145
|
-
return provisioningCondition.status !== "True";
|
|
241132
|
+
// DELETED
|
|
241133
|
+
const delCond = getConditionByType(cr.status.conditions, "DELETED");
|
|
241134
|
+
if (delCond && delCond.status === "True" && delCond.observedGeneration >= cr.metadata.generation) {
|
|
241135
|
+
log(`${fCrLog(cr)} has been deleted, skipping provisioning`);
|
|
241136
|
+
return false;
|
|
241146
241137
|
}
|
|
241147
|
-
|
|
241138
|
+
// PROVISIONING
|
|
241139
|
+
const provisioningCondition = getConditionByType(cr.status.conditions, "PROVISIONING");
|
|
241140
|
+
if (provisioningCondition && provisioningCondition.status === "True") {
|
|
241141
|
+
log(`${fCrLog(cr)} is in PROVISIONING state, it was not finished, provisioning again...`);
|
|
241148
241142
|
return true;
|
|
241149
241143
|
}
|
|
241144
|
+
log(`${fCrLog(cr)} is in a not handled state, skipping provisioning...`);
|
|
241145
|
+
return false;
|
|
241150
241146
|
}
|
|
241151
|
-
exports.
|
|
241147
|
+
exports.needsProvisioningOnCreate = needsProvisioningOnCreate;
|
|
241152
241148
|
async function updateTransition(itemPath, reason, type, statusValue, message = "", updateStatusOnly = false) {
|
|
241153
|
-
log("
|
|
241149
|
+
log("Update transition for item: %s, reason: %s, type: %s, status: %s, message: %s, updateStatusOnly: %s", itemPath, reason, type, statusValue, message, updateStatusOnly);
|
|
241154
241150
|
const k8sItem = await (0, ctl_1.getItemByItemPath)(itemPath);
|
|
241155
241151
|
if (!("status" in k8sItem))
|
|
241156
241152
|
k8sItem.status = {};
|
|
@@ -241169,20 +241165,18 @@ async function updateTransition(itemPath, reason, type, statusValue, message = "
|
|
|
241169
241165
|
}
|
|
241170
241166
|
exports.updateTransition = updateTransition;
|
|
241171
241167
|
function getRelevantCondition(conditionList, type) {
|
|
241172
|
-
|
|
241173
|
-
|
|
241174
|
-
|
|
241175
|
-
|
|
241176
|
-
|
|
241177
|
-
|
|
241178
|
-
|
|
241179
|
-
|
|
241180
|
-
|
|
241181
|
-
|
|
241182
|
-
|
|
241183
|
-
|
|
241184
|
-
};
|
|
241185
|
-
}
|
|
241168
|
+
const condition = getConditionByType(conditionList, type);
|
|
241169
|
+
if (condition)
|
|
241170
|
+
return condition;
|
|
241171
|
+
return {
|
|
241172
|
+
"lastTransitionTime": new Date().toJSON(),
|
|
241173
|
+
"lastUpdateTime": new Date().toJSON(),
|
|
241174
|
+
"message": "",
|
|
241175
|
+
"observedGeneration": -1,
|
|
241176
|
+
"reason": "",
|
|
241177
|
+
"status": "",
|
|
241178
|
+
"type": type,
|
|
241179
|
+
};
|
|
241186
241180
|
}
|
|
241187
241181
|
function updateCondition(condition, reason, status, message, generation) {
|
|
241188
241182
|
condition.lastUpdateTime = new Date().toJSON();
|
|
@@ -241197,7 +241191,7 @@ function getConditionByType(conditionList, type) {
|
|
|
241197
241191
|
if (conditionList[i].type === type)
|
|
241198
241192
|
return conditionList[i];
|
|
241199
241193
|
}
|
|
241200
|
-
|
|
241194
|
+
return false;
|
|
241201
241195
|
}
|
|
241202
241196
|
function updateConditionByType(conditionList, type, newCondition) {
|
|
241203
241197
|
let typeFound = false;
|
|
@@ -241213,6 +241207,82 @@ function updateConditionByType(conditionList, type, newCondition) {
|
|
|
241213
241207
|
}
|
|
241214
241208
|
|
|
241215
241209
|
|
|
241210
|
+
/***/ }),
|
|
241211
|
+
|
|
241212
|
+
/***/ 87432:
|
|
241213
|
+
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
|
|
241214
|
+
|
|
241215
|
+
"use strict";
|
|
241216
|
+
|
|
241217
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
241218
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
241219
|
+
};
|
|
241220
|
+
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
241221
|
+
exports.itemPath = exports.Store = void 0;
|
|
241222
|
+
const fast_json_patch_1 = __importDefault(__nccwpck_require__(75177));
|
|
241223
|
+
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
241224
|
+
const log = (0, debug_1.default)('firestartr:operator:store');
|
|
241225
|
+
class Store {
|
|
241226
|
+
kind;
|
|
241227
|
+
store = {};
|
|
241228
|
+
constructor(kind) {
|
|
241229
|
+
this.kind = kind;
|
|
241230
|
+
}
|
|
241231
|
+
add(item) {
|
|
241232
|
+
this.store[itemPath(this.kind, item)] = {
|
|
241233
|
+
item
|
|
241234
|
+
};
|
|
241235
|
+
}
|
|
241236
|
+
hasDeletionTimestamp(item) {
|
|
241237
|
+
return "deletionTimestamp" in item.metadata;
|
|
241238
|
+
}
|
|
241239
|
+
markToDelete(item) {
|
|
241240
|
+
this.store[itemPath(this.kind, item)] = {
|
|
241241
|
+
item,
|
|
241242
|
+
markedToDelete: true
|
|
241243
|
+
};
|
|
241244
|
+
}
|
|
241245
|
+
hasBeenMarkedToDelete(item) {
|
|
241246
|
+
const oldItem = this.getItem(item).item;
|
|
241247
|
+
const patches = fast_json_patch_1.default.compare(item, oldItem);
|
|
241248
|
+
let updated = false;
|
|
241249
|
+
for (const patch of patches) {
|
|
241250
|
+
if (patch.path.match(/^\/metadata\/deletionTimestamp/)) {
|
|
241251
|
+
updated = true;
|
|
241252
|
+
break;
|
|
241253
|
+
}
|
|
241254
|
+
}
|
|
241255
|
+
return updated;
|
|
241256
|
+
}
|
|
241257
|
+
modified(item) {
|
|
241258
|
+
const oldItem = this.getItem(item).item;
|
|
241259
|
+
const patches = fast_json_patch_1.default.compare(item, oldItem);
|
|
241260
|
+
let updated = false;
|
|
241261
|
+
for (const patch of patches) {
|
|
241262
|
+
if (patch.path.match(/^\/spec/) || patch.path.match(/\/metadata.*annotations/)) {
|
|
241263
|
+
updated = true;
|
|
241264
|
+
break;
|
|
241265
|
+
}
|
|
241266
|
+
}
|
|
241267
|
+
this.store[itemPath(this.kind, item)] = {
|
|
241268
|
+
item
|
|
241269
|
+
};
|
|
241270
|
+
return updated;
|
|
241271
|
+
}
|
|
241272
|
+
remove(item) {
|
|
241273
|
+
delete this.store[itemPath(this.kind, item)];
|
|
241274
|
+
}
|
|
241275
|
+
getItem(item) {
|
|
241276
|
+
return this.store[itemPath(this.kind, item)];
|
|
241277
|
+
}
|
|
241278
|
+
}
|
|
241279
|
+
exports.Store = Store;
|
|
241280
|
+
function itemPath(kind, item) {
|
|
241281
|
+
return `${item.metadata.namespace}/${kind}/${item.metadata.name}`;
|
|
241282
|
+
}
|
|
241283
|
+
exports.itemPath = itemPath;
|
|
241284
|
+
|
|
241285
|
+
|
|
241216
241286
|
/***/ }),
|
|
241217
241287
|
|
|
241218
241288
|
/***/ 74298:
|
|
@@ -241383,7 +241453,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
241383
241453
|
};
|
|
241384
241454
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
241385
241455
|
exports.buildProvisionerContext = exports.processOperationPlan = void 0;
|
|
241386
|
-
const informer_1 = __nccwpck_require__(41151);
|
|
241387
241456
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
241388
241457
|
const terraform_provisioner_1 = __nccwpck_require__(6777);
|
|
241389
241458
|
const github_1 = __importDefault(__nccwpck_require__(39759));
|
|
@@ -241394,12 +241463,15 @@ const TF_PROJECTS_PATH = "/tmp/tfworkspaces";
|
|
|
241394
241463
|
function processOperationPlan(item, op, handler) {
|
|
241395
241464
|
try {
|
|
241396
241465
|
clearLocalTfProjects();
|
|
241397
|
-
|
|
241398
|
-
|
|
241399
|
-
|
|
241400
|
-
|
|
241401
|
-
|
|
241402
|
-
|
|
241466
|
+
const policy = getPolicy(item);
|
|
241467
|
+
if (policy === "observe" || policy === "apply") {
|
|
241468
|
+
return plan(item, op, handler);
|
|
241469
|
+
}
|
|
241470
|
+
else if (policy === "destroy") {
|
|
241471
|
+
return plan(item, op, handler, "plain-text", "plan-destroy");
|
|
241472
|
+
}
|
|
241473
|
+
else {
|
|
241474
|
+
return nothing(item, op, handler);
|
|
241403
241475
|
}
|
|
241404
241476
|
}
|
|
241405
241477
|
catch (e) {
|
|
@@ -241408,7 +241480,7 @@ function processOperationPlan(item, op, handler) {
|
|
|
241408
241480
|
}
|
|
241409
241481
|
}
|
|
241410
241482
|
exports.processOperationPlan = processOperationPlan;
|
|
241411
|
-
async function* nothing(item, op,
|
|
241483
|
+
async function* nothing(item, op, _handler) {
|
|
241412
241484
|
yield {
|
|
241413
241485
|
item,
|
|
241414
241486
|
reason: op,
|
|
@@ -241417,19 +241489,19 @@ async function* nothing(item, op, handler) {
|
|
|
241417
241489
|
message: "NOTHING"
|
|
241418
241490
|
};
|
|
241419
241491
|
}
|
|
241420
|
-
async function* plan(item, op, handler, format = "plain-text") {
|
|
241492
|
+
async function* plan(item, op, handler, format = "plain-text", action = "plan") {
|
|
241421
241493
|
if (format == "plain-text") {
|
|
241422
|
-
for await (const transition of doPlanPlainTextFormat(item, op, handler)) {
|
|
241494
|
+
for await (const transition of doPlanPlainTextFormat(item, op, handler, action)) {
|
|
241423
241495
|
yield transition;
|
|
241424
241496
|
}
|
|
241425
241497
|
}
|
|
241426
241498
|
else if (format == "json") {
|
|
241427
|
-
for await (const transition of doPlanJSONFormat(item, op, handler)) {
|
|
241499
|
+
for await (const transition of doPlanJSONFormat(item, op, handler, action)) {
|
|
241428
241500
|
yield transition;
|
|
241429
241501
|
}
|
|
241430
241502
|
}
|
|
241431
241503
|
}
|
|
241432
|
-
async function* doPlanPlainTextFormat(item, op, handler) {
|
|
241504
|
+
async function* doPlanPlainTextFormat(item, op, handler, action) {
|
|
241433
241505
|
try {
|
|
241434
241506
|
yield {
|
|
241435
241507
|
item,
|
|
@@ -241455,7 +241527,7 @@ async function* doPlanPlainTextFormat(item, op, handler) {
|
|
|
241455
241527
|
const deps = await handler.resolveReferences();
|
|
241456
241528
|
log('Item %s has the following dependencies: %O', item.metadata.name, deps);
|
|
241457
241529
|
const context = buildProvisionerContext(item, deps);
|
|
241458
|
-
const tfPlanOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context,
|
|
241530
|
+
const tfPlanOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, action);
|
|
241459
241531
|
await publishPlan(item, tfPlanOutput);
|
|
241460
241532
|
yield {
|
|
241461
241533
|
item,
|
|
@@ -241509,7 +241581,7 @@ async function* doPlanPlainTextFormat(item, op, handler) {
|
|
|
241509
241581
|
}
|
|
241510
241582
|
}
|
|
241511
241583
|
}
|
|
241512
|
-
async function* doPlanJSONFormat(item, op, handler) {
|
|
241584
|
+
async function* doPlanJSONFormat(item, op, handler, action) {
|
|
241513
241585
|
try {
|
|
241514
241586
|
yield {
|
|
241515
241587
|
item,
|
|
@@ -241535,7 +241607,7 @@ async function* doPlanJSONFormat(item, op, handler) {
|
|
|
241535
241607
|
const deps = await handler.resolveReferences();
|
|
241536
241608
|
log('Item %s has the following dependencies: %O', item.metadata.name, deps);
|
|
241537
241609
|
const context = buildProvisionerContext(item, deps);
|
|
241538
|
-
const tfPlan = await (0, terraform_provisioner_1.runTerraformProvisioner)(context,
|
|
241610
|
+
const tfPlan = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, action);
|
|
241539
241611
|
if (tfPlan.summary.hasChanges()) {
|
|
241540
241612
|
yield {
|
|
241541
241613
|
item,
|
|
@@ -241843,6 +241915,11 @@ async function publishPlan(item, planOutput) {
|
|
|
241843
241915
|
console.error(e);
|
|
241844
241916
|
}
|
|
241845
241917
|
}
|
|
241918
|
+
function getPolicy(item) {
|
|
241919
|
+
const policy = item.metadata.annotations && item.metadata.annotations["firestartr.dev/policy"];
|
|
241920
|
+
if (policy)
|
|
241921
|
+
return policy;
|
|
241922
|
+
}
|
|
241846
241923
|
|
|
241847
241924
|
|
|
241848
241925
|
/***/ }),
|
|
@@ -241941,7 +242018,7 @@ const terraform_provisioner_1 = __nccwpck_require__(6777);
|
|
|
241941
242018
|
const ctl_1 = __nccwpck_require__(46679);
|
|
241942
242019
|
const ctx_1 = __nccwpck_require__(15284);
|
|
241943
242020
|
const resolver_1 = __nccwpck_require__(31022);
|
|
241944
|
-
const
|
|
242021
|
+
const process_operation_1 = __nccwpck_require__(3937);
|
|
241945
242022
|
const cdk8s_renderer_1 = __importDefault(__nccwpck_require__(80318));
|
|
241946
242023
|
const ctl_2 = __nccwpck_require__(59018);
|
|
241947
242024
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
@@ -241988,7 +242065,7 @@ async function buildContext(claim, namespace, command) {
|
|
|
241988
242065
|
};
|
|
241989
242066
|
compute["runProvision"] = async () => {
|
|
241990
242067
|
infolog("đ Running terraform process...");
|
|
241991
|
-
const data = await (0,
|
|
242068
|
+
const data = await (0, process_operation_1.buildProvisionerContext)(cr, deps);
|
|
241992
242069
|
const result = await (0, terraform_provisioner_1.runTerraformProvisioner)(data, command);
|
|
241993
242070
|
infolog("â
Terraform process finished");
|
|
241994
242071
|
return result;
|
|
@@ -242000,7 +242077,72 @@ exports.buildContext = buildContext;
|
|
|
242000
242077
|
|
|
242001
242078
|
/***/ }),
|
|
242002
242079
|
|
|
242003
|
-
/***/
|
|
242080
|
+
/***/ 31058:
|
|
242081
|
+
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
|
|
242082
|
+
|
|
242083
|
+
"use strict";
|
|
242084
|
+
|
|
242085
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
242086
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
242087
|
+
};
|
|
242088
|
+
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
242089
|
+
exports.policyAllowsOp = exports.policies = void 0;
|
|
242090
|
+
const informer_1 = __nccwpck_require__(41151);
|
|
242091
|
+
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
242092
|
+
const debug = (0, debug_1.default)("firestartr:operator:tfworkspaces:policies");
|
|
242093
|
+
exports.policies = {
|
|
242094
|
+
"observe": [
|
|
242095
|
+
informer_1.OperationType.NOTHING
|
|
242096
|
+
],
|
|
242097
|
+
"apply": [
|
|
242098
|
+
informer_1.OperationType.UPDATED,
|
|
242099
|
+
informer_1.OperationType.CREATED,
|
|
242100
|
+
informer_1.OperationType.RENAMED,
|
|
242101
|
+
informer_1.OperationType.SYNC,
|
|
242102
|
+
informer_1.OperationType.RETRY,
|
|
242103
|
+
informer_1.OperationType.NOTHING
|
|
242104
|
+
],
|
|
242105
|
+
"create-only": [
|
|
242106
|
+
informer_1.OperationType.CREATED,
|
|
242107
|
+
informer_1.OperationType.RETRY,
|
|
242108
|
+
],
|
|
242109
|
+
"create-update-only": [
|
|
242110
|
+
informer_1.OperationType.UPDATED,
|
|
242111
|
+
informer_1.OperationType.CREATED,
|
|
242112
|
+
informer_1.OperationType.RETRY,
|
|
242113
|
+
informer_1.OperationType.RENAMED,
|
|
242114
|
+
informer_1.OperationType.SYNC,
|
|
242115
|
+
informer_1.OperationType.NOTHING
|
|
242116
|
+
],
|
|
242117
|
+
"full-control": [
|
|
242118
|
+
informer_1.OperationType.UPDATED,
|
|
242119
|
+
informer_1.OperationType.CREATED,
|
|
242120
|
+
informer_1.OperationType.RENAMED,
|
|
242121
|
+
informer_1.OperationType.SYNC,
|
|
242122
|
+
informer_1.OperationType.MARKED_TO_DELETION,
|
|
242123
|
+
informer_1.OperationType.RETRY,
|
|
242124
|
+
informer_1.OperationType.NOTHING
|
|
242125
|
+
],
|
|
242126
|
+
};
|
|
242127
|
+
function policyAllowsOp(policy, op, item) {
|
|
242128
|
+
if (op === informer_1.OperationType.RETRY.toString() && exports.policies[policy].includes(op)) {
|
|
242129
|
+
if ("deletionTimestamp" in item.metadata && "full-control" !== policy) {
|
|
242130
|
+
return false;
|
|
242131
|
+
}
|
|
242132
|
+
else {
|
|
242133
|
+
return true;
|
|
242134
|
+
}
|
|
242135
|
+
}
|
|
242136
|
+
if (!exports.policies[policy])
|
|
242137
|
+
return false;
|
|
242138
|
+
return exports.policies[policy].includes(op);
|
|
242139
|
+
}
|
|
242140
|
+
exports.policyAllowsOp = policyAllowsOp;
|
|
242141
|
+
|
|
242142
|
+
|
|
242143
|
+
/***/ }),
|
|
242144
|
+
|
|
242145
|
+
/***/ 3937:
|
|
242004
242146
|
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
|
|
242005
242147
|
|
|
242006
242148
|
"use strict";
|
|
@@ -242036,38 +242178,39 @@ exports.buildProvisionerContext = exports.processOperation = void 0;
|
|
|
242036
242178
|
const informer_1 = __nccwpck_require__(41151);
|
|
242037
242179
|
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
242038
242180
|
const terraform_provisioner_1 = __nccwpck_require__(6777);
|
|
242039
|
-
const log = (0, debug_1.default)('firestartr:operator:terraform');
|
|
242040
|
-
const github_1 = __importDefault(__nccwpck_require__(39759));
|
|
242041
242181
|
const fs = __importStar(__nccwpck_require__(57147));
|
|
242042
242182
|
const path = __importStar(__nccwpck_require__(71017));
|
|
242043
|
-
const
|
|
242183
|
+
const user_feedback_ops_1 = __nccwpck_require__(36322);
|
|
242184
|
+
const policies_1 = __nccwpck_require__(31058);
|
|
242185
|
+
const log = (0, debug_1.default)('firestartr:operator:terraform');
|
|
242044
242186
|
const TF_PROJECTS_PATH = "/tmp/tfworkspaces";
|
|
242045
242187
|
function processOperation(item, op, handler) {
|
|
242046
242188
|
try {
|
|
242047
242189
|
clearLocalTfProjects();
|
|
242048
242190
|
const policy = getPolicy(item);
|
|
242049
|
-
if (policy === "observe" ||
|
|
242191
|
+
if (!policy || policy === "observe" || policy === "observe-only") {
|
|
242050
242192
|
return observe(item, op, handler);
|
|
242051
242193
|
}
|
|
242052
|
-
|
|
242053
|
-
|
|
242054
|
-
|
|
242055
|
-
|
|
242056
|
-
|
|
242057
|
-
|
|
242058
|
-
|
|
242059
|
-
|
|
242060
|
-
|
|
242061
|
-
|
|
242062
|
-
|
|
242063
|
-
|
|
242064
|
-
|
|
242065
|
-
|
|
242066
|
-
|
|
242067
|
-
|
|
242068
|
-
|
|
242069
|
-
|
|
242070
|
-
|
|
242194
|
+
if (!(0, policies_1.policyAllowsOp)(policy, op, item)) {
|
|
242195
|
+
return errorPolicyNotAllowsOp(item, op, policy, handler);
|
|
242196
|
+
}
|
|
242197
|
+
switch (op) {
|
|
242198
|
+
case informer_1.OperationType.UPDATED:
|
|
242199
|
+
return updated(item, op, handler);
|
|
242200
|
+
case informer_1.OperationType.CREATED:
|
|
242201
|
+
return created(item, op, handler);
|
|
242202
|
+
case informer_1.OperationType.RENAMED:
|
|
242203
|
+
return renamed(item, op, handler);
|
|
242204
|
+
case informer_1.OperationType.SYNC:
|
|
242205
|
+
return sync(item, op, handler);
|
|
242206
|
+
case informer_1.OperationType.MARKED_TO_DELETION:
|
|
242207
|
+
return markedToDeletion(item, op, handler);
|
|
242208
|
+
case informer_1.OperationType.RETRY:
|
|
242209
|
+
return retry(item, op, handler);
|
|
242210
|
+
case informer_1.OperationType.NOTHING:
|
|
242211
|
+
return nothing(item, op, handler);
|
|
242212
|
+
default:
|
|
242213
|
+
throw new Error(`Operation ${op} not supported`);
|
|
242071
242214
|
}
|
|
242072
242215
|
}
|
|
242073
242216
|
catch (e) {
|
|
@@ -242107,7 +242250,11 @@ async function* doPlanJSONFormat(item, op, handler) {
|
|
|
242107
242250
|
const deps = await handler.resolveReferences();
|
|
242108
242251
|
log('Item %s has the following dependencies: %O', item.metadata.name, deps);
|
|
242109
242252
|
const context = buildProvisionerContext(item, deps);
|
|
242110
|
-
|
|
242253
|
+
let planType = "plan-json";
|
|
242254
|
+
if ("deletionTimestamp" in item.metadata) {
|
|
242255
|
+
planType = "plan-destroy-json";
|
|
242256
|
+
}
|
|
242257
|
+
const tfPlan = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, planType);
|
|
242111
242258
|
if (tfPlan.summary.hasChanges()) {
|
|
242112
242259
|
yield {
|
|
242113
242260
|
item,
|
|
@@ -242116,6 +242263,7 @@ async function* doPlanJSONFormat(item, op, handler) {
|
|
|
242116
242263
|
status: "False",
|
|
242117
242264
|
message: "Plan has changes"
|
|
242118
242265
|
};
|
|
242266
|
+
policies_1.policyAllowsOp;
|
|
242119
242267
|
yield {
|
|
242120
242268
|
item,
|
|
242121
242269
|
reason: op,
|
|
@@ -242213,7 +242361,7 @@ async function* updated(item, op, handler) {
|
|
|
242213
242361
|
}
|
|
242214
242362
|
}
|
|
242215
242363
|
async function* retry(item, op, handler) {
|
|
242216
|
-
if (
|
|
242364
|
+
if (isDestroyRetry(item)) {
|
|
242217
242365
|
for await (const transition of markedToDeletion(item, op, handler)) {
|
|
242218
242366
|
yield transition;
|
|
242219
242367
|
}
|
|
@@ -242224,6 +242372,14 @@ async function* retry(item, op, handler) {
|
|
|
242224
242372
|
}
|
|
242225
242373
|
}
|
|
242226
242374
|
}
|
|
242375
|
+
function isDestroyRetry(item) {
|
|
242376
|
+
if ("deletionTimestamp" in item.metadata) {
|
|
242377
|
+
return true;
|
|
242378
|
+
}
|
|
242379
|
+
return false;
|
|
242380
|
+
}
|
|
242381
|
+
function canDestroyRetry(item, op, handler) {
|
|
242382
|
+
}
|
|
242227
242383
|
async function* sync(item, op, handler) {
|
|
242228
242384
|
yield {
|
|
242229
242385
|
item,
|
|
@@ -242246,6 +242402,20 @@ async function* sync(item, op, handler) {
|
|
|
242246
242402
|
async function* markedToDeletion(item, op, handler) {
|
|
242247
242403
|
try {
|
|
242248
242404
|
let type = "DELETING";
|
|
242405
|
+
yield {
|
|
242406
|
+
item,
|
|
242407
|
+
reason: op,
|
|
242408
|
+
type: "PROVISIONING",
|
|
242409
|
+
status: "False",
|
|
242410
|
+
message: "markedToDeletion"
|
|
242411
|
+
};
|
|
242412
|
+
yield {
|
|
242413
|
+
item,
|
|
242414
|
+
reason: op,
|
|
242415
|
+
type: "DELETED",
|
|
242416
|
+
status: "False",
|
|
242417
|
+
message: "markedToDeletion"
|
|
242418
|
+
};
|
|
242249
242419
|
yield {
|
|
242250
242420
|
item,
|
|
242251
242421
|
reason: op,
|
|
@@ -242284,7 +242454,7 @@ async function* markedToDeletion(item, op, handler) {
|
|
|
242284
242454
|
const deps = await handler.resolveReferences();
|
|
242285
242455
|
const context = buildProvisionerContext(item, deps);
|
|
242286
242456
|
const destroyOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "destroy");
|
|
242287
|
-
await
|
|
242457
|
+
await (0, user_feedback_ops_1.tryPublishDestroy)(item, destroyOutput);
|
|
242288
242458
|
yield {
|
|
242289
242459
|
item,
|
|
242290
242460
|
reason: op,
|
|
@@ -242292,6 +242462,13 @@ async function* markedToDeletion(item, op, handler) {
|
|
|
242292
242462
|
status: "False",
|
|
242293
242463
|
message: "Destroying process finished"
|
|
242294
242464
|
};
|
|
242465
|
+
yield {
|
|
242466
|
+
item,
|
|
242467
|
+
reason: op,
|
|
242468
|
+
type: "DELETED",
|
|
242469
|
+
status: "True",
|
|
242470
|
+
message: "destroyed"
|
|
242471
|
+
};
|
|
242295
242472
|
await handler.finalize(handler.pluralKind, item.metadata.namespace, item, "firestartr.dev/finalizer");
|
|
242296
242473
|
await handler.writeTerraformOutputInTfResult(item, destroyOutput);
|
|
242297
242474
|
handler.success();
|
|
@@ -242325,6 +242502,13 @@ async function* nothing(item, op, handler) {
|
|
|
242325
242502
|
*/
|
|
242326
242503
|
async function* doApply(item, op, handler) {
|
|
242327
242504
|
try {
|
|
242505
|
+
yield {
|
|
242506
|
+
item,
|
|
242507
|
+
reason: op,
|
|
242508
|
+
type: "DELETED",
|
|
242509
|
+
status: "False",
|
|
242510
|
+
message: "markedToDeletion"
|
|
242511
|
+
};
|
|
242328
242512
|
yield {
|
|
242329
242513
|
item,
|
|
242330
242514
|
reason: op,
|
|
@@ -242366,7 +242550,7 @@ async function* doApply(item, op, handler) {
|
|
|
242366
242550
|
log('Item %s has the following dependencies: %O', item.metadata.name, deps);
|
|
242367
242551
|
const context = buildProvisionerContext(item, deps);
|
|
242368
242552
|
const applyOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "apply");
|
|
242369
|
-
await tryPublishApply(item, applyOutput);
|
|
242553
|
+
await (0, user_feedback_ops_1.tryPublishApply)(item, applyOutput);
|
|
242370
242554
|
const terraformOutputJson = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "output");
|
|
242371
242555
|
if (!terraformOutputJson) {
|
|
242372
242556
|
throw new Error(`Terraform output is empty for ${item.kind}/${item.metadata.name}`);
|
|
@@ -242399,7 +242583,7 @@ async function* doApply(item, op, handler) {
|
|
|
242399
242583
|
}
|
|
242400
242584
|
catch (e) {
|
|
242401
242585
|
console.error(e);
|
|
242402
|
-
await tryPublishApply(item, e);
|
|
242586
|
+
await (0, user_feedback_ops_1.tryPublishApply)(item, e);
|
|
242403
242587
|
log("Error applying item %s: %O", item.metadata.name, e);
|
|
242404
242588
|
yield {
|
|
242405
242589
|
item,
|
|
@@ -242428,6 +242612,73 @@ async function* doApply(item, op, handler) {
|
|
|
242428
242612
|
}
|
|
242429
242613
|
}
|
|
242430
242614
|
}
|
|
242615
|
+
async function* errorPolicyNotAllowsOp(item, op, policy, handler) {
|
|
242616
|
+
const fSearchAllowedPoliciesForOp = (op) => {
|
|
242617
|
+
let allowedPolicies = [];
|
|
242618
|
+
for (const [key, value] of Object.entries(policies_1.policies)) {
|
|
242619
|
+
if (value.includes(op)) {
|
|
242620
|
+
allowedPolicies.push(key);
|
|
242621
|
+
}
|
|
242622
|
+
}
|
|
242623
|
+
if (allowedPolicies.length > 0)
|
|
242624
|
+
return allowedPolicies.join(", ");
|
|
242625
|
+
return "none";
|
|
242626
|
+
};
|
|
242627
|
+
const errorMessage = `Operation ${op} not allowed by policy \`${policy}\`, to allow this operation, switch to one of the following policies: \`${fSearchAllowedPoliciesForOp(op)}\``;
|
|
242628
|
+
const reason = "POLICY CONFLICT";
|
|
242629
|
+
await (0, user_feedback_ops_1.tryPublishError)(item, reason, errorMessage);
|
|
242630
|
+
yield {
|
|
242631
|
+
item,
|
|
242632
|
+
reason: op,
|
|
242633
|
+
type: "ERROR",
|
|
242634
|
+
status: "True",
|
|
242635
|
+
message: errorMessage
|
|
242636
|
+
};
|
|
242637
|
+
yield {
|
|
242638
|
+
item,
|
|
242639
|
+
reason: op,
|
|
242640
|
+
type: "PROVISIONED",
|
|
242641
|
+
status: "False",
|
|
242642
|
+
message: errorMessage
|
|
242643
|
+
};
|
|
242644
|
+
yield {
|
|
242645
|
+
item,
|
|
242646
|
+
reason: op,
|
|
242647
|
+
type: "PROVISIONING",
|
|
242648
|
+
status: "False",
|
|
242649
|
+
message: errorMessage
|
|
242650
|
+
};
|
|
242651
|
+
yield {
|
|
242652
|
+
item,
|
|
242653
|
+
reason: op,
|
|
242654
|
+
type: "OUT_OF_SYNC",
|
|
242655
|
+
status: "False",
|
|
242656
|
+
message: errorMessage
|
|
242657
|
+
};
|
|
242658
|
+
yield {
|
|
242659
|
+
item,
|
|
242660
|
+
reason: op,
|
|
242661
|
+
type: "DELETED",
|
|
242662
|
+
status: "False",
|
|
242663
|
+
message: errorMessage
|
|
242664
|
+
};
|
|
242665
|
+
yield {
|
|
242666
|
+
item,
|
|
242667
|
+
reason: op,
|
|
242668
|
+
type: "PLANNING",
|
|
242669
|
+
status: "False",
|
|
242670
|
+
message: errorMessage
|
|
242671
|
+
};
|
|
242672
|
+
yield {
|
|
242673
|
+
item,
|
|
242674
|
+
reason: op,
|
|
242675
|
+
type: "DELETING",
|
|
242676
|
+
status: "False",
|
|
242677
|
+
message: errorMessage
|
|
242678
|
+
};
|
|
242679
|
+
await handler.writeTerraformOutputInTfResult(item, errorMessage);
|
|
242680
|
+
handler.error();
|
|
242681
|
+
}
|
|
242431
242682
|
/**
|
|
242432
242683
|
* @description Adapts the CR to the format expected by the terraform provisioner
|
|
242433
242684
|
* @param item - CR to be applied
|
|
@@ -242619,6 +242870,23 @@ function getErrorOutputMessage(cr, key, ref) {
|
|
|
242619
242870
|
throw new Error(`â Source ${cr.spec.source} not supported`);
|
|
242620
242871
|
}
|
|
242621
242872
|
}
|
|
242873
|
+
|
|
242874
|
+
|
|
242875
|
+
/***/ }),
|
|
242876
|
+
|
|
242877
|
+
/***/ 36322:
|
|
242878
|
+
/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
|
|
242879
|
+
|
|
242880
|
+
"use strict";
|
|
242881
|
+
|
|
242882
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
242883
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
242884
|
+
};
|
|
242885
|
+
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
242886
|
+
exports.publishError = exports.tryPublishError = exports.publishApply = exports.tryPublishDestroy = exports.tryPublishApply = void 0;
|
|
242887
|
+
const github_1 = __importDefault(__nccwpck_require__(39759));
|
|
242888
|
+
const debug_1 = __importDefault(__nccwpck_require__(67984));
|
|
242889
|
+
const log = (0, debug_1.default)('firestartr:operator:terraform');
|
|
242622
242890
|
async function tryPublishApply(item, planOutput) {
|
|
242623
242891
|
try {
|
|
242624
242892
|
if (!("firestartr.dev/last-state-pr" in item.metadata.annotations)) {
|
|
@@ -242631,7 +242899,63 @@ async function tryPublishApply(item, planOutput) {
|
|
|
242631
242899
|
log(`Error publishing apply: ${e}`);
|
|
242632
242900
|
}
|
|
242633
242901
|
}
|
|
242902
|
+
exports.tryPublishApply = tryPublishApply;
|
|
242903
|
+
async function tryPublishDestroy(item, destroyOutput) {
|
|
242904
|
+
try {
|
|
242905
|
+
log("Trying to publish destroy");
|
|
242906
|
+
const { repo, org } = extractPrInfo(item);
|
|
242907
|
+
const lastPr = await github_1.default.pulls.filterPrBy({
|
|
242908
|
+
title: `hydrate: ${item.metadata.name}`,
|
|
242909
|
+
state: 'closed',
|
|
242910
|
+
repo,
|
|
242911
|
+
owner: org,
|
|
242912
|
+
userType: 'Bot'
|
|
242913
|
+
}, {
|
|
242914
|
+
maxRetries: 3
|
|
242915
|
+
});
|
|
242916
|
+
if (!lastPr) {
|
|
242917
|
+
log(`CR ${item.metadata.name} has no last state PR. Skipping terraform destroy publish.`);
|
|
242918
|
+
return;
|
|
242919
|
+
}
|
|
242920
|
+
const comment = `<h1>
|
|
242921
|
+
<img width="25" src="https://static-00.iconduck.com/assets.00/file-type-terraform-icon-1821x2048-mbxeegff.png"> Terraform destroy
|
|
242922
|
+
</h1>
|
|
242923
|
+
<p><b>TFWorkspace: </b>${item.metadata.name}</p>
|
|
242924
|
+
|
|
242925
|
+
<details id=github>
|
|
242926
|
+
<summary>DESTROY LOGS</summary>
|
|
242927
|
+
|
|
242928
|
+
\`\`\`shell
|
|
242929
|
+
${destroyOutput}
|
|
242930
|
+
\`\`\`
|
|
242931
|
+
</details>`;
|
|
242932
|
+
log("Publishing comment in PR number: ", lastPr.number);
|
|
242933
|
+
await github_1.default.pulls.commentInPR(comment, lastPr.number, repo, org);
|
|
242934
|
+
log("Published destroy comment in PR number: ", lastPr.number);
|
|
242935
|
+
}
|
|
242936
|
+
catch (e) {
|
|
242937
|
+
log(`Error publishing apply: ${e}`);
|
|
242938
|
+
}
|
|
242939
|
+
}
|
|
242940
|
+
exports.tryPublishDestroy = tryPublishDestroy;
|
|
242634
242941
|
async function publishApply(item, applyOutput) {
|
|
242942
|
+
const { prNumber, repo, org } = extractPrInfo(item);
|
|
242943
|
+
const comment = `<h1>
|
|
242944
|
+
<img width="25" src="https://static-00.iconduck.com/assets.00/file-type-terraform-icon-1821x2048-mbxeegff.png"> Terraform apply
|
|
242945
|
+
</h1>
|
|
242946
|
+
<p><b>TFWorkspace: </b>${item.metadata.name}</p>
|
|
242947
|
+
|
|
242948
|
+
<details id=github>
|
|
242949
|
+
<summary>APPLY LOGS</summary>
|
|
242950
|
+
|
|
242951
|
+
\`\`\`shell
|
|
242952
|
+
${applyOutput}
|
|
242953
|
+
\`\`\`
|
|
242954
|
+
</details>`;
|
|
242955
|
+
await github_1.default.pulls.commentInPR(comment, parseInt(prNumber), repo, org);
|
|
242956
|
+
}
|
|
242957
|
+
exports.publishApply = publishApply;
|
|
242958
|
+
function extractPrInfo(item) {
|
|
242635
242959
|
const prInfo = item.metadata.annotations["firestartr.dev/last-state-pr"];
|
|
242636
242960
|
const prNumber = prInfo.split("#")[1];
|
|
242637
242961
|
if (!prNumber)
|
|
@@ -242642,20 +242966,27 @@ async function publishApply(item, applyOutput) {
|
|
|
242642
242966
|
const repo = prInfo.split("#")[0].split("/")[1];
|
|
242643
242967
|
if (!repo)
|
|
242644
242968
|
throw new Error("No repo found in CR");
|
|
242645
|
-
|
|
242646
|
-
|
|
242647
|
-
|
|
242648
|
-
|
|
242649
|
-
|
|
242650
|
-
|
|
242651
|
-
|
|
242652
|
-
|
|
242653
|
-
|
|
242654
|
-
|
|
242655
|
-
|
|
242656
|
-
|
|
242969
|
+
return { prNumber, repo, org };
|
|
242970
|
+
}
|
|
242971
|
+
async function tryPublishError(item, reason, message) {
|
|
242972
|
+
try {
|
|
242973
|
+
await publishError(item, reason, message);
|
|
242974
|
+
}
|
|
242975
|
+
catch (e) {
|
|
242976
|
+
log(`Error publishing warning: ${e}`);
|
|
242977
|
+
}
|
|
242978
|
+
}
|
|
242979
|
+
exports.tryPublishError = tryPublishError;
|
|
242980
|
+
async function publishError(item, reason, message) {
|
|
242981
|
+
const { prNumber, repo, org } = extractPrInfo(item);
|
|
242982
|
+
const comment = `# â Error on claim ${item.metadata.annotations["firestartr.dev/claim-ref"].split("/")[1]}
|
|
242983
|
+
### đ Reason: ${reason}
|
|
242984
|
+
#### âšī¸ Details:
|
|
242985
|
+
${message}
|
|
242986
|
+
`;
|
|
242657
242987
|
await github_1.default.pulls.commentInPR(comment, parseInt(prNumber), repo, org);
|
|
242658
242988
|
}
|
|
242989
|
+
exports.publishError = publishError;
|
|
242659
242990
|
|
|
242660
242991
|
|
|
242661
242992
|
/***/ }),
|
|
@@ -243864,6 +244195,12 @@ async function execCommand(command, tfProject) {
|
|
|
243864
244195
|
case "apply":
|
|
243865
244196
|
await tfProject.apply();
|
|
243866
244197
|
break;
|
|
244198
|
+
case "plan-destroy":
|
|
244199
|
+
await tfProject.planDestroy("human");
|
|
244200
|
+
break;
|
|
244201
|
+
case "plan-destroy-json":
|
|
244202
|
+
await tfProject.planDestroy("json");
|
|
244203
|
+
break;
|
|
243867
244204
|
case "destroy":
|
|
243868
244205
|
await tfProject.destroy();
|
|
243869
244206
|
break;
|
|
@@ -243965,6 +244302,12 @@ class TFProjectManager {
|
|
|
243965
244302
|
this.tfOutput = null;
|
|
243966
244303
|
this.tfOutput = await (0, utils_1.plan)(this.projectPath, this.secrets, format);
|
|
243967
244304
|
}
|
|
244305
|
+
async planDestroy(format) {
|
|
244306
|
+
await this.__init();
|
|
244307
|
+
if (format == "json")
|
|
244308
|
+
this.tfOutput = null;
|
|
244309
|
+
this.tfOutput = await (0, utils_1.plan)(this.projectPath, this.secrets, format, ["plan", "-destroy"]);
|
|
244310
|
+
}
|
|
243968
244311
|
async apply() {
|
|
243969
244312
|
await this.__init();
|
|
243970
244313
|
this.tfOutput += await (0, utils_1.apply)(this.projectPath, this.secrets);
|
|
@@ -244389,8 +244732,8 @@ async function initFromModule(path, source, secrets) {
|
|
|
244389
244732
|
], secrets, []);
|
|
244390
244733
|
}
|
|
244391
244734
|
exports.initFromModule = initFromModule;
|
|
244392
|
-
async function plan(path, secrets, format) {
|
|
244393
|
-
const plan = await tfExec(path,
|
|
244735
|
+
async function plan(path, secrets, format, args = ["plan"]) {
|
|
244736
|
+
const plan = await tfExec(path, args
|
|
244394
244737
|
.concat(format == "json" ?
|
|
244395
244738
|
["-json"]
|
|
244396
244739
|
:
|