policies/constraints/compute_vm_external_ip.yaml (17 lines of code) (raw):
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
apiVersion: constraints.gatekeeper.sh/v1alpha1
kind: GCPComputeExternalIpAccessConstraintV2
metadata:
name: forbid_external_ip
annotations:
# This constraint is not certified by CIS.
bundles.validator.forsetisecurity.org/cis-v1.1: 4.08
description: Checks if Compute Engine instances have public IPs.
spec:
severity: high
match:
target: # {"$ref":"#/definitions/io.k8s.cli.setters.target_prj_data"}
- "organizations/**"
parameters:
# modes can be [allowlist, denylist]
mode: allowlist
# match_mode can be [exact, regex], default is exact.
match_mode: regex
instances: # {"$ref":"#/definitions/io.k8s.cli.setters.vm_instances"}
# regex example:
- //compute.googleapis.com/projects/test-project2/.*