solutions/client-landing-zone/client-folder/standard/applications-infrastructure/dns-project/public-dns.yaml (38 lines of code) (raw):
# Copyright 2020 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
#
# http://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.
#########
# Public Client DNS subzone
# SC-22
# AU-12 - Enable Logging for DNS Managed zone
apiVersion: dns.cnrm.cloud.google.com/v1beta1
kind: DNSManagedZone
metadata:
name: client-name-standard-public-dns # kpt-set: ${client-name}-standard-public-dns
namespace: client-name-networking # kpt-set: ${client-name}-networking
annotations:
cnrm.cloud.google.com/project-id: dns-project-id # kpt-set: ${dns-project-id}
config.kubernetes.io/depends-on: resourcemanager.cnrm.cloud.google.com/namespaces/client-name-projects/Project/dns-project-id # kpt-set: resourcemanager.cnrm.cloud.google.com/namespaces/${client-name}-projects/Project/${dns-project-id}
spec:
description: "client-name standard public dns subzone" # kpt-set: ${client-name} standard public dns subzone
resourceID: client-name-standard-public-dns # kpt-set: ${client-name}-standard-public-dns
dnsName: "dns-name" # kpt-set: ${dns-name}
visibility: public
dnssecConfig:
state: "on"
# AU-12
cloudLoggingConfig:
enableLogging: true
---
# Record Set for client DNS subzone in public core DNS zone
# SC-22
apiVersion: dns.cnrm.cloud.google.com/v1beta1
kind: DNSRecordSet
metadata:
name: client-name-standard-core-public-dns-ns-rset # kpt-set: ${client-name}-standard-core-public-dns-ns-rset
namespace: client-name-networking # kpt-set: ${client-name}-networking
annotations:
cnrm.cloud.google.com/project-id: core-dns-project-id # kpt-set: ${core-dns-project-id}
config.kubernetes.io/depends-on: dns.cnrm.cloud.google.com/namespaces/client-name-networking/DNSManagedZone/client-name-standard-public-dns # kpt-set: dns.cnrm.cloud.google.com/namespaces/${client-name}-networking/DNSManagedZone/${client-name}-standard-public-dns
spec:
name: "dns-name" # kpt-set: ${dns-name}
type: "NS"
ttl: 300
managedZoneRef:
name: core-dns-project-id-standard-core-public-dns # kpt-set: ${core-dns-project-id}-standard-core-public-dns
namespace: networking
# The nameservers below must be updated to match the same nameservers as the client DNS subzone
# Cloud DNS creates NS and SOA records automatically when a zone is created and these cannot be changed
# See https://cloud.google.com/dns/docs/zones#create-pub-zone
rrdatas: # kpt-set: ${dns-nameservers}
- "ns-cloud-a1.googledomains.com."
- "ns-cloud-a2.googledomains.com."
- "ns-cloud-a3.googledomains.com."
- "ns-cloud-a4.googledomains.com."