From d413bbd9e53affbb6e25e6d43b96a3a126e773e4 Mon Sep 17 00:00:00 2001 From: DodinViorel Date: Tue, 16 Apr 2024 18:44:29 +0300 Subject: [PATCH] Service principal fix and plugin name fixes (#7) * Fix for service principal auth (#7) Signed-off-by: Viorel Dodin * Fix naming from cop to observability (#8) Various errors were encountered during testing. Binnary plugin name and provider name must match. Signed-off-by: Viorel Dodin --------- Signed-off-by: Viorel Dodin --- .../data-sources/cop_example/data-source.tf | 17 +++++----- examples/provider/provider_oauth.tf | 6 ++-- .../provider/provider_service_principal.tf | 6 ++-- examples/resources/cop_example/resource.tf | 8 ++--- internal/api/objectapi.go | 5 +-- internal/api/typeapi.go | 5 +-- internal/provider/provider.go | 32 +++++++++---------- main.go | 2 +- 8 files changed, 38 insertions(+), 43 deletions(-) diff --git a/examples/data-sources/cop_example/data-source.tf b/examples/data-sources/cop_example/data-source.tf index ca695bc..d2541fd 100644 --- a/examples/data-sources/cop_example/data-source.tf +++ b/examples/data-sources/cop_example/data-source.tf @@ -6,23 +6,24 @@ terraform { required_providers { - cop = { - source = "testTerraform.com/appd/cop" + observability = { + source = "testTerraform.com/appd/observability" } } } -provider "cop" { - tenant = "47a01df9-54a0-472b-96b8-7c8f64eb7cbf" - auth_method = "oauth" - url = "https://alameda-c0-test-02.saas.appd-test.com" +provider "observability" { + tenant="0eb4e853-34fb-4f77-b3fc-b9cd3b462366" + auth_method="service-principal" + url="https://aiops-dev.saas.appd-test.com" + secrets_file="/home/vdodin/aiops_secret.json" } -data "cop_type" "ns" { +data "observability_type" "ns" { type_name = "fmm:namespace" } output "myType" { - value = data.cop_type.ns + value = data.observability_type.ns } diff --git a/examples/provider/provider_oauth.tf b/examples/provider/provider_oauth.tf index 9a17c99..604a5f8 100644 --- a/examples/provider/provider_oauth.tf +++ b/examples/provider/provider_oauth.tf @@ -6,13 +6,13 @@ terraform { required_providers { - cop = { - source = "testTerraform.com/appd/cop" + observability = { + source = "testTerraform.com/appd/observability" } } } -provider "cop" { +provider "observability" { tenant="47a01df9-54a0-472b-96b8-7c8f64eb7cbf" auth_method="oauth" url="https://alameda-c0-test-02.saas.appd-test.com" diff --git a/examples/provider/provider_service_principal.tf b/examples/provider/provider_service_principal.tf index 2d0bf3f..2872e67 100644 --- a/examples/provider/provider_service_principal.tf +++ b/examples/provider/provider_service_principal.tf @@ -6,13 +6,13 @@ terraform { required_providers { - cop = { - source = "testTerraform.com/appd/cop" + observability = { + source = "testTerraform.com/appd/observability" } } } -provider "cop" { +provider "observability" { tenant="47a01df9-54a0-472b-96b8-7c8f64eb7cbf" auth_method="service-principal" url="https://alameda-c0-test-02.saas.appd-test.com" diff --git a/examples/resources/cop_example/resource.tf b/examples/resources/cop_example/resource.tf index b2a475d..9f32337 100644 --- a/examples/resources/cop_example/resource.tf +++ b/examples/resources/cop_example/resource.tf @@ -6,19 +6,19 @@ terraform { required_providers { - cop = { - source = "testTerraform.com/appd/cop" + observability = { + source = "testTerraform.com/appd/observability" } } } -provider "cop" { +provider "observability" { tenant = "47a01df9-54a0-472b-96b8-7c8f64eb7cbf" auth_method = "oauth" url = "https://alameda-c0-test-02.saas.appd-test.com" } -resource "cop_object" "ns" { +resource "observability_object" "ns" { type_name = "fmm:namespace" object_id = "aws" layer_type = "TENANT" diff --git a/internal/api/objectapi.go b/internal/api/objectapi.go index 98e4415..86293b2 100644 --- a/internal/api/objectapi.go +++ b/internal/api/objectapi.go @@ -34,10 +34,7 @@ func (ac *AppdClient) GetObject(fullyQualifiedTypeName, objectID, layerID, layer req.Header.Add("Content-Type", contentType) req.Header.Add("Accept", contentType) - - if ac.AuthMethod == authMethodOAuth { - req.Header.Add("Authorization", "Bearer "+ac.Token) - } + req.Header.Add("Authorization", "Bearer "+ac.Token) req.Header.Add("layer-id", layerID) req.Header.Add("layer-type", layerType) diff --git a/internal/api/typeapi.go b/internal/api/typeapi.go index 4b9a486..d467cc6 100644 --- a/internal/api/typeapi.go +++ b/internal/api/typeapi.go @@ -27,10 +27,7 @@ func (ac *AppdClient) GetType(fullyQualifiedTypeName string) ([]byte, error) { req.Header.Add("Content-Type", contentType) req.Header.Add("Accept", contentType) - - if ac.AuthMethod == authMethodOAuth { - req.Header.Add("Authorization", "Bearer "+ac.Token) - } + req.Header.Add("Authorization", "Bearer "+ac.Token) // Do request resp, err := ac.APIClient.Do(req) diff --git a/internal/provider/provider.go b/internal/provider/provider.go index e5138c9..55f5f56 100644 --- a/internal/provider/provider.go +++ b/internal/provider/provider.go @@ -41,7 +41,7 @@ type COPProviderModel struct { } func (p *COPProvider) Metadata(_ context.Context, _ provider.MetadataRequest, resp *provider.MetadataResponse) { - resp.TypeName = "cop" + resp.TypeName = "observability" resp.Version = p.version } @@ -49,7 +49,7 @@ func (p *COPProvider) Schema(_ context.Context, _ provider.SchemaRequest, resp * resp.Schema = schema.Schema{ Attributes: map[string]schema.Attribute{ "auth_method": schema.StringAttribute{ - MarkdownDescription: "Authentication type selected for COP API requests. Possible values(oauth, headless, service-principal)", + MarkdownDescription: "Authentication type selected for observability API requests. Possible values(oauth, headless, service-principal)", Required: true, }, "tenant": schema.StringAttribute{ @@ -92,7 +92,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if data.AuthMethod.IsUnknown() { resp.Diagnostics.AddAttributeError( path.Root("auth_method"), - "Unknown cop API auth_method", + "Unknown observability API auth_method", "Please make sure you configure the auth_method field", ) } @@ -100,7 +100,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if data.Tenant.IsUnknown() { resp.Diagnostics.AddAttributeError( path.Root("tenant"), - "Unknown cop API tenant", + "Unknown observability API tenant", "Please make sure you configure the tenant field", ) } @@ -108,7 +108,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if data.Username.IsUnknown() { resp.Diagnostics.AddAttributeError( path.Root("username"), - "Unknown cop API username", + "Unknown observability API username", "Please make sure you configure the username field", ) } @@ -116,7 +116,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if data.Password.IsUnknown() { resp.Diagnostics.AddAttributeError( path.Root("password"), - "Unknown cop API password", + "Unknown observability API password", "Please make sure you configure the password field", ) } @@ -124,7 +124,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if data.URL.IsUnknown() { resp.Diagnostics.AddAttributeError( path.Root("url"), - "Unknown cop API url", + "Unknown observability API url", "Please make sure you configure the url field", ) } @@ -132,7 +132,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if data.URL.IsUnknown() { resp.Diagnostics.AddAttributeError( path.Root("secrets_file"), - "Unknown cop API secrets_file", + "Unknown observability API secrets_file", "Please make sure you configure the secrets_file field", ) } @@ -186,7 +186,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if authMethod == "" { resp.Diagnostics.AddAttributeError( path.Root("auth_method"), - "Missing cop API auth_method", + "Missing observability API auth_method", "SET the COP_AUTH_METHOD env var or the config", ) tflog.Error(ctx, "Missing or empty value for auth_method attribute") @@ -197,7 +197,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if url == "" { resp.Diagnostics.AddAttributeError( path.Root("url"), - "Missing cop API url", + "Missing observability API url", "SET the COP_URL env var or the config", ) } @@ -205,7 +205,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if tenantID == "" { resp.Diagnostics.AddAttributeError( path.Root("tenant"), - "Missing cop API tenant", + "Missing observability API tenant", "SET the COP_TENANT env var or the config", ) } @@ -213,7 +213,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if username == "" { resp.Diagnostics.AddAttributeError( path.Root("username"), - "Missing cop API username", + "Missing observability API username", "SET the COP_USERNAME env var or the config", ) } @@ -221,7 +221,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if password == "" { resp.Diagnostics.AddAttributeError( path.Root("password"), - "Missing cop API password", + "Missing observability API password", "SET the COP_PASSWORD env var or the config", ) } @@ -229,7 +229,7 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque if secretsFile == "" { resp.Diagnostics.AddAttributeError( path.Root("secrets_file"), - "Missing cop API secrets_file", + "Missing observability API secrets_file", "SET the SECRETS_FILE env var or the config", ) } @@ -253,10 +253,10 @@ func (p *COPProvider) Configure(ctx context.Context, req provider.ConfigureReque err := appdClient.Login() if err != nil { - tflog.Error(ctx, fmt.Sprintf("Failed to authenticate to COP client: %s", err.Error())) + tflog.Error(ctx, fmt.Sprintf("Failed to authenticate to observability client: %s", err.Error())) } - tflog.Debug(ctx, fmt.Sprintf("Successful authentication to COP client using %s", appdClient.AuthMethod)) + tflog.Debug(ctx, fmt.Sprintf("Successful authentication to observability client using %s", appdClient.AuthMethod)) // TODO change this to a real client resp.DataSourceData = appdClient diff --git a/main.go b/main.go index 9cb50a0..c748457 100644 --- a/main.go +++ b/main.go @@ -45,7 +45,7 @@ func main() { // TODO: Update this string with the published name of your provider. // Also update the tfplugindocs generate command to either remove the // -provider-name flag or set its value to the updated provider name. - Address: "testTerraform.com/appd/cop", + Address: "testTerraform.com/appd/observability", Debug: debug, }