@firestartr/cli 0.1.9 → 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.
Files changed (38) hide show
  1. package/build/index.js +569 -193
  2. package/build/provisioner/cdktf.json +0 -0
  3. package/build/provisioner/dist-cdktf/index.js +34 -2
  4. package/build/provisioner/dist-cdktf/index.js.map +1 -1
  5. package/build/provisioner/dist-cdktf/tsconfig.cdktf.tsbuildinfo +1 -1
  6. package/package.json +1 -1
  7. package/build/provisioner/dist-cdktf/src/entities/feature/FirestarterGithubRepositoryFeature.d.ts +0 -8
  8. package/build/provisioner/dist-cdktf/src/entities/feature/FirestarterGithubRepositoryFeature.js +0 -15
  9. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/FirestarterGithubGroup.d.ts +0 -8
  10. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/FirestarterGithubGroup.js +0 -17
  11. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/auxiliars/TeamConfigAux.d.ts +0 -29
  12. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/auxiliars/TeamConfigAux.js +0 -35
  13. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/helpers/TeamMembersHelper.d.ts +0 -4
  14. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/helpers/TeamMembersHelper.js +0 -28
  15. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/helpers/TeamsHelper.d.ts +0 -4
  16. package/build/provisioner/dist-cdktf/src/entities/firestartergithubgroup/helpers/TeamsHelper.js +0 -23
  17. package/build/provisioner/dist-cdktf/src/entities/firestartergithubmembership/FirestarterGithubMembership.d.ts +0 -8
  18. package/build/provisioner/dist-cdktf/src/entities/firestartergithubmembership/FirestarterGithubMembership.js +0 -15
  19. package/build/provisioner/dist-cdktf/src/entities/firestartergithubmembership/helpers/MembershipHelper.d.ts +0 -4
  20. package/build/provisioner/dist-cdktf/src/entities/firestartergithubmembership/helpers/MembershipHelper.js +0 -19
  21. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/FirestarterGithubRepository.d.ts +0 -9
  22. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/FirestarterGithubRepository.js +0 -30
  23. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/auxiliars/RepositoryConfigAux.d.ts +0 -52
  24. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/auxiliars/RepositoryConfigAux.js +0 -72
  25. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/ActionsHelper.d.ts +0 -5
  26. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/ActionsHelper.js +0 -19
  27. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/CodeownersHelper.d.ts +0 -5
  28. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/CodeownersHelper.js +0 -24
  29. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/DefaultBranchHelper.d.ts +0 -5
  30. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/DefaultBranchHelper.js +0 -17
  31. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/RepositoryHelper.d.ts +0 -5
  32. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/RepositoryHelper.js +0 -72
  33. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/RepositoryTeamsHelper.d.ts +0 -4
  34. package/build/provisioner/dist-cdktf/src/entities/firestartergithubrepository/helpers/RepositoryTeamsHelper.js +0 -49
  35. package/build/provisioner/dist-cdktf/src/entities/firestarterterraformmodule/FirestarterTerraformModule.d.ts +0 -10
  36. package/build/provisioner/dist-cdktf/src/entities/firestarterterraformmodule/FirestarterTerraformModule.js +0 -17
  37. package/build/provisioner/dist-cdktf/src/entities/firestarterterraformmodule/auxiliars/terraformModuleHelper.d.ts +0 -13
  38. package/build/provisioner/dist-cdktf/src/entities/firestarterterraformmodule/auxiliars/terraformModuleHelper.js +0 -36
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLnNjaGVtYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jbGFpbXMvdGZ3b3Jrc3BhY2VzL3RlcnJhZm9ybS5zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxrQkFBZTtJQUVYLFNBQVMsRUFBRSx5Q0FBeUM7SUFFcEQsS0FBSyxFQUFFLG1CQUFtQjtJQUUxQixhQUFhLEVBQUU7UUFFYixtQkFBbUIsRUFBRTtZQUVuQixLQUFLLEVBQUUsOENBQThDO1lBRXJELE1BQU0sRUFBRSxRQUFRO1lBRWhCLGFBQWEsRUFBRSx1QkFBdUI7WUFFdEMsT0FBTyxFQUFFO2dCQUVQLEVBQUMsTUFBTSxFQUFFLCtDQUErQyxFQUFDO2dCQUV6RDtvQkFDRSxNQUFNLEVBQUUsUUFBUTtvQkFFaEIsWUFBWSxFQUFFO3dCQUVaLE1BQU0sRUFBRTs0QkFFTixNQUFNLEVBQUUsUUFBUTt5QkFDakI7d0JBRUQsUUFBUSxFQUFFOzRCQUVSLE1BQU0sRUFBRSxRQUFROzRCQUVoQixNQUFNLEVBQUUsQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxRQUFRLENBQUM7eUJBRWpEO3dCQUVELGNBQWMsRUFBRTs0QkFFZCxNQUFNLEVBQUUsUUFBUTs0QkFFaEIsYUFBYSxFQUFFLGdEQUFnRDt5QkFFaEU7d0JBRUQsUUFBUSxFQUFDOzRCQUVQLE1BQU0sRUFBRSxRQUFROzRCQUVoQixZQUFZLEVBQUUsRUFBRTs0QkFFaEIsc0JBQXNCLEVBQUUsSUFBSTt5QkFFN0I7d0JBRUQsUUFBUSxFQUFFOzRCQUVSLE1BQU0sRUFBRSxRQUFRO3lCQUVqQjt3QkFFRCxTQUFTLEVBQUU7NEJBRVQsTUFBTSxFQUFFLFFBQVE7NEJBRWhCLFlBQVksRUFBRTtnQ0FFWixXQUFXLEVBQUU7b0NBRVgsTUFBTSxFQUFFLE9BQU87b0NBRWYsT0FBTyxFQUFFO3dDQUVQLE1BQU0sRUFBRSxRQUFRO3dDQUVoQixZQUFZLEVBQUU7NENBRVosTUFBTSxFQUFFO2dEQUVOLE1BQU0sRUFBRSxRQUFROzZDQUNqQjt5Q0FFRjt3Q0FFRCxzQkFBc0IsRUFBRSxLQUFLO3FDQUU5QjtpQ0FFRjtnQ0FFRCxTQUFTLEVBQUU7b0NBRVQsTUFBTSxFQUFFLFFBQVE7b0NBRWhCLFlBQVksRUFBRTt3Q0FFWixNQUFNLEVBQUU7NENBRU4sTUFBTSxFQUFFLFFBQVE7eUNBQ2pCO3FDQUVGO29DQUVELHNCQUFzQixFQUFFLEtBQUs7aUNBQzlCOzZCQUVGOzRCQUVELFVBQVUsRUFBRSxDQUFDLFdBQVcsQ0FBQzs0QkFFekIsc0JBQXNCLEVBQUUsS0FBSzt5QkFFOUI7cUJBRUY7b0JBRUQsVUFBVSxFQUFFLENBQUMsUUFBUSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDO2lCQUVwRDthQUVGO1NBRUY7S0FDRjtDQUNKLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCB7XG5cbiAgICBcIiRzY2hlbWFcIjogXCJodHRwOi8vanNvbi1zY2hlbWEub3JnL2RyYWZ0LTA3L3NjaGVtYSNcIixcblxuICAgIFwiJGlkXCI6IFwiVGVycmFmb3JtUHJvdmlkZXJcIixcblxuICAgIFwiZGVmaW5pdGlvbnNcIjoge1xuXG4gICAgICBcIlRlcnJhZm9ybVByb3ZpZGVyXCI6IHtcblxuICAgICAgICBcIiRpZFwiOiBcImZpcmVzdGFydHIuZGV2Oi8vdGVycmFmb3JtL1RlcnJhZm9ybVByb3ZpZGVyXCIsXG5cbiAgICAgICAgXCJ0eXBlXCI6IFwib2JqZWN0XCIsXG5cbiAgICAgICAgXCJkZXNjcmlwdGlvblwiOiBcIkEgdGVycmFmb3JtIHdvcmtzcGFjZVwiLFxuXG4gICAgICAgIFwiYWxsT2ZcIjogW1xuXG4gICAgICAgICAge1wiJHJlZlwiOiBcImZpcmVzdGFydHIuZGV2Oi8vY29tbW9uL0NsYWltUHJvdmlkZXJFbnZlbG9wZVwifSxcblxuICAgICAgICAgIHtcbiAgICAgICAgICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuXG4gICAgICAgICAgICBcInByb3BlcnRpZXNcIjoge1xuXG4gICAgICAgICAgICAgIFwibmFtZVwiOiB7XG4gICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgIFwic291cmNlXCI6IHtcblxuICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcInN0cmluZ1wiLFxuXG4gICAgICAgICAgICAgICAgXCJlbnVtXCI6IFtcInJlbW90ZVwiLCBcImlubGluZVwiLCBcIlJlbW90ZVwiLCBcIklubGluZVwiXVxuXG4gICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgXCJ2YWx1ZXNTY2hlbWFcIjoge1xuICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIixcblxuICAgICAgICAgICAgICAgIFwiZGVzY3JpcHRpb25cIjogXCJhIGxvY2F0b3IgZm9yIGEganNvbiBzY2hlbWEgdG8gdmFsaWRhdGUgdmFsdWVzXCJcbiAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgXCJ2YWx1ZXNcIjp7XG5cbiAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJvYmplY3RcIixcblxuICAgICAgICAgICAgICAgIFwicHJvcGVydGllc1wiOiB7fSxcblxuICAgICAgICAgICAgICAgIFwiYWRkaXRpb25hbFByb3BlcnRpZXNcIjogdHJ1ZVxuXG4gICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgXCJtb2R1bGVcIjoge1xuICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIlxuICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgfSxcblxuICAgICAgICAgICAgICBcImNvbnRleHRcIjoge1xuXG4gICAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwib2JqZWN0XCIsXG5cbiAgICAgICAgICAgICAgICBcInByb3BlcnRpZXNcIjoge1xuICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgXCJwcm92aWRlcnNcIjoge1xuICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcImFycmF5XCIsXG5cbiAgICAgICAgICAgICAgICAgICAgXCJpdGVtc1wiOiB7XG4gICAgICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuXG4gICAgICAgICAgICAgICAgICAgICAgXCJwcm9wZXJ0aWVzXCI6IHtcbiAgICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgICAgIFwibmFtZVwiOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgXCJ0eXBlXCI6IFwic3RyaW5nXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgICAgICAgICAgXCJhZGRpdGlvbmFsUHJvcGVydGllc1wiOiBmYWxzZVxuICAgICAgICAgICAgICAgICAgICBcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICB9LFxuXG4gICAgICAgICAgICAgICAgICBcImJhY2tlbmRcIjoge1xuICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIFwidHlwZVwiOiBcIm9iamVjdFwiLFxuXG4gICAgICAgICAgICAgICAgICAgIFwicHJvcGVydGllc1wiOiB7XG4gICAgICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgICAgICAgIFwibmFtZVwiOiB7XG4gICAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgICAgICBcInR5cGVcIjogXCJzdHJpbmdcIlxuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgXG4gICAgICAgICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgICAgICAgXCJhZGRpdGlvbmFsUHJvcGVydGllc1wiOiBmYWxzZVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIFxuICAgICAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgICAgICBcInJlcXVpcmVkXCI6IFtcInByb3ZpZGVyc1wiXSxcblxuICAgICAgICAgICAgICAgIFwiYWRkaXRpb25hbFByb3BlcnRpZXNcIjogZmFsc2VcblxuICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIH0sXG5cbiAgICAgICAgICAgIFwicmVxdWlyZWRcIjogW1widmFsdWVzXCIsIFwiY29udGV4dFwiLCBcInNvdXJjZVwiLCBcIm5hbWVcIl1cblxuICAgICAgICAgIH1cblxuICAgICAgICBdXG5cbiAgICAgIH1cbiAgICB9XG59XG4iXX0=
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
  /*
@@ -235382,6 +235387,7 @@ async function render(catalogScope, firestartrScope) {
235382
235387
  const data = await (0, loader_1.loadAll)();
235383
235388
  const result = await fRenderClaims(catalogScope, firestartrScope, data);
235384
235389
  (0, references_1.validateReferentialIntegrity)(result);
235390
+ (0, references_1.validateTfStateKeyUniqueness)(result);
235385
235391
  return result;
235386
235392
  }
235387
235393
  exports.render = render;
@@ -235389,7 +235395,21 @@ exports.render = render;
235389
235395
  * Function called when rendering Terraform workspaces Plans
235390
235396
  * based on the previous renderer Terraform workspaces
235391
235397
  */
235392
- 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
+ }
235393
235413
  // Iterate over the source folder and get the list of Terraform workspaces
235394
235414
  await (0, crawler_1.crawl)(source, () => true, (entry, data) => {
235395
235415
  const fileName = path_1.default.join(destiny, path_1.default.basename(entry));
@@ -235581,7 +235601,7 @@ function getPreviousCRfromClaim(claim, previousCRs) {
235581
235601
  function isExcludedFromPreviousCR(crKind) {
235582
235602
  return ["FirestartrGithubRepositoryFeature"].includes(crKind);
235583
235603
  }
235584
- //# 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 } 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  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"]}
235585
235605
 
235586
235606
  /***/ }),
235587
235607
 
@@ -236064,7 +236084,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
236064
236084
  return (mod && mod.__esModule) ? mod : { "default": mod };
236065
236085
  };
236066
236086
  Object.defineProperty(exports, "__esModule", ({ value: true }));
236067
- exports.isCatalogEntity = exports.validateReferentialIntegrity = void 0;
236087
+ exports.isCatalogEntity = exports.validateTfStateKeyUniqueness = exports.validateReferentialIntegrity = void 0;
236068
236088
  const config_1 = __nccwpck_require__(56600);
236069
236089
  const lodash_1 = __importDefault(__nccwpck_require__(78018));
236070
236090
  const wellKnownStructures_1 = __nccwpck_require__(67482);
@@ -236112,6 +236132,35 @@ function validateReferentialIntegrity(crs) {
236112
236132
  }
236113
236133
  }
236114
236134
  exports.validateReferentialIntegrity = validateReferentialIntegrity;
236135
+ function validateTfStateKeyUniqueness(crs) {
236136
+ const tfStateKeys = {};
236137
+ for (const crKey of Object.keys(crs)) {
236138
+ const cr = crs[crKey];
236139
+ if (!isTerraformWorkspace(cr))
236140
+ continue;
236141
+ const tfKey = cr.spec.firestartr.tfStateKey;
236142
+ if (tfStateKeys[tfKey]) {
236143
+ throw new Error(`❗❗ ❌ RENDER ERROR ❌ ❗❗
236144
+
236145
+ The tfStateKey ${tfKey} is not unique,
236146
+
236147
+ It is being used by the following CRs:
236148
+
236149
+ - ${tfStateKeys[tfKey].kind} ${tfStateKeys[tfKey].metadata.name}
236150
+
236151
+ - ${cr.kind} ${cr.metadata.name}
236152
+
236153
+ Check the following Claims to ensure that the tfStateKey is unique:
236154
+
236155
+ - ${tfStateKeys[tfKey].metadata.annotations["firestartr.dev/claim-ref"]}
236156
+
236157
+ - ${cr.metadata.annotations["firestartr.dev/claim-ref"]}
236158
+ `);
236159
+ }
236160
+ tfStateKeys[cr.spec.firestartr.tfStateKey] = cr;
236161
+ }
236162
+ }
236163
+ exports.validateTfStateKeyUniqueness = validateTfStateKeyUniqueness;
236115
236164
  /**
236116
236165
  * @description This function validates that all references in the CR are valid,
236117
236166
  * it uses the wellknownRelations object to know which properties to validate
@@ -236216,7 +236265,10 @@ function isCatalogEntity(cr) {
236216
236265
  ].includes(cr.kind);
236217
236266
  }
236218
236267
  exports.isCatalogEntity = isCatalogEntity;
236219
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"references.js","sourceRoot":"","sources":["../../../src/validations/references.ts"],"names":[],"mappings":"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","sourcesContent":["import { getConfiguredProvider, AllowedProviders } from \"../config\";\nimport _ from \"lodash\";\nimport { isCollaborator } from \"./wellKnownStructures\";\n\n/**\n * @description This object contains the well known relations between CRs\n * The key is the kind of the CR and the value is an array of properties that are references to other CRs\n * The value is the path to the property in the CR\n */\nconst WELL_KNOWN_RELATIONS: any = {\n  \"FirestartrGithubGroup\": [ \"spec.members\" ],\n  \"FirestartrGithubRepository\": [ \"spec.permissions\" ],\n  \"FirestartrGithubMembership\": [],\n  \"FiresarterTerraformWorkspace\": [],\n};\n\n/**\n * @description This object contains the well known relations between CRs in the catalog repo\n * The key is the kind of the CR and the value is an array of properties that are references to other CRs\n * The value is the path to the property in the CR\n */\nconst WELL_KNOWN_RELATIONS_CATALOG: any = {\n  \"Component\": [ \"spec.owner\", \"spec.system\" ],\n  \"Domain\": [ \"spec.owner\" ],\n  \"Resource\": [\"spec.owner\", \"spec.system\", \"spec.dependencyOf\", \"spec.dependsOn\"],\n  \"Group\": [ \"spec.children\", \"spec.members\", \"spec.parent\" ],\n  \"System\": [ \"spec.domain\", \"spec.owner\" ],\n  \"User\": [],\n};\n\n/**\n * @description This object maps the kind of the CR to the kind of the claim\n * This will be used for feedback messages to final users\n */\nconst MAP_KIND_CR_TO_CLAIM: any = {\n  \"FirestartrGithubGroup\": \"group\",\n  \"FirestartrGithubRepository\": \"repository\",\n  \"FirestartrGithubMembership\": \"user\",\n  \"FirestartrTerraformWorkspace\": \"tfworkspace\",\n};\n\n\n/**\n * @description This function validates that all references in the CRs are valid\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nexport function validateReferentialIntegrity(crs: any) {\n  for(const crKey of Object.keys(crs)){\n    validateReferencesInCR(crs[crKey], crs)\n  }\n}\n\n\n/**\n * @description This function validates that all references in the CR are valid,\n * it uses the wellknownRelations object to know which properties to validate\n * @param cr The cr to validate\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nfunction validateReferencesInCR(cr: any, crs: any) {\n  if(isCatalogEntity(cr)) {\n    if(getConfiguredProvider() === AllowedProviders.catalog) {\n      validateCatalogEntities(cr, crs);\n    }\n  } else {\n    validateNonCatalogEntities(cr, crs);\n  }\n}\n\n\nfunction throwIfRefNotFound(crs: any, refObj: any, refStr: string, crStr: string) {\n  const refKey = `${refObj.kind}-${refObj.name}`\n\n  if(!crs[refKey]){\n    throw new Error(\n      `Error: Reference \"${refStr}\" in claim for ${crStr} not found`\n    )\n  }\n}\n\n\n/*\n * @description This function validates non catalog entities, using the\n * WELL_KNOWN_RELATIONS object to know which fields to validate.\n * It returns nothing and throws an error if a reference is not found.\n *\n * @param cr The cr to validate\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nfunction validateNonCatalogEntities(cr: any, crs: any) {\n  for(const rel of WELL_KNOWN_RELATIONS[cr.kind] || []){\n    const propertyRef = _.get(cr, rel);\n\n    if(!propertyRef) {\n      throw new Error(\n        `CR ${cr.kind} ${cr.metadata.name} does not have property ${rel}`\n      )\n    }\n\n    if(!Array.isArray(propertyRef)) {\n\n      if(isCollaborator(propertyRef)) {\n        continue;\n      }\n\n      throwIfRefNotFound(\n        crs,\n        propertyRef,\n        `${MAP_KIND_CR_TO_CLAIM[propertyRef.kind]}:${propertyRef.name}`,\n        `${cr.kind}-${cr.metadata.name}`,\n      )\n    } else {\n      for(const propertyRel of propertyRef){\n\n        if(isCollaborator(propertyRel)) {\n          continue;\n        }\n\n        throwIfRefNotFound(\n          crs,\n          propertyRel.ref,\n          `${MAP_KIND_CR_TO_CLAIM[propertyRel.ref.kind]}:${propertyRel.ref.name}`,\n          `${cr.kind}-${cr.metadata.name}`,\n        )\n      }\n    }\n  }\n}\n\n\n/*\n * @description This function validates catalog entities, using the\n * WELL_KNOWN_RELATIONS_CATALOG object to know which fields to validate.\n * It returns nothing and throws an error if a reference is not found.\n *\n * @param cr The cr to validate\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nfunction validateCatalogEntities(cr: any, crs: any) {\n  for(const rel of WELL_KNOWN_RELATIONS_CATALOG[cr.kind]){\n    if(_.has(cr, rel)) {\n      const refObject = _.get(cr, rel);\n\n      if(!Array.isArray(refObject)) {\n        const propertyRef: any = createCatalogEntityPropertyRef(refObject);\n        throwIfRefNotFound(\n          crs,\n          propertyRef,\n          `${propertyRef.kind.toLowerCase()}:${propertyRef.name}`,\n          `${cr.kind}-${cr.name}`,\n        )\n      } else {\n        for(const refEntry of refObject){\n          const propertyRef: any = createCatalogEntityPropertyRef(refEntry);\n          throwIfRefNotFound(\n            crs,\n            propertyRef,\n            `${propertyRef.kind.toLowerCase()}:${propertyRef.name}`,\n            `${cr.kind}-${cr.name}`,\n          )\n        }\n      }\n    }\n  }\n}\n\n/*\n * @description When dealing with catalog entities, their references are stored\n * as a string in the \"[kind]:[name]\" format. This function transforms those strings\n * into a reference in the { kind: [kind], name: [name] } format\n *\n * @param refString The string to transform. Must be in the \"[kind]:[name]\" format\n */\nfunction createCatalogEntityPropertyRef(refString: string): any {\n  const splittedRefString: string[] = refString.split(\":\");\n  return {\n    // The kind string needs to be capitalized\n    kind:\n      splittedRefString[0].substring(0, 1).toUpperCase() +\n      splittedRefString[0].substring(1).toLowerCase(),\n    name: splittedRefString[1],\n  }\n}\n\nexport function isCatalogEntity(cr: any): boolean {\n  return [\n    \"Component\", \n    \"Domain\", \n    \"System\", \n    \"User\", \n    \"Group\", \n    \"Resource\"\n  ].includes(cr.kind)\n}\n"]}
236268
+ function isTerraformWorkspace(cr) {
236269
+ return cr.kind === "FirestartrTerraformWorkspace";
236270
+ }
236271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"references.js","sourceRoot":"","sources":["../../../src/validations/references.ts"],"names":[],"mappings":"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","sourcesContent":["import { getConfiguredProvider, AllowedProviders } from \"../config\";\nimport _ from \"lodash\";\nimport { isCollaborator } from \"./wellKnownStructures\";\n\n/**\n * @description This object contains the well known relations between CRs\n * The key is the kind of the CR and the value is an array of properties that are references to other CRs\n * The value is the path to the property in the CR\n */\nconst WELL_KNOWN_RELATIONS: any = {\n  \"FirestartrGithubGroup\": [ \"spec.members\" ],\n  \"FirestartrGithubRepository\": [ \"spec.permissions\" ],\n  \"FirestartrGithubMembership\": [],\n  \"FiresarterTerraformWorkspace\": [],\n};\n\n/**\n * @description This object contains the well known relations between CRs in the catalog repo\n * The key is the kind of the CR and the value is an array of properties that are references to other CRs\n * The value is the path to the property in the CR\n */\nconst WELL_KNOWN_RELATIONS_CATALOG: any = {\n  \"Component\": [ \"spec.owner\", \"spec.system\" ],\n  \"Domain\": [ \"spec.owner\" ],\n  \"Resource\": [\"spec.owner\", \"spec.system\", \"spec.dependencyOf\", \"spec.dependsOn\"],\n  \"Group\": [ \"spec.children\", \"spec.members\", \"spec.parent\" ],\n  \"System\": [ \"spec.domain\", \"spec.owner\" ],\n  \"User\": [],\n};\n\n/**\n * @description This object maps the kind of the CR to the kind of the claim\n * This will be used for feedback messages to final users\n */\nconst MAP_KIND_CR_TO_CLAIM: any = {\n  \"FirestartrGithubGroup\": \"group\",\n  \"FirestartrGithubRepository\": \"repository\",\n  \"FirestartrGithubMembership\": \"user\",\n  \"FirestartrTerraformWorkspace\": \"tfworkspace\",\n};\n\n\n/**\n * @description This function validates that all references in the CRs are valid\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nexport function validateReferentialIntegrity(crs: any) {\n  for(const crKey of Object.keys(crs)){\n    validateReferencesInCR(crs[crKey], crs)\n  }\n}\n\nexport function validateTfStateKeyUniqueness(crs: any) {\n  \n  const tfStateKeys: { [key: string]: any } = {};\n\n  for(const crKey of Object.keys(crs)){\n    \n    const cr = crs[crKey];\n    \n    if(!isTerraformWorkspace(cr)) continue\n    \n    const tfKey = cr.spec.firestartr.tfStateKey;\n      \n    if(tfStateKeys[tfKey]) {\n    \n      throw new Error(\n    \n`❗❗ ❌ RENDER ERROR ❌ ❗❗\n\nThe tfStateKey ${tfKey} is not unique,\n\nIt is being used by the following CRs:\n\n- ${tfStateKeys[tfKey].kind} ${tfStateKeys[tfKey].metadata.name}\n\n- ${cr.kind} ${cr.metadata.name}\n\nCheck the following Claims to ensure that the tfStateKey is unique:\n\n- ${tfStateKeys[tfKey].metadata.annotations[\"firestartr.dev/claim-ref\"]}\n\n- ${cr.metadata.annotations[\"firestartr.dev/claim-ref\"]}\n`\n      )\n    \n    }\n      \n    tfStateKeys[cr.spec.firestartr.tfStateKey] = cr\n  }\n}\n\n\n/**\n * @description This function validates that all references in the CR are valid,\n * it uses the wellknownRelations object to know which properties to validate\n * @param cr The cr to validate\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nfunction validateReferencesInCR(cr: any, crs: any) {\n  if(isCatalogEntity(cr)) {\n    if(getConfiguredProvider() === AllowedProviders.catalog) {\n      validateCatalogEntities(cr, crs);\n    }\n  } else {\n    validateNonCatalogEntities(cr, crs);\n  }\n}\n\n\nfunction throwIfRefNotFound(crs: any, refObj: any, refStr: string, crStr: string) {\n  const refKey = `${refObj.kind}-${refObj.name}`\n\n  if(!crs[refKey]){\n    throw new Error(\n      `Error: Reference \"${refStr}\" in claim for ${crStr} not found`\n    )\n  }\n}\n\n\n/*\n * @description This function validates non catalog entities, using the\n * WELL_KNOWN_RELATIONS object to know which fields to validate.\n * It returns nothing and throws an error if a reference is not found.\n *\n * @param cr The cr to validate\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nfunction validateNonCatalogEntities(cr: any, crs: any) {\n  for(const rel of WELL_KNOWN_RELATIONS[cr.kind] || []){\n    const propertyRef = _.get(cr, rel);\n\n    if(!propertyRef) {\n      throw new Error(\n        `CR ${cr.kind} ${cr.metadata.name} does not have property ${rel}`\n      )\n    }\n\n    if(!Array.isArray(propertyRef)) {\n\n      if(isCollaborator(propertyRef)) {\n        continue;\n      }\n\n      throwIfRefNotFound(\n        crs,\n        propertyRef,\n        `${MAP_KIND_CR_TO_CLAIM[propertyRef.kind]}:${propertyRef.name}`,\n        `${cr.kind}-${cr.metadata.name}`,\n      )\n    } else {\n      for(const propertyRel of propertyRef){\n\n        if(isCollaborator(propertyRel)) {\n          continue;\n        }\n\n        throwIfRefNotFound(\n          crs,\n          propertyRel.ref,\n          `${MAP_KIND_CR_TO_CLAIM[propertyRel.ref.kind]}:${propertyRel.ref.name}`,\n          `${cr.kind}-${cr.metadata.name}`,\n        )\n      }\n    }\n  }\n}\n\n\n/*\n * @description This function validates catalog entities, using the\n * WELL_KNOWN_RELATIONS_CATALOG object to know which fields to validate.\n * It returns nothing and throws an error if a reference is not found.\n *\n * @param cr The cr to validate\n * @param crs The crs object is a map of crs where the key is the kind and metada.name of the cr\n */\nfunction validateCatalogEntities(cr: any, crs: any) {\n  for(const rel of WELL_KNOWN_RELATIONS_CATALOG[cr.kind]){\n    if(_.has(cr, rel)) {\n      const refObject = _.get(cr, rel);\n\n      if(!Array.isArray(refObject)) {\n        const propertyRef: any = createCatalogEntityPropertyRef(refObject);\n        throwIfRefNotFound(\n          crs,\n          propertyRef,\n          `${propertyRef.kind.toLowerCase()}:${propertyRef.name}`,\n          `${cr.kind}-${cr.name}`,\n        )\n      } else {\n        for(const refEntry of refObject){\n          const propertyRef: any = createCatalogEntityPropertyRef(refEntry);\n          throwIfRefNotFound(\n            crs,\n            propertyRef,\n            `${propertyRef.kind.toLowerCase()}:${propertyRef.name}`,\n            `${cr.kind}-${cr.name}`,\n          )\n        }\n      }\n    }\n  }\n}\n\n/*\n * @description When dealing with catalog entities, their references are stored\n * as a string in the \"[kind]:[name]\" format. This function transforms those strings\n * into a reference in the { kind: [kind], name: [name] } format\n *\n * @param refString The string to transform. Must be in the \"[kind]:[name]\" format\n */\nfunction createCatalogEntityPropertyRef(refString: string): any {\n  const splittedRefString: string[] = refString.split(\":\");\n  return {\n    // The kind string needs to be capitalized\n    kind:\n      splittedRefString[0].substring(0, 1).toUpperCase() +\n      splittedRefString[0].substring(1).toLowerCase(),\n    name: splittedRefString[1],\n  }\n}\n\nexport function isCatalogEntity(cr: any): boolean {\n  return [\n    \"Component\", \n    \"Domain\", \n    \"System\", \n    \"User\", \n    \"Group\", \n    \"Resource\"\n  ].includes(cr.kind)\n}\n\n\nfunction isTerraformWorkspace(cr: any): boolean {\n  return cr.kind === \"FirestartrTerraformWorkspace\"\n}\n"]}
236220
236272
 
236221
236273
  /***/ }),
236222
236274
 
@@ -237053,7 +237105,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
237053
237105
  return (mod && mod.__esModule) ? mod : { "default": mod };
237054
237106
  };
237055
237107
  Object.defineProperty(exports, "__esModule", ({ value: true }));
237056
- exports.commentInPR = void 0;
237108
+ exports.getPrFiles = exports.commentInPR = void 0;
237057
237109
  const auth_1 = __nccwpck_require__(7745);
237058
237110
  const debug_1 = __importDefault(__nccwpck_require__(67984));
237059
237111
  const messageLog = (0, debug_1.default)('firestartr:github:pull_request');
@@ -237065,7 +237117,39 @@ async function commentInPR(comment, pr_number, repo, owner = "prefapp") {
237065
237117
  });
237066
237118
  }
237067
237119
  exports.commentInPR = commentInPR;
237068
- exports["default"] = { commentInPR };
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 };
237069
237153
 
237070
237154
 
237071
237155
  /***/ }),
@@ -239067,7 +239151,7 @@ const informer_1 = __nccwpck_require__(41151);
239067
239151
  const dummy_1 = __nccwpck_require__(73490);
239068
239152
  const processItem_1 = __nccwpck_require__(84766);
239069
239153
  const cdktf_1 = __nccwpck_require__(10805);
239070
- const processOperation_1 = __nccwpck_require__(53014);
239154
+ const process_operation_1 = __nccwpck_require__(3937);
239071
239155
  const leader_election_1 = __nccwpck_require__(29856);
239072
239156
  const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
239073
239157
  const processOperationPlan_1 = __nccwpck_require__(79980);
@@ -239131,7 +239215,7 @@ function getProvisionImplementation(plural) {
239131
239215
  let implementation = undefined;
239132
239216
  switch (plural) {
239133
239217
  case "terraformworkspaces":
239134
- implementation = processOperation_1.processOperation;
239218
+ implementation = process_operation_1.processOperation;
239135
239219
  break;
239136
239220
  case "terraformworkspaceplans":
239137
239221
  implementation = processOperationPlan_1.processOperationPlan;
@@ -240160,7 +240244,7 @@ async function inform(pluralKind, item, op, lastWorkItem = null) {
240160
240244
  };
240161
240245
  return workItem;
240162
240246
  case "onRename":
240163
- if (await (0, status_1.needsProvisioningOnCreate)(itemPath(pluralKind, item), item)) {
240247
+ if (await (0, status_1.needsProvisioningOnCreate)(item)) {
240164
240248
  log("onRename - needsProvisioningOnCreate true %s", item.metadata.name);
240165
240249
  workItem = {
240166
240250
  operation: OperationType.RENAMED,
@@ -240184,7 +240268,7 @@ async function inform(pluralKind, item, op, lastWorkItem = null) {
240184
240268
  return workItem;
240185
240269
  case "onAdd":
240186
240270
  log("onAdd %s", item.metadata.name);
240187
- if (await (0, status_1.needsProvisioningOnCreate)(itemPath(pluralKind, item), item)) {
240271
+ if (await (0, status_1.needsProvisioningOnCreate)(item)) {
240188
240272
  workItem = {
240189
240273
  operation: OperationType.CREATED,
240190
240274
  item,
@@ -240701,11 +240785,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
240701
240785
  Object.defineProperty(exports, "__esModule", ({ value: true }));
240702
240786
  exports.observe = void 0;
240703
240787
  const ctl_1 = __nccwpck_require__(46679);
240704
- const fast_json_patch_1 = __importDefault(__nccwpck_require__(75177));
240705
240788
  const debug_1 = __importDefault(__nccwpck_require__(67984));
240706
240789
  const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
240707
240790
  const log = (0, debug_1.default)('firestartr:operator:reflector');
240708
240791
  const k8s = __importStar(__nccwpck_require__(54851));
240792
+ const store_1 = __nccwpck_require__(87432);
240709
240793
  /**
240710
240794
  * Execute the callbacks for each item in the store
240711
240795
  * @param {string} kind - Kind to observe
@@ -240716,7 +240800,7 @@ const k8s = __importStar(__nccwpck_require__(54851));
240716
240800
  * @param {Function} onRename - Function to call when an item is renamed
240717
240801
  */
240718
240802
  async function observe(kind, namespace, onAdd, onChange, onDelete, _onRename) {
240719
- const store = new Store(kind);
240803
+ const store = new store_1.Store(kind);
240720
240804
  const { kc } = await (0, ctl_1.getConnection)();
240721
240805
  try {
240722
240806
  const k8sApi = kc.makeApiClient(k8s.CustomObjectsApi);
@@ -240728,29 +240812,37 @@ async function observe(kind, namespace, onAdd, onChange, onDelete, _onRename) {
240728
240812
  };
240729
240813
  const informer = k8s.makeInformer(kc, apiPaths, listFn);
240730
240814
  informer.on('add', (obj) => {
240731
- log(`informer: ADDED ${obj.metadata.name}`);
240732
240815
  store.add(obj);
240733
- onAdd(obj);
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
+ }
240734
240825
  });
240735
240826
  informer.on('update', (obj) => {
240736
- log(`informer: UPDATE %O`, obj);
240737
- if (store.getItem(obj).markedToDelete) {
240738
- }
240739
- else if (store.isMarkedToDelete(obj)) {
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`);
240740
240832
  store.markToDelete(obj);
240741
240833
  onDelete(obj);
240742
240834
  }
240743
240835
  else if (store.modified(obj)) {
240836
+ log(`informer (on update): The item ${obj.kind}: ${obj.metadata.name} has been modified`);
240744
240837
  onChange(obj);
240745
240838
  }
240746
240839
  });
240747
240840
  informer.on('delete', (obj) => {
240748
- log(`informer: DELETED ${obj.metadata.name}`);
240841
+ log(`informer (on delete): The item ${obj.metadata.name} :${obj.metadata.name} has been deleted from etcd`);
240749
240842
  store.remove(obj);
240750
240843
  });
240751
240844
  informer.on('error', (err) => {
240752
- console.error(err);
240753
- // Restart informer after 5sec
240845
+ log(`informer (on error): ERROR %O`, err);
240754
240846
  setTimeout(() => {
240755
240847
  informer.start();
240756
240848
  }, 5000);
@@ -240764,52 +240856,6 @@ async function observe(kind, namespace, onAdd, onChange, onDelete, _onRename) {
240764
240856
  }
240765
240857
  }
240766
240858
  exports.observe = observe;
240767
- class Store {
240768
- kind;
240769
- store = {};
240770
- constructor(kind) {
240771
- this.kind = kind;
240772
- }
240773
- add(item) {
240774
- this.store[itemPath(this.kind, item)] = {
240775
- item
240776
- };
240777
- }
240778
- isMarkedToDelete(item) {
240779
- return "deletionTimestamp" in item.metadata;
240780
- }
240781
- markToDelete(item) {
240782
- this.store[itemPath(this.kind, item)] = {
240783
- item,
240784
- markedToDelete: true
240785
- };
240786
- }
240787
- modified(item) {
240788
- const oldItem = this.getItem(item).item;
240789
- const patches = fast_json_patch_1.default.compare(item, oldItem);
240790
- let updated = false;
240791
- for (const patch of patches) {
240792
- if (patch.path.match(/^\/spec/) || patch.path.match(/\/metadata.*annotations/)) {
240793
- updated = true;
240794
- break;
240795
- }
240796
- }
240797
- this.store[itemPath(this.kind, item)] = {
240798
- item
240799
- };
240800
- console.log(Object.keys(this.store));
240801
- return updated;
240802
- }
240803
- remove(item) {
240804
- delete this.store[itemPath(this.kind, item)];
240805
- }
240806
- getItem(item) {
240807
- return this.store[itemPath(this.kind, item)];
240808
- }
240809
- }
240810
- function itemPath(kind, item) {
240811
- return `${item.metadata.namespace}/${kind}/${item.metadata.name}`;
240812
- }
240813
240859
 
240814
240860
 
240815
240861
  /***/ }),
@@ -240958,7 +241004,7 @@ const ctl_1 = __nccwpck_require__(46679);
240958
241004
  const debug_1 = __importDefault(__nccwpck_require__(67984));
240959
241005
  const log = (0, debug_1.default)('firestartr:operator:retry');
240960
241006
  const NEXT_RETRY_SECS = 1000 * 60;
240961
- const MAXRETRY = 10;
241007
+ const MAXRETRY = 5;
240962
241008
  const retryWatchers = {};
240963
241009
  async function initRetry(enqueue) {
240964
241010
  loop(enqueue);
@@ -240978,6 +241024,9 @@ exports.initRetry = initRetry;
240978
241024
  function retry(itemPath) {
240979
241025
  if (retryWatchers[itemPath]) {
240980
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`);
240981
241030
  retryWatchers[itemPath].retry = false;
240982
241031
  retryWatchers[itemPath].nextRetry = setTimeout(() => {
240983
241032
  if (itemPath in retryWatchers)
@@ -241057,67 +241106,47 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
241057
241106
  return (mod && mod.__esModule) ? mod : { "default": mod };
241058
241107
  };
241059
241108
  Object.defineProperty(exports, "__esModule", ({ value: true }));
241060
- exports.updateTransition = exports.needsProvisioningOnUpdate = exports.needsProvisioningOnCreate = void 0;
241109
+ exports.updateTransition = exports.needsProvisioningOnCreate = void 0;
241061
241110
  const ctl_1 = __nccwpck_require__(46679);
241062
241111
  const debug_1 = __importDefault(__nccwpck_require__(67984));
241063
241112
  const log = (0, debug_1.default)('firestartr:operator:status');
241064
- const catalog_common_1 = __importDefault(__nccwpck_require__(74100));
241065
- async function needsProvisioningOnCreate(itemPath, item) {
241066
- const k8sItem = item;
241067
- if (!("status" in k8sItem) || !("conditions" in k8sItem.status))
241068
- return true;
241069
- try {
241070
- const errorCondition = getConditionByType(k8sItem.status.conditions, "ERROR");
241071
- if (errorCondition.status === "True" &&
241072
- errorCondition.observedGeneration >= k8sItem.metadata.generation) {
241073
- return true;
241074
- }
241075
- }
241076
- catch (e) {
241077
- catalog_common_1.default.io.writeFunctionLog("needsProvisioningOnCreate", `Error getting error condition: ${e}`);
241078
- }
241079
- try {
241080
- const provisionedCondition = getConditionByType(k8sItem.status.conditions, "PROVISIONED");
241081
- if (provisionedCondition.status === "True" &&
241082
- provisionedCondition.observedGeneration >= k8sItem.metadata.generation) {
241083
- return false;
241084
- }
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...`);
241085
241118
  return true;
241086
241119
  }
241087
- catch (e) {
241088
- console.log("error getting provisioned condition");
241089
- return true;
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;
241090
241125
  }
241091
- }
241092
- exports.needsProvisioningOnCreate = needsProvisioningOnCreate;
241093
- async function needsProvisioningOnUpdate(itemPath) {
241094
- const k8sItem = await (0, ctl_1.getItemByItemPath)(itemPath);
241095
- if (!("status" in k8sItem) || !("conditions" in k8sItem.status))
241096
- return true;
241097
- try {
241098
- const errorCondition = getConditionByType(k8sItem.status.conditions, "ERROR");
241099
- if (errorCondition.status === "True" &&
241100
- errorCondition.observedGeneration >= k8sItem.metadata.generation) {
241101
- return true;
241102
- }
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;
241103
241131
  }
241104
- catch (e) { }
241105
- try {
241106
- const provisionedCondition = getConditionByType(k8sItem.status.conditions, "PROVISIONED");
241107
- if (provisionedCondition.status === "True" &&
241108
- provisionedCondition.observedGeneration >= k8sItem.metadata.generation) {
241109
- return false;
241110
- }
241111
- const provisioningCondition = getConditionByType(k8sItem.status.conditions, "PROVISIONING");
241112
- 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;
241113
241137
  }
241114
- catch (e) {
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...`);
241115
241142
  return true;
241116
241143
  }
241144
+ log(`${fCrLog(cr)} is in a not handled state, skipping provisioning...`);
241145
+ return false;
241117
241146
  }
241118
- exports.needsProvisioningOnUpdate = needsProvisioningOnUpdate;
241147
+ exports.needsProvisioningOnCreate = needsProvisioningOnCreate;
241119
241148
  async function updateTransition(itemPath, reason, type, statusValue, message = "", updateStatusOnly = false) {
241120
- log("UPDATE TRANSITION");
241149
+ log("Update transition for item: %s, reason: %s, type: %s, status: %s, message: %s, updateStatusOnly: %s", itemPath, reason, type, statusValue, message, updateStatusOnly);
241121
241150
  const k8sItem = await (0, ctl_1.getItemByItemPath)(itemPath);
241122
241151
  if (!("status" in k8sItem))
241123
241152
  k8sItem.status = {};
@@ -241136,20 +241165,18 @@ async function updateTransition(itemPath, reason, type, statusValue, message = "
241136
241165
  }
241137
241166
  exports.updateTransition = updateTransition;
241138
241167
  function getRelevantCondition(conditionList, type) {
241139
- try {
241140
- return getConditionByType(conditionList, type);
241141
- }
241142
- catch (e) {
241143
- return {
241144
- "lastTransitionTime": new Date().toJSON(),
241145
- "lastUpdateTime": new Date().toJSON(),
241146
- "message": "",
241147
- "observedGeneration": -1,
241148
- "reason": "",
241149
- "status": "",
241150
- "type": type,
241151
- };
241152
- }
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
+ };
241153
241180
  }
241154
241181
  function updateCondition(condition, reason, status, message, generation) {
241155
241182
  condition.lastUpdateTime = new Date().toJSON();
@@ -241164,7 +241191,7 @@ function getConditionByType(conditionList, type) {
241164
241191
  if (conditionList[i].type === type)
241165
241192
  return conditionList[i];
241166
241193
  }
241167
- throw new Error(`getConditionByType: Type ${type} not found in condition list`);
241194
+ return false;
241168
241195
  }
241169
241196
  function updateConditionByType(conditionList, type, newCondition) {
241170
241197
  let typeFound = false;
@@ -241180,6 +241207,82 @@ function updateConditionByType(conditionList, type, newCondition) {
241180
241207
  }
241181
241208
 
241182
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
+
241183
241286
  /***/ }),
241184
241287
 
241185
241288
  /***/ 74298:
@@ -241350,7 +241453,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
241350
241453
  };
241351
241454
  Object.defineProperty(exports, "__esModule", ({ value: true }));
241352
241455
  exports.buildProvisionerContext = exports.processOperationPlan = void 0;
241353
- const informer_1 = __nccwpck_require__(41151);
241354
241456
  const debug_1 = __importDefault(__nccwpck_require__(67984));
241355
241457
  const terraform_provisioner_1 = __nccwpck_require__(6777);
241356
241458
  const github_1 = __importDefault(__nccwpck_require__(39759));
@@ -241361,12 +241463,15 @@ const TF_PROJECTS_PATH = "/tmp/tfworkspaces";
241361
241463
  function processOperationPlan(item, op, handler) {
241362
241464
  try {
241363
241465
  clearLocalTfProjects();
241364
- switch (op) {
241365
- case informer_1.OperationType.UPDATED:
241366
- case informer_1.OperationType.CREATED:
241367
- return plan(item, op, handler);
241368
- default:
241369
- return nothing(item, op, handler);
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);
241370
241475
  }
241371
241476
  }
241372
241477
  catch (e) {
@@ -241375,7 +241480,7 @@ function processOperationPlan(item, op, handler) {
241375
241480
  }
241376
241481
  }
241377
241482
  exports.processOperationPlan = processOperationPlan;
241378
- async function* nothing(item, op, handler) {
241483
+ async function* nothing(item, op, _handler) {
241379
241484
  yield {
241380
241485
  item,
241381
241486
  reason: op,
@@ -241384,19 +241489,19 @@ async function* nothing(item, op, handler) {
241384
241489
  message: "NOTHING"
241385
241490
  };
241386
241491
  }
241387
- async function* plan(item, op, handler, format = "plain-text") {
241492
+ async function* plan(item, op, handler, format = "plain-text", action = "plan") {
241388
241493
  if (format == "plain-text") {
241389
- for await (const transition of doPlanPlainTextFormat(item, op, handler)) {
241494
+ for await (const transition of doPlanPlainTextFormat(item, op, handler, action)) {
241390
241495
  yield transition;
241391
241496
  }
241392
241497
  }
241393
241498
  else if (format == "json") {
241394
- for await (const transition of doPlanJSONFormat(item, op, handler)) {
241499
+ for await (const transition of doPlanJSONFormat(item, op, handler, action)) {
241395
241500
  yield transition;
241396
241501
  }
241397
241502
  }
241398
241503
  }
241399
- async function* doPlanPlainTextFormat(item, op, handler) {
241504
+ async function* doPlanPlainTextFormat(item, op, handler, action) {
241400
241505
  try {
241401
241506
  yield {
241402
241507
  item,
@@ -241422,7 +241527,7 @@ async function* doPlanPlainTextFormat(item, op, handler) {
241422
241527
  const deps = await handler.resolveReferences();
241423
241528
  log('Item %s has the following dependencies: %O', item.metadata.name, deps);
241424
241529
  const context = buildProvisionerContext(item, deps);
241425
- const tfPlanOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "plan");
241530
+ const tfPlanOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, action);
241426
241531
  await publishPlan(item, tfPlanOutput);
241427
241532
  yield {
241428
241533
  item,
@@ -241476,7 +241581,7 @@ async function* doPlanPlainTextFormat(item, op, handler) {
241476
241581
  }
241477
241582
  }
241478
241583
  }
241479
- async function* doPlanJSONFormat(item, op, handler) {
241584
+ async function* doPlanJSONFormat(item, op, handler, action) {
241480
241585
  try {
241481
241586
  yield {
241482
241587
  item,
@@ -241502,7 +241607,7 @@ async function* doPlanJSONFormat(item, op, handler) {
241502
241607
  const deps = await handler.resolveReferences();
241503
241608
  log('Item %s has the following dependencies: %O', item.metadata.name, deps);
241504
241609
  const context = buildProvisionerContext(item, deps);
241505
- const tfPlan = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "plan-json");
241610
+ const tfPlan = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, action);
241506
241611
  if (tfPlan.summary.hasChanges()) {
241507
241612
  yield {
241508
241613
  item,
@@ -241810,6 +241915,11 @@ async function publishPlan(item, planOutput) {
241810
241915
  console.error(e);
241811
241916
  }
241812
241917
  }
241918
+ function getPolicy(item) {
241919
+ const policy = item.metadata.annotations && item.metadata.annotations["firestartr.dev/policy"];
241920
+ if (policy)
241921
+ return policy;
241922
+ }
241813
241923
 
241814
241924
 
241815
241925
  /***/ }),
@@ -241908,7 +242018,7 @@ const terraform_provisioner_1 = __nccwpck_require__(6777);
241908
242018
  const ctl_1 = __nccwpck_require__(46679);
241909
242019
  const ctx_1 = __nccwpck_require__(15284);
241910
242020
  const resolver_1 = __nccwpck_require__(31022);
241911
- const processOperation_1 = __nccwpck_require__(53014);
242021
+ const process_operation_1 = __nccwpck_require__(3937);
241912
242022
  const cdk8s_renderer_1 = __importDefault(__nccwpck_require__(80318));
241913
242023
  const ctl_2 = __nccwpck_require__(59018);
241914
242024
  const debug_1 = __importDefault(__nccwpck_require__(67984));
@@ -241955,7 +242065,7 @@ async function buildContext(claim, namespace, command) {
241955
242065
  };
241956
242066
  compute["runProvision"] = async () => {
241957
242067
  infolog("🔁 Running terraform process...");
241958
- const data = await (0, processOperation_1.buildProvisionerContext)(cr, deps);
242068
+ const data = await (0, process_operation_1.buildProvisionerContext)(cr, deps);
241959
242069
  const result = await (0, terraform_provisioner_1.runTerraformProvisioner)(data, command);
241960
242070
  infolog("✅ Terraform process finished");
241961
242071
  return result;
@@ -241967,7 +242077,72 @@ exports.buildContext = buildContext;
241967
242077
 
241968
242078
  /***/ }),
241969
242079
 
241970
- /***/ 53014:
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:
241971
242146
  /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) {
241972
242147
 
241973
242148
  "use strict";
@@ -242003,38 +242178,39 @@ exports.buildProvisionerContext = exports.processOperation = void 0;
242003
242178
  const informer_1 = __nccwpck_require__(41151);
242004
242179
  const debug_1 = __importDefault(__nccwpck_require__(67984));
242005
242180
  const terraform_provisioner_1 = __nccwpck_require__(6777);
242006
- const log = (0, debug_1.default)('firestartr:operator:terraform');
242007
- const github_1 = __importDefault(__nccwpck_require__(39759));
242008
242181
  const fs = __importStar(__nccwpck_require__(57147));
242009
242182
  const path = __importStar(__nccwpck_require__(71017));
242010
- const __1 = __nccwpck_require__(79622);
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');
242011
242186
  const TF_PROJECTS_PATH = "/tmp/tfworkspaces";
242012
242187
  function processOperation(item, op, handler) {
242013
242188
  try {
242014
242189
  clearLocalTfProjects();
242015
242190
  const policy = getPolicy(item);
242016
- if (policy === "observe" || (0, __1.isObserveModeActive)()) {
242191
+ if (!policy || policy === "observe" || policy === "observe-only") {
242017
242192
  return observe(item, op, handler);
242018
242193
  }
242019
- else if (policy === "apply") {
242020
- switch (op) {
242021
- case informer_1.OperationType.UPDATED:
242022
- return updated(item, op, handler);
242023
- case informer_1.OperationType.CREATED:
242024
- return created(item, op, handler);
242025
- case informer_1.OperationType.RENAMED:
242026
- return renamed(item, op, handler);
242027
- case informer_1.OperationType.SYNC:
242028
- return sync(item, op, handler);
242029
- case informer_1.OperationType.MARKED_TO_DELETION:
242030
- return markedToDeletion(item, op, handler);
242031
- case informer_1.OperationType.RETRY:
242032
- return retry(item, op, handler);
242033
- case informer_1.OperationType.NOTHING:
242034
- return nothing(item, op, handler);
242035
- default:
242036
- throw new Error(`Operation ${op} not supported`);
242037
- }
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`);
242038
242214
  }
242039
242215
  }
242040
242216
  catch (e) {
@@ -242074,7 +242250,11 @@ async function* doPlanJSONFormat(item, op, handler) {
242074
242250
  const deps = await handler.resolveReferences();
242075
242251
  log('Item %s has the following dependencies: %O', item.metadata.name, deps);
242076
242252
  const context = buildProvisionerContext(item, deps);
242077
- const tfPlan = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "plan-json");
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);
242078
242258
  if (tfPlan.summary.hasChanges()) {
242079
242259
  yield {
242080
242260
  item,
@@ -242083,6 +242263,7 @@ async function* doPlanJSONFormat(item, op, handler) {
242083
242263
  status: "False",
242084
242264
  message: "Plan has changes"
242085
242265
  };
242266
+ policies_1.policyAllowsOp;
242086
242267
  yield {
242087
242268
  item,
242088
242269
  reason: op,
@@ -242180,7 +242361,7 @@ async function* updated(item, op, handler) {
242180
242361
  }
242181
242362
  }
242182
242363
  async function* retry(item, op, handler) {
242183
- if ("deletionTimestamp" in item.metadata) {
242364
+ if (isDestroyRetry(item)) {
242184
242365
  for await (const transition of markedToDeletion(item, op, handler)) {
242185
242366
  yield transition;
242186
242367
  }
@@ -242191,6 +242372,14 @@ async function* retry(item, op, handler) {
242191
242372
  }
242192
242373
  }
242193
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
+ }
242194
242383
  async function* sync(item, op, handler) {
242195
242384
  yield {
242196
242385
  item,
@@ -242213,6 +242402,20 @@ async function* sync(item, op, handler) {
242213
242402
  async function* markedToDeletion(item, op, handler) {
242214
242403
  try {
242215
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
+ };
242216
242419
  yield {
242217
242420
  item,
242218
242421
  reason: op,
@@ -242251,7 +242454,7 @@ async function* markedToDeletion(item, op, handler) {
242251
242454
  const deps = await handler.resolveReferences();
242252
242455
  const context = buildProvisionerContext(item, deps);
242253
242456
  const destroyOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "destroy");
242254
- await tryPublishApply(item, destroyOutput);
242457
+ await (0, user_feedback_ops_1.tryPublishDestroy)(item, destroyOutput);
242255
242458
  yield {
242256
242459
  item,
242257
242460
  reason: op,
@@ -242259,6 +242462,13 @@ async function* markedToDeletion(item, op, handler) {
242259
242462
  status: "False",
242260
242463
  message: "Destroying process finished"
242261
242464
  };
242465
+ yield {
242466
+ item,
242467
+ reason: op,
242468
+ type: "DELETED",
242469
+ status: "True",
242470
+ message: "destroyed"
242471
+ };
242262
242472
  await handler.finalize(handler.pluralKind, item.metadata.namespace, item, "firestartr.dev/finalizer");
242263
242473
  await handler.writeTerraformOutputInTfResult(item, destroyOutput);
242264
242474
  handler.success();
@@ -242292,6 +242502,13 @@ async function* nothing(item, op, handler) {
242292
242502
  */
242293
242503
  async function* doApply(item, op, handler) {
242294
242504
  try {
242505
+ yield {
242506
+ item,
242507
+ reason: op,
242508
+ type: "DELETED",
242509
+ status: "False",
242510
+ message: "markedToDeletion"
242511
+ };
242295
242512
  yield {
242296
242513
  item,
242297
242514
  reason: op,
@@ -242333,7 +242550,7 @@ async function* doApply(item, op, handler) {
242333
242550
  log('Item %s has the following dependencies: %O', item.metadata.name, deps);
242334
242551
  const context = buildProvisionerContext(item, deps);
242335
242552
  const applyOutput = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "apply");
242336
- await tryPublishApply(item, applyOutput);
242553
+ await (0, user_feedback_ops_1.tryPublishApply)(item, applyOutput);
242337
242554
  const terraformOutputJson = await (0, terraform_provisioner_1.runTerraformProvisioner)(context, "output");
242338
242555
  if (!terraformOutputJson) {
242339
242556
  throw new Error(`Terraform output is empty for ${item.kind}/${item.metadata.name}`);
@@ -242366,7 +242583,7 @@ async function* doApply(item, op, handler) {
242366
242583
  }
242367
242584
  catch (e) {
242368
242585
  console.error(e);
242369
- await tryPublishApply(item, e);
242586
+ await (0, user_feedback_ops_1.tryPublishApply)(item, e);
242370
242587
  log("Error applying item %s: %O", item.metadata.name, e);
242371
242588
  yield {
242372
242589
  item,
@@ -242395,6 +242612,73 @@ async function* doApply(item, op, handler) {
242395
242612
  }
242396
242613
  }
242397
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
+ }
242398
242682
  /**
242399
242683
  * @description Adapts the CR to the format expected by the terraform provisioner
242400
242684
  * @param item - CR to be applied
@@ -242586,6 +242870,23 @@ function getErrorOutputMessage(cr, key, ref) {
242586
242870
  throw new Error(`❌ Source ${cr.spec.source} not supported`);
242587
242871
  }
242588
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');
242589
242890
  async function tryPublishApply(item, planOutput) {
242590
242891
  try {
242591
242892
  if (!("firestartr.dev/last-state-pr" in item.metadata.annotations)) {
@@ -242598,7 +242899,63 @@ async function tryPublishApply(item, planOutput) {
242598
242899
  log(`Error publishing apply: ${e}`);
242599
242900
  }
242600
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;
242601
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) {
242602
242959
  const prInfo = item.metadata.annotations["firestartr.dev/last-state-pr"];
242603
242960
  const prNumber = prInfo.split("#")[1];
242604
242961
  if (!prNumber)
@@ -242609,20 +242966,27 @@ async function publishApply(item, applyOutput) {
242609
242966
  const repo = prInfo.split("#")[0].split("/")[1];
242610
242967
  if (!repo)
242611
242968
  throw new Error("No repo found in CR");
242612
- const comment = `<h1>
242613
- <img width="25" src="https://static-00.iconduck.com/assets.00/file-type-terraform-icon-1821x2048-mbxeegff.png"> Terraform apply
242614
- </h1>
242615
- <p><b>TFWorkspace: </b>${item.metadata.name}</p>
242616
-
242617
- <details id=github>
242618
- <summary>APPLY LOGS</summary>
242619
-
242620
- \`\`\`shell
242621
- ${applyOutput}
242622
- \`\`\`
242623
- </details>`;
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
+ `;
242624
242987
  await github_1.default.pulls.commentInPR(comment, parseInt(prNumber), repo, org);
242625
242988
  }
242989
+ exports.publishError = publishError;
242626
242990
 
242627
242991
 
242628
242992
  /***/ }),
@@ -243831,6 +244195,12 @@ async function execCommand(command, tfProject) {
243831
244195
  case "apply":
243832
244196
  await tfProject.apply();
243833
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;
243834
244204
  case "destroy":
243835
244205
  await tfProject.destroy();
243836
244206
  break;
@@ -243932,6 +244302,12 @@ class TFProjectManager {
243932
244302
  this.tfOutput = null;
243933
244303
  this.tfOutput = await (0, utils_1.plan)(this.projectPath, this.secrets, format);
243934
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
+ }
243935
244311
  async apply() {
243936
244312
  await this.__init();
243937
244313
  this.tfOutput += await (0, utils_1.apply)(this.projectPath, this.secrets);
@@ -244356,8 +244732,8 @@ async function initFromModule(path, source, secrets) {
244356
244732
  ], secrets, []);
244357
244733
  }
244358
244734
  exports.initFromModule = initFromModule;
244359
- async function plan(path, secrets, format) {
244360
- const plan = await tfExec(path, ["plan"]
244735
+ async function plan(path, secrets, format, args = ["plan"]) {
244736
+ const plan = await tfExec(path, args
244361
244737
  .concat(format == "json" ?
244362
244738
  ["-json"]
244363
244739
  :