-
Notifications
You must be signed in to change notification settings - Fork 1.7k
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 (#1435)
Merged PR #1435.
- Loading branch information
1 parent
1bc9197
commit c28a75d
Showing
8 changed files
with
279 additions
and
0 deletions.
There are no files selected for viewing
27 changes: 27 additions & 0 deletions
27
third_party/terraform/data_sources/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) | ||
} |
27 changes: 27 additions & 0 deletions
27
third_party/terraform/data_sources/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) | ||
} |
91 changes: 91 additions & 0 deletions
91
third_party/terraform/tests/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) | ||
} |
47 changes: 47 additions & 0 deletions
47
third_party/terraform/tests/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
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
...aform/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
...form/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. | ||
|