@firestartr/cli 0.1.10 → 0.1.11

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