-
Notifications
You must be signed in to change notification settings - Fork 264
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Adding datasources for folder and project org policy (#468)
<!-- This change is generated by MagicModules. --> /cc @chrisst
- Loading branch information
1 parent
ab0ac3d
commit 9ec09a4
Showing
8 changed files
with
279 additions
and
0 deletions.
There are no files selected for viewing
27 changes: 27 additions & 0 deletions
27
google-beta/data_source_google_folder_organization_policy.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
package google | ||
|
||
import ( | ||
"fmt" | ||
|
||
"github.com/hashicorp/terraform/helper/schema" | ||
) | ||
|
||
func dataSourceGoogleFolderOrganizationPolicy() *schema.Resource { | ||
// Generate datasource schema from resource | ||
dsSchema := datasourceSchemaFromResourceSchema(resourceGoogleFolderOrganizationPolicy().Schema) | ||
|
||
addRequiredFieldsToSchema(dsSchema, "folder") | ||
addRequiredFieldsToSchema(dsSchema, "constraint") | ||
|
||
return &schema.Resource{ | ||
Read: datasourceGoogleFolderOrganizationPolicyRead, | ||
Schema: dsSchema, | ||
} | ||
} | ||
|
||
func datasourceGoogleFolderOrganizationPolicyRead(d *schema.ResourceData, meta interface{}) error { | ||
|
||
d.SetId(fmt.Sprintf("%s:%s", d.Get("folder"), d.Get("constraint"))) | ||
|
||
return resourceGoogleFolderOrganizationPolicyRead(d, meta) | ||
} |
91 changes: 91 additions & 0 deletions
91
google-beta/data_source_google_folder_organization_policy_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
package google | ||
|
||
import ( | ||
"fmt" | ||
"testing" | ||
|
||
"github.com/hashicorp/terraform/helper/acctest" | ||
"github.com/hashicorp/terraform/helper/resource" | ||
"github.com/hashicorp/terraform/terraform" | ||
) | ||
|
||
func TestAccDataSourceGoogleFolderOrganizationPolicy_basic(t *testing.T) { | ||
folder := acctest.RandomWithPrefix("tf-test") | ||
org := getTestOrgFromEnv(t) | ||
|
||
resource.Test(t, resource.TestCase{ | ||
PreCheck: func() { testAccPreCheck(t) }, | ||
Providers: testAccProviders, | ||
Steps: []resource.TestStep{ | ||
{ | ||
Config: testAccDataSourceGoogleFolderOrganizationPolicy_basic(org, folder), | ||
Check: testAccDataSourceGoogleOrganizationPolicyCheck( | ||
"data.google_folder_organization_policy.data", | ||
"google_folder_organization_policy.resource"), | ||
}, | ||
}, | ||
}) | ||
} | ||
|
||
func testAccDataSourceGoogleOrganizationPolicyCheck(dataSourceName string, resourceName string) resource.TestCheckFunc { | ||
return func(s *terraform.State) error { | ||
ds, ok := s.RootModule().Resources[dataSourceName] | ||
if !ok { | ||
return fmt.Errorf("root module has no resource called %s", dataSourceName) | ||
} | ||
|
||
rs, ok := s.RootModule().Resources[resourceName] | ||
if !ok { | ||
return fmt.Errorf("can't find %s in state", resourceName) | ||
} | ||
|
||
dsAttr := ds.Primary.Attributes | ||
rsAttr := rs.Primary.Attributes | ||
|
||
cloudFuncAttrToCheck := []string{ | ||
"name", | ||
"folder", | ||
"constraint", | ||
"version", | ||
"list_policy", | ||
"restore_policy", | ||
"boolean_policy", | ||
} | ||
|
||
for _, attr := range cloudFuncAttrToCheck { | ||
if dsAttr[attr] != rsAttr[attr] { | ||
return fmt.Errorf( | ||
"%s is %s; want %s", | ||
attr, | ||
dsAttr[attr], | ||
rsAttr[attr], | ||
) | ||
} | ||
} | ||
|
||
return nil | ||
} | ||
} | ||
|
||
func testAccDataSourceGoogleFolderOrganizationPolicy_basic(org, folder string) string { | ||
return fmt.Sprintf(` | ||
resource "google_folder" "orgpolicy" { | ||
display_name = "%s" | ||
parent = "%s" | ||
} | ||
resource "google_folder_organization_policy" "resource" { | ||
folder = "${google_folder.orgpolicy.name}" | ||
constraint = "serviceuser.services" | ||
restore_policy { | ||
default = true | ||
} | ||
} | ||
data "google_folder_organization_policy" "data" { | ||
folder = "${google_folder.orgpolicy.name}" | ||
constraint = "serviceuser.services" | ||
} | ||
`, folder, "organizations/"+org) | ||
} |
27 changes: 27 additions & 0 deletions
27
google-beta/data_source_google_project_organization_policy.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
package google | ||
|
||
import ( | ||
"fmt" | ||
|
||
"github.com/hashicorp/terraform/helper/schema" | ||
) | ||
|
||
func dataSourceGoogleProjectOrganizationPolicy() *schema.Resource { | ||
// Generate datasource schema from resource | ||
dsSchema := datasourceSchemaFromResourceSchema(resourceGoogleProjectOrganizationPolicy().Schema) | ||
|
||
addRequiredFieldsToSchema(dsSchema, "project") | ||
addRequiredFieldsToSchema(dsSchema, "constraint") | ||
|
||
return &schema.Resource{ | ||
Read: datasourceGoogleProjectOrganizationPolicyRead, | ||
Schema: dsSchema, | ||
} | ||
} | ||
|
||
func datasourceGoogleProjectOrganizationPolicyRead(d *schema.ResourceData, meta interface{}) error { | ||
|
||
d.SetId(fmt.Sprintf("%s:%s", d.Get("project"), d.Get("constraint"))) | ||
|
||
return resourceGoogleProjectOrganizationPolicyRead(d, meta) | ||
} |
47 changes: 47 additions & 0 deletions
47
google-beta/data_source_google_project_organization_policy_test.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
package google | ||
|
||
import ( | ||
"fmt" | ||
"testing" | ||
|
||
"github.com/hashicorp/terraform/helper/resource" | ||
) | ||
|
||
func TestAccDataSourceGoogleProjectOrganizationPolicy_basic(t *testing.T) { | ||
project := getTestProjectFromEnv() | ||
|
||
resource.Test(t, resource.TestCase{ | ||
PreCheck: func() { testAccPreCheck(t) }, | ||
Providers: testAccProviders, | ||
Steps: []resource.TestStep{ | ||
{ | ||
Config: testAccDataSourceGoogleProjectOrganizationPolicy_basic(project), | ||
Check: testAccDataSourceGoogleOrganizationPolicyCheck( | ||
"data.google_project_organization_policy.data", | ||
"google_project_organization_policy.resource"), | ||
}, | ||
}, | ||
}) | ||
} | ||
|
||
func testAccDataSourceGoogleProjectOrganizationPolicy_basic(project string) string { | ||
return fmt.Sprintf(` | ||
resource "google_project_organization_policy" "resource" { | ||
project = "%s" | ||
constraint = "constraints/compute.trustedImageProjects" | ||
list_policy { | ||
allow { | ||
all = true | ||
} | ||
} | ||
} | ||
data "google_project_organization_policy" "data" { | ||
project = "%s" | ||
constraint = "constraints/compute.trustedImageProjects" | ||
} | ||
`, project, project) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
39 changes: 39 additions & 0 deletions
39
website/docs/d/datasource_google_folder_organization_policy.html.markdown
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
--- | ||
layout: "google" | ||
page_title: "Google: google_folder_organization_policy" | ||
sidebar_current: "docs-google-datasource-folder-organization-policy" | ||
description: |- | ||
Retrieve Organization policies for a Google Folder | ||
--- | ||
|
||
# google\_folder\_organization\_policy | ||
|
||
Allows management of Organization policies for a Google Folder. For more information see | ||
[the official | ||
documentation](https://cloud.google.com/resource-manager/docs/organization-policy/overview) | ||
|
||
## Example Usage | ||
|
||
```hcl | ||
data "google_folder_organization_policy" "policy" { | ||
folder = "folders/folderid" | ||
constraint = "constraints/compute.trustedImageProjects" | ||
} | ||
output "version" { | ||
value = "${data.google_folder_organization_policy.policy.version}" | ||
} | ||
``` | ||
|
||
## Argument Reference | ||
|
||
The following arguments are supported: | ||
|
||
* `folder` - (Required) The resource name of the folder to set the policy for. Its format is folders/{folder_id}. | ||
|
||
* `constraint` - (Required) (Required) The name of the Constraint the Policy is configuring, for example, `serviceuser.services`. Check out the [complete list of available constraints](https://cloud.google.com/resource-manager/docs/organization-policy/understanding-constraints#available_constraints). | ||
|
||
|
||
## Attributes Reference | ||
|
||
See [google_folder_organization_policy](https://www.terraform.io/docs/providers/google/r/google_folder_organization_policy.html) resource for details of the available attributes. |
40 changes: 40 additions & 0 deletions
40
website/docs/d/datasource_google_project_organization_policy.html.markdown
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
--- | ||
layout: "google" | ||
page_title: "Google: google_project_organization_policy" | ||
sidebar_current: "docs-google-datasource-project-organization-policy" | ||
description: |- | ||
Retrieve Organization policies for a Google Project. | ||
--- | ||
|
||
# google\_project\_organization\_policy | ||
|
||
Allows management of Organization policies for a Google Project. For more information see | ||
[the official | ||
documentation](https://cloud.google.com/resource-manager/docs/organization-policy/overview) | ||
|
||
## Example Usage | ||
|
||
```hcl | ||
data "google_project_organization_policy" "policy" { | ||
project = "project-id" | ||
constraint = "constraints/serviceuser.services" | ||
} | ||
output "version" { | ||
value = "${data.google_project_organization_policy.policy.version}" | ||
} | ||
``` | ||
|
||
## Argument Reference | ||
|
||
The following arguments are supported: | ||
|
||
* `project` - (Required) The project ID. | ||
|
||
* `constraint` - (Required) (Required) The name of the Constraint the Policy is configuring, for example, `serviceuser.services`. Check out the [complete list of available constraints](https://cloud.google.com/resource-manager/docs/organization-policy/understanding-constraints#available_constraints). | ||
|
||
|
||
## Attributes Reference | ||
|
||
See [google_project_organization_policy](https://www.terraform.io/docs/providers/google/r/google_project.html) resource for details of the available attributes. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters