Skip to content

Commit

Permalink
Add support for BigQuery table ACLs (#3856) (#7041)
Browse files Browse the repository at this point in the history
* Add support for BigQuery table ACLs

* Update terraform.yaml

removed the commented line

Co-authored-by: Edward Sun <[email protected]>
Signed-off-by: Modular Magician <[email protected]>

Co-authored-by: Edward Sun <[email protected]>
  • Loading branch information
modular-magician and Edward Sun authored Aug 17, 2020
1 parent 41e62f1 commit 7c2cbf5
Show file tree
Hide file tree
Showing 6 changed files with 816 additions and 2 deletions.
3 changes: 3 additions & 0 deletions .changelog/3856.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:enhancement
Add support for BigQuery table ACLs
```
200 changes: 200 additions & 0 deletions google/iam_big_query_table.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,200 @@
// ----------------------------------------------------------------------------
//
// *** AUTO GENERATED CODE *** AUTO GENERATED CODE ***
//
// ----------------------------------------------------------------------------
//
// This file is automatically generated by Magic Modules and manual
// changes will be clobbered when the file is regenerated.
//
// Please read more about how to change this file in
// .github/CONTRIBUTING.md.
//
// ----------------------------------------------------------------------------
package google

import (
"fmt"

"github.com/hashicorp/errwrap"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
"google.golang.org/api/cloudresourcemanager/v1"
)

var BigQueryTableIamSchema = map[string]*schema.Schema{
"project": {
Type: schema.TypeString,
Computed: true,
Optional: true,
ForceNew: true,
},
"dataset_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
"table_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
DiffSuppressFunc: compareSelfLinkOrResourceName,
},
}

type BigQueryTableIamUpdater struct {
project string
datasetId string
tableId string
d *schema.ResourceData
Config *Config
}

func BigQueryTableIamUpdaterProducer(d *schema.ResourceData, config *Config) (ResourceIamUpdater, error) {
values := make(map[string]string)

project, _ := getProject(d, config)
if project != "" {
d.Set("project", project)
}
values["project"] = project
if v, ok := d.GetOk("dataset_id"); ok {
values["dataset_id"] = v.(string)
}

if v, ok := d.GetOk("table_id"); ok {
values["table_id"] = v.(string)
}

// We may have gotten either a long or short name, so attempt to parse long name if possible
m, err := getImportIdQualifiers([]string{"projects/(?P<project>[^/]+)/datasets/(?P<dataset_id>[^/]+)/tables/(?P<table_id>[^/]+)", "(?P<project>[^/]+)/(?P<dataset_id>[^/]+)/(?P<table_id>[^/]+)", "(?P<dataset_id>[^/]+)/(?P<table_id>[^/]+)", "(?P<table_id>[^/]+)"}, d, config, d.Get("table_id").(string))
if err != nil {
return nil, err
}

for k, v := range m {
values[k] = v
}

u := &BigQueryTableIamUpdater{
project: values["project"],
datasetId: values["dataset_id"],
tableId: values["table_id"],
d: d,
Config: config,
}

d.Set("project", u.project)
d.Set("dataset_id", u.datasetId)
d.Set("table_id", u.GetResourceId())

return u, nil
}

func BigQueryTableIdParseFunc(d *schema.ResourceData, config *Config) error {
values := make(map[string]string)

project, _ := getProject(d, config)
if project != "" {
values["project"] = project
}

m, err := getImportIdQualifiers([]string{"projects/(?P<project>[^/]+)/datasets/(?P<dataset_id>[^/]+)/tables/(?P<table_id>[^/]+)", "(?P<project>[^/]+)/(?P<dataset_id>[^/]+)/(?P<table_id>[^/]+)", "(?P<dataset_id>[^/]+)/(?P<table_id>[^/]+)", "(?P<table_id>[^/]+)"}, d, config, d.Id())
if err != nil {
return err
}

for k, v := range m {
values[k] = v
}

u := &BigQueryTableIamUpdater{
project: values["project"],
datasetId: values["dataset_id"],
tableId: values["table_id"],
d: d,
Config: config,
}
d.Set("table_id", u.GetResourceId())
d.SetId(u.GetResourceId())
return nil
}

func (u *BigQueryTableIamUpdater) GetResourceIamPolicy() (*cloudresourcemanager.Policy, error) {
url, err := u.qualifyTableUrl("getIamPolicy")
if err != nil {
return nil, err
}

project, err := getProject(u.d, u.Config)
if err != nil {
return nil, err
}
var obj map[string]interface{}
obj = map[string]interface{}{
"options": map[string]interface{}{
"requestedPolicyVersion": 1,
},
}

policy, err := sendRequest(u.Config, "POST", project, url, obj)
if err != nil {
return nil, errwrap.Wrapf(fmt.Sprintf("Error retrieving IAM policy for %s: {{err}}", u.DescribeResource()), err)
}

out := &cloudresourcemanager.Policy{}
err = Convert(policy, out)
if err != nil {
return nil, errwrap.Wrapf("Cannot convert a policy to a resource manager policy: {{err}}", err)
}

return out, nil
}

func (u *BigQueryTableIamUpdater) SetResourceIamPolicy(policy *cloudresourcemanager.Policy) error {
json, err := ConvertToMap(policy)
if err != nil {
return err
}

// This is an override of the existing version that might have been set in the resource_iam_member|policy|binding code
json["version"] = 1
obj := make(map[string]interface{})
obj["policy"] = json

url, err := u.qualifyTableUrl("setIamPolicy")
if err != nil {
return err
}
project, err := getProject(u.d, u.Config)
if err != nil {
return err
}

_, err = sendRequestWithTimeout(u.Config, "POST", project, url, obj, u.d.Timeout(schema.TimeoutCreate))
if err != nil {
return errwrap.Wrapf(fmt.Sprintf("Error setting IAM policy for %s: {{err}}", u.DescribeResource()), err)
}

return nil
}

func (u *BigQueryTableIamUpdater) qualifyTableUrl(methodIdentifier string) (string, error) {
urlTemplate := fmt.Sprintf("{{BigQueryBasePath}}%s:%s", fmt.Sprintf("projects/%s/datasets/%s/tables/%s", u.project, u.datasetId, u.tableId), methodIdentifier)
url, err := replaceVars(u.d, u.Config, urlTemplate)
if err != nil {
return "", err
}
return url, nil
}

func (u *BigQueryTableIamUpdater) GetResourceId() string {
return fmt.Sprintf("projects/%s/datasets/%s/tables/%s", u.project, u.datasetId, u.tableId)
}

func (u *BigQueryTableIamUpdater) GetMutexKey() string {
return fmt.Sprintf("iam-bigquery-table-%s", u.GetResourceId())
}

func (u *BigQueryTableIamUpdater) DescribeResource() string {
return fmt.Sprintf("bigquery table %q", u.GetResourceId())
}
Loading

0 comments on commit 7c2cbf5

Please sign in to comment.