Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: Add support for usage tracking to data sources #3224

Merged
merged 4 commits into from
Nov 26, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 9 additions & 7 deletions pkg/datasources/accounts.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ import (
"context"
"log"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/snowflakeroles"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/sdk"
Expand Down Expand Up @@ -110,19 +113,18 @@ var accountsSchema = map[string]*schema.Schema{
// Accounts Snowflake Accounts resource.
func Accounts() *schema.Resource {
return &schema.Resource{
Read: ReadAccounts,
Schema: accountsSchema,
ReadContext: TrackingReadWrapper(datasources.Accounts, ReadAccounts),
Schema: accountsSchema,
}
}

// ReadAccounts lists accounts.
func ReadAccounts(d *schema.ResourceData, meta interface{}) error {
func ReadAccounts(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
client := meta.(*provider.Context).Client
ctx := context.Background()

ok, err := client.ContextFunctions.IsRoleInSession(ctx, snowflakeroles.Orgadmin)
if err != nil {
return err
return diag.FromErr(err)
}
if !ok {
log.Printf("[DEBUG] ORGADMIN role is not in current session, cannot read accounts")
Expand All @@ -136,7 +138,7 @@ func ReadAccounts(d *schema.ResourceData, meta interface{}) error {
}
accounts, err := client.Accounts.Show(ctx, opts)
if err != nil {
return err
return diag.FromErr(err)
}
d.SetId("accounts")
accountsFlatten := []map[string]interface{}{}
Expand All @@ -161,7 +163,7 @@ func ReadAccounts(d *schema.ResourceData, meta interface{}) error {
accountsFlatten = append(accountsFlatten, m)
}
if err := d.Set("accounts", accountsFlatten); err != nil {
return err
return diag.FromErr(err)
}
return nil
}
14 changes: 8 additions & 6 deletions pkg/datasources/alerts.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ import (
"context"
"log"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/sdk"
Expand Down Expand Up @@ -76,15 +79,14 @@ var alertsSchema = map[string]*schema.Schema{
// Alerts Snowflake Roles resource.
func Alerts() *schema.Resource {
return &schema.Resource{
Read: ReadAlerts,
Schema: alertsSchema,
ReadContext: TrackingReadWrapper(datasources.Alerts, ReadAlerts),
Schema: alertsSchema,
}
}

// ReadAlerts Reads the database metadata information.
func ReadAlerts(d *schema.ResourceData, meta interface{}) error {
func ReadAlerts(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
client := meta.(*provider.Context).Client
ctx := context.Background()

d.SetId("alerts_read")

Expand Down Expand Up @@ -114,7 +116,7 @@ func ReadAlerts(d *schema.ResourceData, meta interface{}) error {
if err != nil {
log.Printf("[DEBUG] failed to list alerts in schema (%s)", d.Id())
d.SetId("")
return err
return diag.FromErr(err)
}

alerts := make([]map[string]any, 0, len(listAlerts))
Expand All @@ -127,7 +129,7 @@ func ReadAlerts(d *schema.ResourceData, meta interface{}) error {
}

if err := d.Set("alerts", alerts); err != nil {
return err
return diag.FromErr(err)
}
return nil
}
12 changes: 12 additions & 0 deletions pkg/datasources/common.go
Original file line number Diff line number Diff line change
@@ -1,10 +1,15 @@
package datasources

import (
"context"
"fmt"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/tracking"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/resources"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/sdk"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
)

Expand Down Expand Up @@ -205,3 +210,10 @@ func handleExtendedIn(d *schema.ResourceData, setField **sdk.ExtendedIn) error {
}
return nil
}

func TrackingReadWrapper(datasourceName datasources.Datasource, readImplementation schema.ReadContextFunc) schema.ReadContextFunc {
return func(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
ctx = tracking.NewContext(ctx, tracking.NewVersionedDatasourceMetadata(datasourceName))
return readImplementation(ctx, d, meta)
}
}
4 changes: 3 additions & 1 deletion pkg/datasources/connections.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package datasources
import (
"context"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/resources"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/schemas"
Expand Down Expand Up @@ -34,7 +36,7 @@ var connectionsSchema = map[string]*schema.Schema{

func Connections() *schema.Resource {
return &schema.Resource{
ReadContext: ReadConnections,
ReadContext: TrackingReadWrapper(datasources.Connections, ReadConnections),
Schema: connectionsSchema,
Description: "Datasource used to get details of filtered connections. Filtering is aligned with the current possibilities for [SHOW CONNECTIONS](https://docs.snowflake.com/en/sql-reference/sql/show-connections) query. The results of SHOW is encapsulated in one output collection `connections`.",
}
Expand Down
13 changes: 8 additions & 5 deletions pkg/datasources/cortex_search_services.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ import (
"context"
"log"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/sdk"
Expand Down Expand Up @@ -108,13 +111,13 @@ var cortexSearchServicesSchema = map[string]*schema.Schema{
// CortexSearchServices Snowflake Cortex search services resource.
func CortexSearchServices() *schema.Resource {
return &schema.Resource{
Read: ReadCortexSearchServices,
Schema: cortexSearchServicesSchema,
ReadContext: TrackingReadWrapper(datasources.CortexSearchServices, ReadCortexSearchServices),
Schema: cortexSearchServicesSchema,
}
}

// ReadCortexSearchServices Reads the cortex search services metadata information.
func ReadCortexSearchServices(d *schema.ResourceData, meta interface{}) error {
func ReadCortexSearchServices(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
client := meta.(*provider.Context).Client
request := sdk.NewShowCortexSearchServiceRequest()

Expand Down Expand Up @@ -167,7 +170,7 @@ func ReadCortexSearchServices(d *schema.ResourceData, meta interface{}) error {
if err != nil {
log.Printf("[DEBUG] snowflake_cortex_search_services.go: %v", err)
d.SetId("")
return err
return diag.FromErr(err)
}
d.SetId("cortex_search_services")
records := make([]map[string]any, 0, len(dts))
Expand All @@ -181,7 +184,7 @@ func ReadCortexSearchServices(d *schema.ResourceData, meta interface{}) error {
records = append(records, record)
}
if err := d.Set("cortex_search_services", records); err != nil {
return err
return diag.FromErr(err)
}
return nil
}
16 changes: 9 additions & 7 deletions pkg/datasources/current_account.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ import (
"fmt"
"log"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"

"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
Expand Down Expand Up @@ -33,15 +36,14 @@ var currentAccountSchema = map[string]*schema.Schema{
// CurrentAccount the Snowflake current account resource.
func CurrentAccount() *schema.Resource {
return &schema.Resource{
Read: ReadCurrentAccount,
Schema: currentAccountSchema,
ReadContext: TrackingReadWrapper(datasources.CurrentAccount, ReadCurrentAccount),
Schema: currentAccountSchema,
}
}

// ReadCurrentAccount read the current snowflake account information.
func ReadCurrentAccount(d *schema.ResourceData, meta interface{}) error {
func ReadCurrentAccount(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
client := meta.(*provider.Context).Client
ctx := context.Background()

current, err := client.ContextFunctions.CurrentSessionDetails(ctx)
if err != nil {
Expand All @@ -53,11 +55,11 @@ func ReadCurrentAccount(d *schema.ResourceData, meta interface{}) error {
d.SetId(fmt.Sprintf("%s.%s", current.Account, current.Region))
accountErr := d.Set("account", current.Account)
if accountErr != nil {
return accountErr
return diag.FromErr(accountErr)
}
regionErr := d.Set("region", current.Region)
if regionErr != nil {
return regionErr
return diag.FromErr(regionErr)
}
url, err := current.AccountURL()
if err != nil {
Expand All @@ -67,7 +69,7 @@ func ReadCurrentAccount(d *schema.ResourceData, meta interface{}) error {

urlErr := d.Set("url", url)
if urlErr != nil {
return urlErr
return diag.FromErr(urlErr)
}
return nil
}
12 changes: 7 additions & 5 deletions pkg/datasources/current_role.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ import (
"context"
"log"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/helpers"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
Expand All @@ -19,14 +22,13 @@ var currentRoleSchema = map[string]*schema.Schema{

func CurrentRole() *schema.Resource {
return &schema.Resource{
Read: ReadCurrentRole,
Schema: currentRoleSchema,
ReadContext: TrackingReadWrapper(datasources.CurrentRole, ReadCurrentRole),
Schema: currentRoleSchema,
}
}

func ReadCurrentRole(d *schema.ResourceData, meta interface{}) error {
func ReadCurrentRole(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
client := meta.(*provider.Context).Client
ctx := context.Background()

role, err := client.ContextFunctions.CurrentRole(ctx)
if err != nil {
Expand All @@ -38,7 +40,7 @@ func ReadCurrentRole(d *schema.ResourceData, meta interface{}) error {
d.SetId(helpers.EncodeSnowflakeID(role))
err = d.Set("name", role.Name())
if err != nil {
return err
return diag.FromErr(err)
}
return nil
}
30 changes: 16 additions & 14 deletions pkg/datasources/database.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ package datasources
import (
"context"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/datasources"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/helpers"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/internal/provider"
Expand Down Expand Up @@ -54,52 +57,51 @@ var databaseSchema = map[string]*schema.Schema{
// Database the Snowflake Database resource.
func Database() *schema.Resource {
return &schema.Resource{
Read: ReadDatabase,
Schema: databaseSchema,
ReadContext: TrackingReadWrapper(datasources.Database, ReadDatabase),
Schema: databaseSchema,
}
}

// ReadDatabase read the database meta-data information.
func ReadDatabase(d *schema.ResourceData, meta interface{}) error {
func ReadDatabase(ctx context.Context, d *schema.ResourceData, meta any) diag.Diagnostics {
client := meta.(*provider.Context).Client
ctx := context.Background()
name := d.Get("name").(string)
id := sdk.NewAccountObjectIdentifier(name)
database, err := client.Databases.ShowByID(ctx, id)
if err != nil {
return err
return diag.FromErr(err)
}
d.SetId(helpers.EncodeResourceIdentifier(database.ID()))
if err := d.Set("name", database.Name); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("comment", database.Comment); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("owner", database.Owner); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("is_default", database.IsDefault); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("is_current", database.IsCurrent); err != nil {
return err
return diag.FromErr(err)
}
var origin string
if database.Origin != nil {
origin = database.Origin.FullyQualifiedName()
}
if err := d.Set("origin", origin); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("retention_time", database.RetentionTime); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("created_on", database.CreatedOn.String()); err != nil {
return err
return diag.FromErr(err)
}
if err := d.Set("options", database.Options); err != nil {
return err
return diag.FromErr(err)
}
return nil
}
Loading
Loading