From 98f9b50e1a162b723da9d1818b786ddec6aa92e9 Mon Sep 17 00:00:00 2001 From: nicolst <35232838+nicolst@users.noreply.github.com> Date: Tue, 14 May 2024 12:48:02 +0200 Subject: [PATCH 1/2] Add repo_config_override to atlantis block --- src/v1/kuben-team-definition.schema.json | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/v1/kuben-team-definition.schema.json b/src/v1/kuben-team-definition.schema.json index 94844af..4dac5cd 100644 --- a/src/v1/kuben-team-definition.schema.json +++ b/src/v1/kuben-team-definition.schema.json @@ -102,6 +102,10 @@ "pattern": "^[a-zA-Z-_.0-9]*$" } }, + "repo_config_override": { + "type": "string", + "description": "Override values in this Atlantis' repos.yaml config. Values get merged on top of default values. Should be a valid YAML string." + }, "folder_iam": { "type": "array", "description": "Array of folder bindings to set for the Atlantis SA.", From 96d654926eef74bbe467c92a3dcc19f4150e7298 Mon Sep 17 00:00:00 2001 From: "dapla-bot[bot]" <143391972+dapla-bot[bot]@users.noreply.github.com> Date: Tue, 14 May 2024 10:48:57 +0000 Subject: [PATCH 2/2] [GENERATE] Java classes from JSON Schema --- .../java/no/ssb/dapla/kuben/v1/Atlantis.java | 53 ++++++++++++++++--- 1 file changed, 46 insertions(+), 7 deletions(-) diff --git a/generated/java/dapla-kuben-resource-model/src/main/java/no/ssb/dapla/kuben/v1/Atlantis.java b/generated/java/dapla-kuben-resource-model/src/main/java/no/ssb/dapla/kuben/v1/Atlantis.java index 1d43195..1419cb6 100644 --- a/generated/java/dapla-kuben-resource-model/src/main/java/no/ssb/dapla/kuben/v1/Atlantis.java +++ b/generated/java/dapla-kuben-resource-model/src/main/java/no/ssb/dapla/kuben/v1/Atlantis.java @@ -21,6 +21,7 @@ @JsonPropertyOrder({ "name", "repos", + "repo_config_override", "folder_iam" }) @Generated("jsonschema2pojo") @@ -44,6 +45,13 @@ public class Atlantis implements Serializable @JsonPropertyDescription("Which repositories under Statistics Norway-organisation this team atlantis instance will monitor.") @Valid private List repos = new ArrayList(); + /** + * Override values in this Atlantis' repos.yaml config. Values get merged on top of default values. Should be a valid YAML string. + * + */ + @JsonProperty("repo_config_override") + @JsonPropertyDescription("Override values in this Atlantis' repos.yaml config. Values get merged on top of default values. Should be a valid YAML string.") + private String repoConfigOverride; /** * Array of folder bindings to set for the Atlantis SA. * @@ -55,7 +63,7 @@ public class Atlantis implements Serializable @JsonIgnore @Valid private Map additionalProperties = new LinkedHashMap(); - private final static long serialVersionUID = 854245460037993476L; + private final static long serialVersionUID = -2127862757532224175L; /** * No args constructor for use in serialization @@ -72,11 +80,14 @@ public Atlantis() { * Array of folder bindings to set for the Atlantis SA. * @param name * The name of the atlantis instance. + * @param repoConfigOverride + * Override values in this Atlantis' repos.yaml config. Values get merged on top of default values. Should be a valid YAML string. */ - public Atlantis(String name, List repos, List folderIam) { + public Atlantis(String name, List repos, String repoConfigOverride, List folderIam) { super(); this.name = name; this.repos = repos; + this.repoConfigOverride = repoConfigOverride; this.folderIam = folderIam; } @@ -122,6 +133,24 @@ public void setRepos(List repos) { this.repos = repos; } + /** + * Override values in this Atlantis' repos.yaml config. Values get merged on top of default values. Should be a valid YAML string. + * + */ + @JsonProperty("repo_config_override") + public String getRepoConfigOverride() { + return repoConfigOverride; + } + + /** + * Override values in this Atlantis' repos.yaml config. Values get merged on top of default values. Should be a valid YAML string. + * + */ + @JsonProperty("repo_config_override") + public void setRepoConfigOverride(String repoConfigOverride) { + this.repoConfigOverride = repoConfigOverride; + } + /** * Array of folder bindings to set for the Atlantis SA. * @@ -162,6 +191,10 @@ public String toString() { sb.append('='); sb.append(((this.repos == null)?"":this.repos)); sb.append(','); + sb.append("repoConfigOverride"); + sb.append('='); + sb.append(((this.repoConfigOverride == null)?"":this.repoConfigOverride)); + sb.append(','); sb.append("folderIam"); sb.append('='); sb.append(((this.folderIam == null)?"":this.folderIam)); @@ -182,6 +215,7 @@ public String toString() { public int hashCode() { int result = 1; result = ((result* 31)+((this.name == null)? 0 :this.name.hashCode())); + result = ((result* 31)+((this.repoConfigOverride == null)? 0 :this.repoConfigOverride.hashCode())); result = ((result* 31)+((this.additionalProperties == null)? 0 :this.additionalProperties.hashCode())); result = ((result* 31)+((this.repos == null)? 0 :this.repos.hashCode())); result = ((result* 31)+((this.folderIam == null)? 0 :this.folderIam.hashCode())); @@ -197,7 +231,7 @@ public boolean equals(Object other) { return false; } Atlantis rhs = ((Atlantis) other); - return (((((this.name == rhs.name)||((this.name!= null)&&this.name.equals(rhs.name)))&&((this.additionalProperties == rhs.additionalProperties)||((this.additionalProperties!= null)&&this.additionalProperties.equals(rhs.additionalProperties))))&&((this.repos == rhs.repos)||((this.repos!= null)&&this.repos.equals(rhs.repos))))&&((this.folderIam == rhs.folderIam)||((this.folderIam!= null)&&this.folderIam.equals(rhs.folderIam)))); + return ((((((this.name == rhs.name)||((this.name!= null)&&this.name.equals(rhs.name)))&&((this.repoConfigOverride == rhs.repoConfigOverride)||((this.repoConfigOverride!= null)&&this.repoConfigOverride.equals(rhs.repoConfigOverride))))&&((this.additionalProperties == rhs.additionalProperties)||((this.additionalProperties!= null)&&this.additionalProperties.equals(rhs.additionalProperties))))&&((this.repos == rhs.repos)||((this.repos!= null)&&this.repos.equals(rhs.repos))))&&((this.folderIam == rhs.folderIam)||((this.folderIam!= null)&&this.folderIam.equals(rhs.folderIam)))); } public static class AtlantisBuilder @@ -209,8 +243,8 @@ public AtlantisBuilder() { super(); } - public AtlantisBuilder(String name, List repos, List folderIam) { - super(name, repos, folderIam); + public AtlantisBuilder(String name, List repos, String repoConfigOverride, List folderIam) { + super(name, repos, repoConfigOverride, folderIam); } } @@ -228,10 +262,10 @@ public AtlantisBuilderBase() { } @SuppressWarnings("unchecked") - public AtlantisBuilderBase(String name, List repos, List folderIam) { + public AtlantisBuilderBase(String name, List repos, String repoConfigOverride, List folderIam) { // Skip initialization when called from subclass if (this.getClass().equals(Atlantis.AtlantisBuilder.class)) { - this.instance = ((T) new Atlantis(name, repos, folderIam)); + this.instance = ((T) new Atlantis(name, repos, repoConfigOverride, folderIam)); } } @@ -252,6 +286,11 @@ public Atlantis.AtlantisBuilderBase withRepos(List repos) { return this; } + public Atlantis.AtlantisBuilderBase withRepoConfigOverride(String repoConfigOverride) { + ((Atlantis) this.instance).repoConfigOverride = repoConfigOverride; + return this; + } + public Atlantis.AtlantisBuilderBase withFolderIam(List folderIam) { ((Atlantis) this.instance).folderIam = folderIam; return this;