From ea70212c51956ca804339cb8f02f7811d8c57798 Mon Sep 17 00:00:00 2001 From: The Magician Date: Mon, 19 Nov 2018 14:34:41 -0800 Subject: [PATCH] Add support for data source google_iam_role (#142) /cc @rileykarson --- google-beta/data_source_google_iam_role.go | 48 +++++++++++++++++ .../data_source_google_iam_role_test.go | 51 +++++++++++++++++++ google-beta/provider.go | 1 + .../datasource_google_iam_role.html.markdown | 36 +++++++++++++ website/google.erb | 3 ++ 5 files changed, 139 insertions(+) create mode 100644 google-beta/data_source_google_iam_role.go create mode 100644 google-beta/data_source_google_iam_role_test.go create mode 100644 website/docs/d/datasource_google_iam_role.html.markdown diff --git a/google-beta/data_source_google_iam_role.go b/google-beta/data_source_google_iam_role.go new file mode 100644 index 0000000000..e96ae5fde0 --- /dev/null +++ b/google-beta/data_source_google_iam_role.go @@ -0,0 +1,48 @@ +package google + +import ( + "fmt" + + "github.com/hashicorp/terraform/helper/schema" +) + +func dataSourceGoogleIamRole() *schema.Resource { + return &schema.Resource{ + Read: dataSourceGoogleIamRoleRead, + Schema: map[string]*schema.Schema{ + "name": &schema.Schema{ + Type: schema.TypeString, + Required: true, + }, + "title": { + Type: schema.TypeString, + Computed: true, + }, + "included_permissions": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Schema{Type: schema.TypeString}, + }, + "stage": { + Type: schema.TypeString, + Computed: true, + }, + }, + } +} + +func dataSourceGoogleIamRoleRead(d *schema.ResourceData, meta interface{}) error { + config := meta.(*Config) + roleName := d.Get("name").(string) + role, err := config.clientIAM.Roles.Get(roleName).Do() + if err != nil { + return handleNotFoundError(err, d, fmt.Sprintf("Error reading IAM Role %s: %s", roleName, err)) + } + + d.SetId(role.Name) + d.Set("title", role.Title) + d.Set("stage", role.Stage) + d.Set("included_permissions", role.IncludedPermissions) + + return nil +} diff --git a/google-beta/data_source_google_iam_role_test.go b/google-beta/data_source_google_iam_role_test.go new file mode 100644 index 0000000000..cb58323a5d --- /dev/null +++ b/google-beta/data_source_google_iam_role_test.go @@ -0,0 +1,51 @@ +package google + +import ( + "errors" + "fmt" + "testing" + + "github.com/hashicorp/terraform/helper/resource" + "github.com/hashicorp/terraform/terraform" +) + +func TestAccDataSourceIAMRole(t *testing.T) { + name := "roles/viewer" + + resource.Test(t, resource.TestCase{ + PreCheck: func() { testAccPreCheck(t) }, + Providers: testAccProviders, + Steps: []resource.TestStep{ + { + Config: testAccCheckGoogleIamRoleConfig(name), + Check: resource.ComposeTestCheckFunc( + testAccCheckGoogleIAMRoleCheck("data.google_iam_role.role"), + ), + }, + }, + }) +} + +func testAccCheckGoogleIAMRoleCheck(n string) resource.TestCheckFunc { + return func(s *terraform.State) error { + ds, ok := s.RootModule().Resources[n] + if !ok { + return fmt.Errorf("Can't find iam role data source: %s", n) + } + + _, ok = ds.Primary.Attributes["included_permissions.#"] + if !ok { + return errors.New("can't find 'included_permissions' attribute") + } + + return nil + } +} + +func testAccCheckGoogleIamRoleConfig(name string) string { + return fmt.Sprintf(` +data "google_iam_role" "role" { + name = "%s" +} +`, name) +} diff --git a/google-beta/provider.go b/google-beta/provider.go index aabd3fbef5..7733987c17 100644 --- a/google-beta/provider.go +++ b/google-beta/provider.go @@ -87,6 +87,7 @@ func Provider() terraform.ResourceProvider { "google_container_registry_repository": dataSourceGoogleContainerRepo(), "google_container_registry_image": dataSourceGoogleContainerImage(), "google_iam_policy": dataSourceGoogleIamPolicy(), + "google_iam_role": dataSourceGoogleIamRole(), "google_kms_secret": dataSourceGoogleKmsSecret(), "google_folder": dataSourceGoogleFolder(), "google_netblock_ip_ranges": dataSourceGoogleNetblockIpRanges(), diff --git a/website/docs/d/datasource_google_iam_role.html.markdown b/website/docs/d/datasource_google_iam_role.html.markdown new file mode 100644 index 0000000000..77aebf4b89 --- /dev/null +++ b/website/docs/d/datasource_google_iam_role.html.markdown @@ -0,0 +1,36 @@ +--- +layout: "google" +page_title: "Google: google_iam_role" +sidebar_current: "docs-google-datasource-iam-role" +description: |- + Get information about a Google IAM Role. +--- + +# google\_iam\_role + +Use this data source to get information about a Google IAM Role. + +```hcl +data "google_iam_role" "roleinfo" { + name = "roles/compute.viewer" +} + +output "the_role_permissions" { + value = "${data.google_iam_role.roleinfo.included_permissions}" +} + +``` + +## Argument Reference + +The following arguments are supported: + +* `name` (Required) - The name of the Role to lookup in the form `roles/{ROLE_NAME}`, `organizations/{ORGANIZATION_ID}/roles/{ROLE_NAME}` or `projects/{PROJECT_ID}/roles/{ROLE_NAME}` + +## Attributes Reference + +The following attributes are exported: + +* `title` - is a friendly title for the role, such as "Role Viewer" +* `included_permissions` - specifies the list of one or more permissions to include in the custom role, such as - `iam.roles.get` +* `stage` - indicates the stage of a role in the launch lifecycle, such as `GA`, `BETA` or `ALPHA`. diff --git a/website/google.erb b/website/google.erb index e782085ab1..7375ec7b77 100644 --- a/website/google.erb +++ b/website/google.erb @@ -114,6 +114,9 @@ > google_iam_policy + > + google_iam_role + > google_kms_secret