From 847f02f4a11499a6878240997bb552563b6a3f48 Mon Sep 17 00:00:00 2001 From: Matthew Cummings Date: Sun, 17 Dec 2023 20:53:09 -0500 Subject: [PATCH] Add the environment context to evaluated templates --- .tool-versions | 2 +- cloudtruth/data_template.go | 11 ++++++----- cloudtruth/resource_template.go | 5 ++++- 3 files changed, 11 insertions(+), 7 deletions(-) diff --git a/.tool-versions b/.tool-versions index 118979e..51d646e 100644 --- a/.tool-versions +++ b/.tool-versions @@ -1 +1 @@ -golang 1.21.0 \ No newline at end of file +golang 1.21.5 \ No newline at end of file diff --git a/cloudtruth/data_template.go b/cloudtruth/data_template.go index 8c57a2b..72ad9aa 100644 --- a/cloudtruth/data_template.go +++ b/cloudtruth/data_template.go @@ -15,7 +15,8 @@ import ( func dataCloudTruthTemplate() *schema.Resource { return &schema.Resource{ - Description: "A CloudTruth template data source", + Description: `A CloudTruth template data source. Use this to reference the rendered values from CloudTruth +Templates in the context of a project and environment.`, ReadContext: dataCloudTruthTemplateRead, Schema: map[string]*schema.Schema{ "project": { @@ -97,7 +98,7 @@ func dataCloudTruthTemplateRead(ctx context.Context, d *schema.ResourceData, met body := template.GetBody() tflog.Debug(ctx, fmt.Sprintf("dataCloudTruthTemplateRead: template body - %s", body)) - previewBody, err := renderTemplateBody(ctx, name, body, *projID, meta) + previewBody, err := renderTemplateBody(ctx, name, body, *projID, *envID, meta) if err != nil { return diag.FromErr(err) } @@ -110,7 +111,7 @@ func dataCloudTruthTemplateRead(ctx context.Context, d *schema.ResourceData, met return nil } -func renderTemplateBody(ctx context.Context, name, body, projectID string, meta any) (*string, error) { +func renderTemplateBody(ctx context.Context, name, body, projectID, envID string, meta any) (*string, error) { tflog.Debug(ctx, "entering renderTemplateBody") defer tflog.Debug(ctx, "exiting renderTemplateBody") c := meta.(*cloudTruthClient) @@ -121,7 +122,7 @@ func renderTemplateBody(ctx context.Context, name, body, projectID string, meta // We cannot use the TF Provider SDK's retry functionality because it only works with state change events // so we employ a simple retry loop instead for retryCount < loadCacheRetries { - previewCreate, r, err := c.openAPIClient.ProjectsAPI.ProjectsTemplatePreviewCreate(ctx, projectID). + previewCreate, r, err := c.openAPIClient.ProjectsAPI.ProjectsTemplatePreviewCreate(ctx, projectID).Environment(envID). TemplatePreviewCreateRequest(*templatePrevReq).Execute() if r.StatusCode >= 500 { apiError = err @@ -218,7 +219,7 @@ func dataCloudTruthTemplatesRead(ctx context.Context, d *schema.ResourceData, me for _, res := range results { templateName := res.GetName() templateBody := res.GetBody() - previewBody, err := renderTemplateBody(ctx, templateName, templateBody, *projID, meta) + previewBody, err := renderTemplateBody(ctx, templateName, templateBody, *projID, *envID, meta) if err != nil { return diag.FromErr(fmt.Errorf("dataCloudTruthTemplatesRead: %w", err)) } else { diff --git a/cloudtruth/resource_template.go b/cloudtruth/resource_template.go index c49659a..b1a8c20 100644 --- a/cloudtruth/resource_template.go +++ b/cloudtruth/resource_template.go @@ -13,7 +13,10 @@ import ( func resourceTemplate() *schema.Resource { return &schema.Resource{ - Description: "A CloudTruth Template.", + Description: `A CloudTruth Template. Use this to manage Templates in your CloudTruth project +If you want to render a template in the context of a project and environment, use a cloudtruth_template +data source instead. The value for a cloudtruth_template resource is the raw unevaluated template string. +`, CreateContext: resourceTemplateCreate, ReadContext: resourceTemplateRead, UpdateContext: resourceTemplateUpdate,