Skip to content

Commit

Permalink
feat(argocd_applicationset): add ignore_application_differences attri…
Browse files Browse the repository at this point in the history
…bute
  • Loading branch information
dtrouillet committed Dec 12, 2023
1 parent b519f37 commit a66d0a3
Show file tree
Hide file tree
Showing 9 changed files with 333 additions and 166 deletions.
2 changes: 1 addition & 1 deletion GNUmakefile
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ ARGOCD_INSECURE?=true
ARGOCD_SERVER?=127.0.0.1:8080
ARGOCD_AUTH_USERNAME?=admin
ARGOCD_AUTH_PASSWORD?=acceptancetesting
ARGOCD_VERSION?=v2.8.3
ARGOCD_VERSION?=v2.9.3

export

Expand Down
12 changes: 10 additions & 2 deletions argocd/resource_argocd_application_set.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ func resourceArgoCDApplicationSetCreate(ctx context.Context, d *schema.ResourceD
return featureNotSupported(features.ApplicationSet)
}

objectMeta, spec, err := expandApplicationSet(d, si.IsFeatureSupported(features.MultipleApplicationSources))
objectMeta, spec, err := expandApplicationSet(d, si.IsFeatureSupported(features.MultipleApplicationSources), si.IsFeatureSupported(features.ApplicationSetIgnoreApplicationDifferences))
if err != nil {
return errorToDiagnostics("failed to expand application set", err)
}
Expand All @@ -50,6 +50,10 @@ func resourceArgoCDApplicationSetCreate(ctx context.Context, d *schema.ResourceD
return featureNotSupported(features.ApplicationSetProgressiveSync)
}

if !si.IsFeatureSupported(features.ApplicationSetIgnoreApplicationDifferences) && spec.IgnoreApplicationDifferences != nil {
return featureNotSupported(features.ApplicationSetIgnoreApplicationDifferences)
}

if !si.IsFeatureSupported(features.ApplicationSetApplicationsSyncPolicy) && spec.SyncPolicy != nil && spec.SyncPolicy.ApplicationsSync != nil {
return featureNotSupported(features.ApplicationSetApplicationsSyncPolicy)
}
Expand Down Expand Up @@ -122,7 +126,7 @@ func resourceArgoCDApplicationSetUpdate(ctx context.Context, d *schema.ResourceD
return nil
}

objectMeta, spec, err := expandApplicationSet(d, si.IsFeatureSupported(features.MultipleApplicationSources))
objectMeta, spec, err := expandApplicationSet(d, si.IsFeatureSupported(features.MultipleApplicationSources), si.IsFeatureSupported(features.ApplicationSetIgnoreApplicationDifferences))
if err != nil {
return errorToDiagnostics(fmt.Sprintf("failed to expand application set %s", d.Id()), err)
}
Expand All @@ -131,6 +135,10 @@ func resourceArgoCDApplicationSetUpdate(ctx context.Context, d *schema.ResourceD
return featureNotSupported(features.ApplicationSetProgressiveSync)
}

if !si.IsFeatureSupported(features.ApplicationSetIgnoreApplicationDifferences) && spec.IgnoreApplicationDifferences != nil {
return featureNotSupported(features.ApplicationSetIgnoreApplicationDifferences)
}

if !si.IsFeatureSupported(features.ApplicationSetApplicationsSyncPolicy) && spec.SyncPolicy != nil && spec.SyncPolicy.ApplicationsSync != nil {
return featureNotSupported(features.ApplicationSetApplicationsSyncPolicy)
}
Expand Down
30 changes: 30 additions & 0 deletions argocd/schema_application_set.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,36 @@ func applicationSetSpecSchemaV0() *schema.Schema {
Required: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"ignore_application_differences": {
Type: schema.TypeList,
Description: "Application Set [ignoreApplicationDifferences](https://argo-cd.readthedocs.io/en/stable/operator-manual/applicationset/Controlling-Resource-Modification/#ignore-certain-changes-to-applications).",
Optional: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"json_pointers": {
Type: schema.TypeSet,
Description: "Json pointers to ignore differences",
Optional: true,
Elem: &schema.Schema{
Type: schema.TypeString,
},
},
"jq_path_expressions": {
Type: schema.TypeSet,
Description: "jq path to ignore differences",
Optional: true,
Elem: &schema.Schema{
Type: schema.TypeString,
},
},
"name": {
Type: schema.TypeString,
Description: "name",
Optional: true,
},
},
},
},
"generator": applicationSetGeneratorSchemaV0(),
"go_template": {
Type: schema.TypeBool,
Expand Down
61 changes: 58 additions & 3 deletions argocd/structure_application_set.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,14 @@ import (
meta "k8s.io/apimachinery/pkg/apis/meta/v1"
)

func expandApplicationSet(d *schema.ResourceData, featureMultipleApplicationSourcesSupported bool) (metadata meta.ObjectMeta, spec application.ApplicationSetSpec, err error) {
func expandApplicationSet(d *schema.ResourceData, featureMultipleApplicationSourcesSupported bool, featureApplicationSetIgnoreApplicationDifferences bool) (metadata meta.ObjectMeta, spec application.ApplicationSetSpec, err error) {
metadata = expandMetadata(d)
spec, err = expandApplicationSetSpec(d, featureMultipleApplicationSourcesSupported)
spec, err = expandApplicationSetSpec(d, featureMultipleApplicationSourcesSupported, featureApplicationSetIgnoreApplicationDifferences)

return
}

func expandApplicationSetSpec(d *schema.ResourceData, featureMultipleApplicationSourcesSupported bool) (spec application.ApplicationSetSpec, err error) {
func expandApplicationSetSpec(d *schema.ResourceData, featureMultipleApplicationSourcesSupported bool, featureApplicationSetIgnoreApplicationDifferences bool) (spec application.ApplicationSetSpec, err error) {
s := d.Get("spec.0").(map[string]interface{})

if v, ok := s["generator"].([]interface{}); ok && len(v) > 0 {
Expand All @@ -42,6 +42,13 @@ func expandApplicationSetSpec(d *schema.ResourceData, featureMultipleApplication
spec.SyncPolicy = expandApplicationSetSyncPolicy(v[0].(map[string]interface{}))
}

if v, ok := s["ignore_application_differences"].([]interface{}); ok && len(v) > 0 {
spec.IgnoreApplicationDifferences = expandApplicationSetIgnoreDifferences(v, featureApplicationSetIgnoreApplicationDifferences)
if err != nil {

Check failure on line 47 in argocd/structure_application_set.go

View workflow job for this annotation

GitHub Actions / Build

if statements should only be cuddled with assignments used in the if statement itself (wsl)
return
}
}

if v, ok := s["template"].([]interface{}); ok && len(v) > 0 {
spec.Template, err = expandApplicationSetTemplate(v[0], featureMultipleApplicationSourcesSupported)
if err != nil {
Expand Down Expand Up @@ -867,6 +874,39 @@ func expandApplicationSetTemplateMeta(meta interface{}) (metadata application.Ap
return metadata, nil
}

func expandApplicationSetIgnoreDifferences(ids []interface{}, featureApplicationSetIgnoreApplicationDifferences bool) (result []application.ApplicationSetResourceIgnoreDifferences) {
if !featureApplicationSetIgnoreApplicationDifferences {
return
}

for _, _id := range ids {
id := _id.(map[string]interface{})

var elem = application.ApplicationSetResourceIgnoreDifferences{}

if v, ok := id["json_pointers"]; ok {
jps := v.(*schema.Set).List()
for _, jp := range jps {
elem.JSONPointers = append(elem.JSONPointers, jp.(string))
}
}

if v, ok := id["jq_path_expressions"]; ok {
jqpes := v.(*schema.Set).List()
for _, jqpe := range jqpes {
elem.JQPathExpressions = append(elem.JQPathExpressions, jqpe.(string))
}
}

if v, ok := id["name"]; ok {
elem.Name = v.(string)
}

result = append(result, elem)
}

return //nolint:nakedret // overriding as function follows pattern in rest of file
}
func flattenApplicationSet(as *application.ApplicationSet, d *schema.ResourceData) error {
fMetadata := flattenMetadata(as.ObjectMeta, d)
if err := d.Set("metadata", fMetadata); err != nil {
Expand Down Expand Up @@ -913,9 +953,24 @@ func flattenApplicationSetSpec(s application.ApplicationSetSpec) ([]map[string]i
spec["sync_policy"] = flattenApplicationSetSyncPolicy(*s.SyncPolicy)
}

if s.IgnoreApplicationDifferences != nil {
spec["ignore_application_differences"] = flattenApplicationSetIgnoreDifferences(s.IgnoreApplicationDifferences)
}

return []map[string]interface{}{spec}, nil
}

func flattenApplicationSetIgnoreDifferences(ids application.ApplicationSetIgnoreDifferences) (result []map[string]interface{}) {
for _, id := range ids {
result = append(result, map[string]interface{}{
"name": id.Name,
"json_pointers": id.JSONPointers,
"jq_path_expressions": id.JQPathExpressions,
})
}

return
}
func flattenGenerator(g application.ApplicationSetGenerator) (map[string]interface{}, error) {
generator := map[string]interface{}{}

Expand Down
11 changes: 11 additions & 0 deletions docs/resources/application_set.md
Original file line number Diff line number Diff line change
Expand Up @@ -598,6 +598,7 @@ Required:
Optional:

- `go_template` (Boolean) Enable use of [Go Text Template](https://pkg.go.dev/text/template).
- `ignore_application_differences` (Block List) Application Set [ignoreApplicationDifferences](https://argo-cd.readthedocs.io/en/stable/operator-manual/applicationset/Controlling-Resource-Modification/#ignore-certain-changes-to-applications). (see [below for nested schema](#nestedblock--spec--ignore_application_differences))
- `strategy` (Block List, Max: 1) [Progressive Sync](https://argo-cd.readthedocs.io/en/stable/operator-manual/applicationset/Progressive-Syncs/) strategy (see [below for nested schema](#nestedblock--spec--strategy))
- `sync_policy` (Block List, Max: 1) Application Set [sync policy](https://argo-cd.readthedocs.io/en/stable/operator-manual/applicationset/Controlling-Resource-Modification/). (see [below for nested schema](#nestedblock--spec--sync_policy))

Expand Down Expand Up @@ -15524,6 +15525,16 @@ Optional:



<a id="nestedblock--spec--ignore_application_differences"></a>
### Nested Schema for `spec.ignore_application_differences`

Optional:

- `jq_path_expressions` (List of String) Json pointers to ignore differences
- `json_pointers` (List of String) Json pointers to ignore differences
- `name` (String) Json pointers to ignore differences


<a id="nestedblock--spec--strategy"></a>
### Nested Schema for `spec.strategy`

Expand Down
Loading

0 comments on commit a66d0a3

Please sign in to comment.