From 27eda4ece6bbe26b76f48fae40962b7c93fe6add Mon Sep 17 00:00:00 2001 From: Gaspard Micol Date: Wed, 18 Sep 2024 14:31:08 -0400 Subject: [PATCH 1/3] [bugfix] Fix undeployment on destroy by checking first if template is deployed for resource mso_schema_site. --- mso/resource_mso_schema_site.go | 65 +++++++++++++++++++++------------ 1 file changed, 41 insertions(+), 24 deletions(-) diff --git a/mso/resource_mso_schema_site.go b/mso/resource_mso_schema_site.go index aef72a6c..45e8755e 100644 --- a/mso/resource_mso_schema_site.go +++ b/mso/resource_mso_schema_site.go @@ -205,31 +205,48 @@ func resourceMSOSchemaSiteDelete(d *schema.ResourceData, m interface{}) error { siteId := d.Get("site_id").(string) templateName := d.Get("template_name").(string) - versionInt, err := msoClient.CompareVersion("3.7.0.0") - - if d.Get("undeploy_on_destroy").(bool) && versionInt == -1 { - payload, err := container.ParseJSON([]byte(fmt.Sprintf(`{"schemaId": "%s", "templateName": "%s", "undeploy": ["%s"]}`, schemaId, templateName, siteId))) - if err != nil { - log.Printf("[DEBUG] Parse of JSON failed with err: %s.", err) - return err - } - req, err := msoClient.MakeRestRequest("POST", "api/v1/task", payload, true) - if err != nil { - log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) - return err - } - _, resp, err := msoClient.Do(req) - if err != nil || resp.StatusCode != 202 { - log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) - return err - } - } else if d.Get("undeploy_on_destroy").(bool) && err == nil { - _, err := msoClient.GetViaURL(fmt.Sprintf("/api/v1/execute/schema/%s/template/%s?undeploy=%s", schemaId, templateName, siteId)) - if err != nil { - return err + req, err := msoClient.MakeRestRequest("GET", fmt.Sprintf("api/v1/deploy/status/schema/%s/template/%s", schemaId, templateName), nil, true) + if err != nil { + log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) + return err + } + obj, resp, err := msoClient.Do(req) + if err != nil || resp.StatusCode != 200 { + log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) + return err + } + if deployMap, ok := obj.Data().(map[string]interface{}); ok { + if statusList, ok := deployMap["status"].([]map[string]interface{}); ok && len(statusList) > 0 { + for _, statusMap := range statusList { + if statusMap["siteId"] == siteId && statusMap["status"].(map[string]interface{})["siteStatus"] == "Succeeded" { + versionInt, err := msoClient.CompareVersion("3.7.0.0") + if d.Get("undeploy_on_destroy").(bool) && versionInt == -1 { + payload, err := container.ParseJSON([]byte(fmt.Sprintf(`{"schemaId": "%s", "templateName": "%s", "undeploy": ["%s"]}`, schemaId, templateName, siteId))) + if err != nil { + log.Printf("[DEBUG] Parse of JSON failed with err: %s.", err) + return err + } + req, err := msoClient.MakeRestRequest("POST", "api/v1/task", payload, true) + if err != nil { + log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) + return err + } + _, resp, err := msoClient.Do(req) + if err != nil || resp.StatusCode != 202 { + log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) + return err + } + } else if d.Get("undeploy_on_destroy").(bool) && err == nil { + _, err := msoClient.GetViaURL(fmt.Sprintf("/api/v1/execute/schema/%s/template/%s?undeploy=%s", schemaId, templateName, siteId)) + if err != nil { + return err + } + } else if d.Get("undeploy_on_destroy").(bool) { + log.Printf("[WARNING] Failed to compare version. Template could not be undeployed prior to schema site deletion. Err: %s.", err) + } + } + } } - } else if d.Get("undeploy_on_destroy").(bool) { - log.Printf("[WARNING] Failed to compare version. Template could not be undeployed prior to schema site deletion. Err: %s.", err) } schemasite := models.NewSchemaSite("remove", fmt.Sprintf("/sites/%s-%s", siteId, templateName), siteId, templateName) From 9c8df05f8f62fc709a7c93fd08c9a508a247ee2a Mon Sep 17 00:00:00 2001 From: Gaspard Micol Date: Wed, 18 Sep 2024 19:35:38 -0400 Subject: [PATCH 2/3] [ignore] Adjust undeployment conditions to reduce API calls and update example for resource schema_site. --- examples/schema_site/main.tf | 19 ++++---- mso/resource_mso_schema_site.go | 77 +++++++++++++++++---------------- 2 files changed, 51 insertions(+), 45 deletions(-) diff --git a/examples/schema_site/main.tf b/examples/schema_site/main.tf index 69804eb8..808ca15e 100644 --- a/examples/schema_site/main.tf +++ b/examples/schema_site/main.tf @@ -50,9 +50,12 @@ resource "mso_tenant" "tenant_1" { } resource "mso_schema" "schema_1" { - name = var.schema_name - template_name = var.template_name - tenant_id = mso_tenant.tenant_1.id + name = var.schema_name + template { + tenant_id = mso_tenant.tenant_1.id + name = var.template_name + display_name = var.template_name + } } resource "mso_schema_site" "schema_site_1" { @@ -61,10 +64,10 @@ resource "mso_schema_site" "schema_site_1" { template_name = var.template_name } -// when a template should be undeployed from site before disassociation the 'undeploy_on_delete' argument should be set to true prior to terraform destroy +// when a template should be undeployed from site before disassociation the 'undeploy_on_destroy' argument should be set to true prior to terraform destroy resource "mso_schema_site" "schema_site_2" { - schema_id = mso_schema.schema_1.id - site_id = mso_site.site_test_1.id - template_name = var.template_name - undeploy_on_delete = true + schema_id = mso_schema.schema_1.id + site_id = mso_site.site_test_1.id + template_name = var.template_name + undeploy_on_destroy = true } \ No newline at end of file diff --git a/mso/resource_mso_schema_site.go b/mso/resource_mso_schema_site.go index 45e8755e..195e7b5e 100644 --- a/mso/resource_mso_schema_site.go +++ b/mso/resource_mso_schema_site.go @@ -205,44 +205,47 @@ func resourceMSOSchemaSiteDelete(d *schema.ResourceData, m interface{}) error { siteId := d.Get("site_id").(string) templateName := d.Get("template_name").(string) - req, err := msoClient.MakeRestRequest("GET", fmt.Sprintf("api/v1/deploy/status/schema/%s/template/%s", schemaId, templateName), nil, true) - if err != nil { - log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) - return err - } - obj, resp, err := msoClient.Do(req) - if err != nil || resp.StatusCode != 200 { - log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) - return err - } - if deployMap, ok := obj.Data().(map[string]interface{}); ok { - if statusList, ok := deployMap["status"].([]map[string]interface{}); ok && len(statusList) > 0 { - for _, statusMap := range statusList { - if statusMap["siteId"] == siteId && statusMap["status"].(map[string]interface{})["siteStatus"] == "Succeeded" { - versionInt, err := msoClient.CompareVersion("3.7.0.0") - if d.Get("undeploy_on_destroy").(bool) && versionInt == -1 { - payload, err := container.ParseJSON([]byte(fmt.Sprintf(`{"schemaId": "%s", "templateName": "%s", "undeploy": ["%s"]}`, schemaId, templateName, siteId))) - if err != nil { - log.Printf("[DEBUG] Parse of JSON failed with err: %s.", err) - return err - } - req, err := msoClient.MakeRestRequest("POST", "api/v1/task", payload, true) - if err != nil { - log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) - return err - } - _, resp, err := msoClient.Do(req) - if err != nil || resp.StatusCode != 202 { - log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) - return err - } - } else if d.Get("undeploy_on_destroy").(bool) && err == nil { - _, err := msoClient.GetViaURL(fmt.Sprintf("/api/v1/execute/schema/%s/template/%s?undeploy=%s", schemaId, templateName, siteId)) - if err != nil { - return err + if d.Get("undeploy_on_destroy").(bool) { + req, err := msoClient.MakeRestRequest("GET", fmt.Sprintf("mso/api/v1/deploy/status/schema/%s/template/%s", schemaId, templateName), nil, true) + if err != nil { + log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) + return err + } + obj, resp, err := msoClient.Do(req) + if err != nil || resp.StatusCode != 200 { + log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) + return err + } + if deployMap, ok := obj.Data().(map[string]interface{}); ok { + if statusList, ok := deployMap["status"].([]map[string]interface{}); ok && len(statusList) > 0 { + for _, statusMap := range statusList { + if statusMap["siteId"] == siteId && statusMap["status"].(map[string]interface{})["siteStatus"] == "Succeeded" { + versionInt, err := msoClient.CompareVersion("3.7.0.0") + if versionInt == -1 { + payload, err := container.ParseJSON([]byte(fmt.Sprintf(`{"schemaId": "%s", "templateName": "%s", "undeploy": ["%s"]}`, schemaId, templateName, siteId))) + if err != nil { + log.Printf("[DEBUG] Parse of JSON failed with err: %s.", err) + return err + } + req, err := msoClient.MakeRestRequest("POST", "api/v1/task", payload, true) + if err != nil { + log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) + return err + } + _, resp, err := msoClient.Do(req) + if err != nil || resp.StatusCode != 202 { + log.Printf("[DEBUG] Request failed with resp: %v. Err: %s.", resp, err) + return err + } + } else if err == nil { + _, err := msoClient.GetViaURL(fmt.Sprintf("/api/v1/execute/schema/%s/template/%s?undeploy=%s", schemaId, templateName, siteId)) + if err != nil { + return err + } + } else { + log.Printf("[WARNING] Failed to compare version. Template could not be undeployed prior to schema site deletion. Err: %s.", err) } - } else if d.Get("undeploy_on_destroy").(bool) { - log.Printf("[WARNING] Failed to compare version. Template could not be undeployed prior to schema site deletion. Err: %s.", err) + break } } } From 76a652765ecd5ad18a473840cbf8340d6de57b4f Mon Sep 17 00:00:00 2001 From: Gaspard Micol Date: Tue, 1 Oct 2024 12:28:50 -0400 Subject: [PATCH 3/3] [ignore] Modify URL for getting deployment status and Adjust conditions for deployment status. --- mso/resource_mso_schema_site.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/mso/resource_mso_schema_site.go b/mso/resource_mso_schema_site.go index 195e7b5e..a065dccc 100644 --- a/mso/resource_mso_schema_site.go +++ b/mso/resource_mso_schema_site.go @@ -206,7 +206,7 @@ func resourceMSOSchemaSiteDelete(d *schema.ResourceData, m interface{}) error { templateName := d.Get("template_name").(string) if d.Get("undeploy_on_destroy").(bool) { - req, err := msoClient.MakeRestRequest("GET", fmt.Sprintf("mso/api/v1/deploy/status/schema/%s/template/%s", schemaId, templateName), nil, true) + req, err := msoClient.MakeRestRequest("GET", fmt.Sprintf("api/v1/deploy/status/schema/%s/template/%s", schemaId, templateName), nil, true) if err != nil { log.Printf("[DEBUG] MakeRestRequest failed with err: %s.", err) return err @@ -217,9 +217,9 @@ func resourceMSOSchemaSiteDelete(d *schema.ResourceData, m interface{}) error { return err } if deployMap, ok := obj.Data().(map[string]interface{}); ok { - if statusList, ok := deployMap["status"].([]map[string]interface{}); ok && len(statusList) > 0 { + if statusList, ok := deployMap["status"].([]interface{}); ok && len(statusList) > 0 { for _, statusMap := range statusList { - if statusMap["siteId"] == siteId && statusMap["status"].(map[string]interface{})["siteStatus"] == "Succeeded" { + if statusMap.(map[string]interface{})["siteId"] == siteId && statusMap.(map[string]interface{})["status"].(map[string]interface{})["siteStatus"] == "Succeeded" { versionInt, err := msoClient.CompareVersion("3.7.0.0") if versionInt == -1 { payload, err := container.ParseJSON([]byte(fmt.Sprintf(`{"schemaId": "%s", "templateName": "%s", "undeploy": ["%s"]}`, schemaId, templateName, siteId)))