Skip to content

Commit

Permalink
Add support for string --> object map for DCL resources (GoogleCloudP…
Browse files Browse the repository at this point in the history
…latform#10039)

* Add support for string --> object map for DCL resources

* Fix whitespace in template

* Add test, need updated DCL to work

* Add override for key name

* Both overrides

* Update docs, prepend key for maps

* Update bundle descriptions

* Comment update
  • Loading branch information
slevenick authored and trodge committed Mar 4, 2024
1 parent 9f3fd8b commit 08ea0b3
Show file tree
Hide file tree
Showing 13 changed files with 330 additions and 21 deletions.
2 changes: 1 addition & 1 deletion mmv1/third_party/terraform/go.mod.erb
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ go 1.20

require (
cloud.google.com/go/bigtable v1.19.0
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.62.0
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.63.0
github.com/apparentlymart/go-cidr v1.1.0
github.com/davecgh/go-spew v1.1.1
github.com/dnaeon/go-vcr v1.0.1
Expand Down
2 changes: 2 additions & 0 deletions mmv1/third_party/terraform/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -413,3 +413,5 @@ gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
rsc.io/binaryregexp v0.2.0 h1:HfqmD5MEmC0zvwBuF187nq9mdnXjXsSivRiXN7SmRkE=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.63.0 h1:eSOBYPZVnU2fZul9sAJFGLVCgv6stNVKkmsogKF7UeY=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.63.0/go.mod h1:pL2Qt5HT+x6xrTd806oMiM3awW6kNIXB/iiuClz6m6k=
Original file line number Diff line number Diff line change
Expand Up @@ -1008,6 +1008,17 @@ func TestAccGKEHubFeatureMembership_gkehubFeaturePolicyController(t *testing.T)
ImportState: true,
ImportStateVerify: true,
},
{
Config: testAccGKEHubFeatureMembership_policycontrollerUpdateMaps(context),
Check: resource.ComposeTestCheckFunc(
testAccCheckGkeHubFeatureMembershipPresent(t, fmt.Sprintf("tf-test-gkehub%s", context["random_suffix"]), "global", "policycontroller", fmt.Sprintf("tf-test1%s", context["random_suffix"])),
),
},
{
ResourceName: "google_gke_hub_feature_membership.feature_member",
ImportState: true,
ImportStateVerify: true,
},
},
})
}
Expand Down Expand Up @@ -1064,9 +1075,92 @@ resource "google_gke_hub_feature_membership" "feature_member" {
"PROMETHEUS"
]
}
deployment_configs {
component_name = "admission"
replica_count = 3
pod_affinity = "ANTI_AFFINITY"
container_resources {
limits {
memory = "1Gi"
cpu = "1.5"
}
requests {
memory = "500Mi"
cpu = "150m"
}
}
pod_tolerations {
key = "key1"
operator = "Equal"
value = "value1"
effect = "NoSchedule"
}
}
deployment_configs {
component_name = "mutation"
replica_count = 3
pod_affinity = "ANTI_AFFINITY"
}
policy_content {
template_library {
installation = "NOT_INSTALLED"
installation = "ALL"
}
bundles {
bundle_name = "pci-dss-v3.2.1"
exempted_namespaces = ["sample-namespace"]
}
bundles {
bundle_name = "nist-sp-800-190"
}
}
}
version = "1.17.0"
}
}
`, context)
}

func testAccGKEHubFeatureMembership_policycontrollerUpdateMaps(context map[string]interface{}) string {
return gkeHubFeatureProjectSetup(context) + gkeHubClusterMembershipSetup(context) + acctest.Nprintf(`
resource "google_gke_hub_feature" "feature" {
project = google_project.project.project_id
name = "policycontroller"
location = "global"
depends_on = [google_project_service.container, google_project_service.gkehub, google_project_service.poco]
}

resource "google_gke_hub_feature_membership" "feature_member" {
project = google_project.project.project_id
location = "global"
feature = google_gke_hub_feature.feature.name
membership = google_gke_hub_membership.membership.membership_id
policycontroller {
policy_controller_hub_config {
install_spec = "INSTALL_SPEC_SUSPENDED"
constraint_violation_limit = 50
referential_rules_enabled = true
log_denies_enabled = true
mutation_enabled = true
monitoring {
backends = [
"PROMETHEUS"
]
}
deployment_configs {
component_name = "admission"
pod_affinity = "NO_AFFINITY"
}
deployment_configs {
component_name = "audit"
container_resources {
limits {
memory = "1Gi"
cpu = "1.5"
}
requests {
memory = "500Mi"
cpu = "150m"
}
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -504,6 +504,10 @@ The following arguments are supported:
(Optional)
The maximum number of audit violations to be stored in a constraint. If not set, the default of 20 will be used.

* `deployment_configs` -
(Optional)
Map of deployment configs to deployments ("admission", "audit", "mutation").

* `policy_content` -
(Optional)
Specifies the desired policy content on the cluster. Structure is [documented below](#nested_policy_content).
Expand All @@ -514,12 +518,97 @@ The following arguments are supported:
(Optional)
Specifies the list of backends Policy Controller will export to. Must be one of `CLOUD_MONITORING` or `PROMETHEUS`. Defaults to [`CLOUD_MONITORING`, `PROMETHEUS`]. Specifying an empty value `[]` disables metrics export.

<a name="nested_deployment_configs"></a>The `deployment_configs` block supports:

* `component_name` -
(Required)
The name of the component. One of `admission` `audit` or `mutation`

* `container_resources` -
(Optional)
Container resource requirements.

* `pod_affinity` -
(Optional)
Pod affinity configuration. Possible values: AFFINITY_UNSPECIFIED, NO_AFFINITY, ANTI_AFFINITY

* `pod_tolerations` -
(Optional)
Pod tolerations of node taints.

* `replica_count` -
(Optional)
Pod replica count.

<a name="nested_container_resources"></a>The `container_resources` block supports:

* `limits` -
(Optional)
Limits describes the maximum amount of compute resources allowed for use by the running container.

* `requests` -
(Optional)
Requests describes the amount of compute resources reserved for the container by the kube-scheduler.

<a name="nested_limits"></a>The `limits` block supports:

* `cpu` -
(Optional)
CPU requirement expressed in Kubernetes resource units.

* `memory` -
(Optional)
Memory requirement expressed in Kubernetes resource units.

<a name="nested_requests"></a>The `requests` block supports:

* `cpu` -
(Optional)
CPU requirement expressed in Kubernetes resource units.

* `memory` -
(Optional)
Memory requirement expressed in Kubernetes resource units.

<a name="nested_pod_tolerations"></a>The `pod_tolerations` block supports:

* `effect` -
(Optional)
Matches a taint effect.

* `key` -
(Optional)
Matches a taint key (not necessarily unique).

* `operator` -
(Optional)
Matches a taint operator.

* `value` -
(Optional)
Matches a taint value.

<a name="nested_policy_content"></a>The `policy_content` block supports:

* `bundles` -
(Optional)
map of bundle name to BundleInstallSpec. The bundle name maps to the `bundleName` key in the `policycontroller.gke.io/constraintData` annotation on a constraint.

* `template_library`
(Optional)
Configures the installation of the Template Library. Structure is [documented below](#nested_template_library).

<a name="nested_bundles"></a>The `template_library` block supports:
The `bundles` block supports:

* `bundle_name` -
(Required)
The name of the bundle.

* `exempted_namespaces` -
(Optional)
The set of namespaces to be exempted from the bundle.

<a name="nested_template_library"></a>The `template_library` block supports:

* `installation`
Expand Down
2 changes: 1 addition & 1 deletion tpgtools/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ go 1.20

require (
bitbucket.org/creachadair/stringset v0.0.11
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.62.0
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.63.0
github.com/golang/glog v1.1.2
github.com/hashicorp/hcl v1.0.0
github.com/kylelemons/godebug v1.1.0
Expand Down
8 changes: 2 additions & 6 deletions tpgtools/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,8 @@ cloud.google.com/go/compute v1.23.0/go.mod h1:4tCnrn48xsqlwSAiLf1HXMQk8CONslYbdi
cloud.google.com/go/compute/metadata v0.2.3 h1:mg4jlk7mCAj6xXp9UJ4fjI9VUI5rubuGBW5aJ7UnBMY=
cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA=
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.60.0 h1:RFZs9I3tXewC7cJf8RKbUMpQZO6jWZ9SHSnNd+auxsQ=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.60.0/go.mod h1:pL2Qt5HT+x6xrTd806oMiM3awW6kNIXB/iiuClz6m6k=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.61.0 h1:IAr9UlYbxURIYABRMagXXo8pDlkFNFFXWz5J2+srrnc=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.61.0/go.mod h1:pL2Qt5HT+x6xrTd806oMiM3awW6kNIXB/iiuClz6m6k=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.62.0 h1:s4Y6r6RrYLBnqosGXLwR0h1Gqr0VT3wgd6rqvHsD9OE=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.62.0/go.mod h1:pL2Qt5HT+x6xrTd806oMiM3awW6kNIXB/iiuClz6m6k=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.63.0 h1:eSOBYPZVnU2fZul9sAJFGLVCgv6stNVKkmsogKF7UeY=
github.com/GoogleCloudPlatform/declarative-resource-client-library v1.63.0/go.mod h1:pL2Qt5HT+x6xrTd806oMiM3awW6kNIXB/iiuClz6m6k=
github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4=
github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM=
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
Expand Down
1 change: 1 addition & 0 deletions tpgtools/override.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ const (
CustomListSize = "CUSTOM_LIST_SIZE_CONSTRAINT"
CustomDefault = "CUSTOM_DEFAULT"
CustomSchemaValues = "CUSTOM_SCHEMA_VALUES"
ComplexMapKey = "COMPLEX_MAP_KEY_NAME"
)

// Overrides represents the type a resource's override file can be marshalled
Expand Down
5 changes: 5 additions & 0 deletions tpgtools/override_details.go
Original file line number Diff line number Diff line change
Expand Up @@ -230,3 +230,8 @@ type StateUpgradeDetails struct {
// The current schema version
SchemaVersion int
}

type ComplexMapKeyDetails struct {
// The name of the key as exposed by Terraform
KeyName string
}
8 changes: 8 additions & 0 deletions tpgtools/overrides/gkehub/beta/feature_membership.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -29,3 +29,11 @@
details:
functions:
- tpgresource.DefaultProviderProject
- type: COMPLEX_MAP_KEY_NAME
field: policycontroller.policy_controller_hub_config.policy_content.bundles
details:
keyname: bundle_name
- type: COMPLEX_MAP_KEY_NAME
field: policycontroller.policy_controller_hub_config.deployment_configs
details:
keyname: component_name
10 changes: 9 additions & 1 deletion tpgtools/overrides/gkehub/feature_membership.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,12 @@
field: mesh.control_plane
details:
message: >-
Deprecated in favor of the `management` field
Deprecated in favor of the `management` field
- type: COMPLEX_MAP_KEY_NAME
field: policycontroller.policy_controller_hub_config.policy_content.bundles
details:
keyname: bundle_name
- type: COMPLEX_MAP_KEY_NAME
field: policycontroller.policy_controller_hub_config.deployment_configs
details:
keyname: component_name
Loading

0 comments on commit 08ea0b3

Please sign in to comment.