mirror of
https://github.com/ansible-collections/google.cloud.git
synced 2025-04-06 02:40:29 -07:00
DNSSec on Managed Zones (#255)
Signed-off-by: Modular Magician <magic-modules@google.com>
This commit is contained in:
parent
92beb99757
commit
3e51483452
2 changed files with 247 additions and 0 deletions
|
@ -57,6 +57,69 @@ options:
|
|||
description:
|
||||
- The DNS name of this managed zone, for instance "example.com.".
|
||||
required: true
|
||||
dnssec_config:
|
||||
description:
|
||||
- DNSSEC configuration.
|
||||
required: false
|
||||
version_added: 2.9
|
||||
suboptions:
|
||||
kind:
|
||||
description:
|
||||
- Identifies what kind of resource this is.
|
||||
required: false
|
||||
default: dns#managedZoneDnsSecConfig
|
||||
non_existence:
|
||||
description:
|
||||
- Specifies the mechanism used to provide authenticated denial-of-existence
|
||||
responses. Output only while state is not OFF. .
|
||||
required: false
|
||||
choices:
|
||||
- nsec
|
||||
- nsec3
|
||||
state:
|
||||
description:
|
||||
- Specifies whether DNSSEC is enabled, and what mode it is in.
|
||||
required: false
|
||||
choices:
|
||||
- 'off'
|
||||
- 'on'
|
||||
- transfer
|
||||
default_key_specs:
|
||||
description:
|
||||
- Specifies parameters that will be used for generating initial DnsKeys for
|
||||
this ManagedZone. Output only while state is not OFF .
|
||||
required: false
|
||||
suboptions:
|
||||
algorithm:
|
||||
description:
|
||||
- String mnemonic specifying the DNSSEC algorithm of this key.
|
||||
required: false
|
||||
choices:
|
||||
- ecdsap256sha256
|
||||
- ecdsap384sha384
|
||||
- rsasha1
|
||||
- rsasha256
|
||||
- rsasha512
|
||||
key_length:
|
||||
description:
|
||||
- Length of the keys in bits.
|
||||
required: false
|
||||
key_type:
|
||||
description:
|
||||
- Specifies whether this is a key signing key (KSK) or a zone signing
|
||||
key (ZSK). Key signing keys have the Secure Entry Point flag set and,
|
||||
when active, will only be used to sign resource record sets of type
|
||||
DNSKEY. Zone signing keys do not have the Secure Entry Point flag set
|
||||
and will be used to sign all other types of resource record sets. .
|
||||
required: false
|
||||
choices:
|
||||
- keySigning
|
||||
- zoneSigning
|
||||
kind:
|
||||
description:
|
||||
- Identifies what kind of resource this is.
|
||||
required: false
|
||||
default: dns#dnsKeySpec
|
||||
name:
|
||||
description:
|
||||
- User assigned name for this resource.
|
||||
|
@ -132,6 +195,59 @@ dnsName:
|
|||
- The DNS name of this managed zone, for instance "example.com.".
|
||||
returned: success
|
||||
type: str
|
||||
dnssecConfig:
|
||||
description:
|
||||
- DNSSEC configuration.
|
||||
returned: success
|
||||
type: complex
|
||||
contains:
|
||||
kind:
|
||||
description:
|
||||
- Identifies what kind of resource this is.
|
||||
returned: success
|
||||
type: str
|
||||
nonExistence:
|
||||
description:
|
||||
- Specifies the mechanism used to provide authenticated denial-of-existence
|
||||
responses. Output only while state is not OFF. .
|
||||
returned: success
|
||||
type: str
|
||||
state:
|
||||
description:
|
||||
- Specifies whether DNSSEC is enabled, and what mode it is in.
|
||||
returned: success
|
||||
type: str
|
||||
defaultKeySpecs:
|
||||
description:
|
||||
- Specifies parameters that will be used for generating initial DnsKeys for
|
||||
this ManagedZone. Output only while state is not OFF .
|
||||
returned: success
|
||||
type: complex
|
||||
contains:
|
||||
algorithm:
|
||||
description:
|
||||
- String mnemonic specifying the DNSSEC algorithm of this key.
|
||||
returned: success
|
||||
type: str
|
||||
keyLength:
|
||||
description:
|
||||
- Length of the keys in bits.
|
||||
returned: success
|
||||
type: int
|
||||
keyType:
|
||||
description:
|
||||
- Specifies whether this is a key signing key (KSK) or a zone signing key
|
||||
(ZSK). Key signing keys have the Secure Entry Point flag set and, when
|
||||
active, will only be used to sign resource record sets of type DNSKEY.
|
||||
Zone signing keys do not have the Secure Entry Point flag set and will
|
||||
be used to sign all other types of resource record sets. .
|
||||
returned: success
|
||||
type: str
|
||||
kind:
|
||||
description:
|
||||
- Identifies what kind of resource this is.
|
||||
returned: success
|
||||
type: str
|
||||
id:
|
||||
description:
|
||||
- Unique identifier for the resource; defined by the server.
|
||||
|
@ -216,6 +332,21 @@ def main():
|
|||
state=dict(default='present', choices=['present', 'absent'], type='str'),
|
||||
description=dict(required=True, type='str'),
|
||||
dns_name=dict(required=True, type='str'),
|
||||
dnssec_config=dict(
|
||||
type='dict',
|
||||
options=dict(
|
||||
kind=dict(default='dns#managedZoneDnsSecConfig', type='str'),
|
||||
non_existence=dict(type='str'),
|
||||
state=dict(type='str'),
|
||||
default_key_specs=dict(
|
||||
type='list',
|
||||
elements='dict',
|
||||
options=dict(
|
||||
algorithm=dict(type='str'), key_length=dict(type='int'), key_type=dict(type='str'), kind=dict(default='dns#dnsKeySpec', type='str')
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
name=dict(required=True, type='str'),
|
||||
name_server_set=dict(type='str'),
|
||||
labels=dict(type='dict'),
|
||||
|
@ -296,6 +427,7 @@ def resource_to_request(module):
|
|||
u'kind': 'dns#managedZone',
|
||||
u'description': module.params.get('description'),
|
||||
u'dnsName': module.params.get('dns_name'),
|
||||
u'dnssecConfig': ManagedZoneDnssecconfig(module.params.get('dnssec_config', {}), module).to_request(),
|
||||
u'name': module.params.get('name'),
|
||||
u'nameServerSet': module.params.get('name_server_set'),
|
||||
u'labels': module.params.get('labels'),
|
||||
|
@ -368,6 +500,7 @@ def response_to_hash(module, response):
|
|||
return {
|
||||
u'description': response.get(u'description'),
|
||||
u'dnsName': response.get(u'dnsName'),
|
||||
u'dnssecConfig': ManagedZoneDnssecconfig(response.get(u'dnssecConfig', {}), module).from_response(),
|
||||
u'id': response.get(u'id'),
|
||||
u'name': response.get(u'name'),
|
||||
u'nameServers': response.get(u'nameServers'),
|
||||
|
@ -379,6 +512,66 @@ def response_to_hash(module, response):
|
|||
}
|
||||
|
||||
|
||||
class ManagedZoneDnssecconfig(object):
|
||||
def __init__(self, request, module):
|
||||
self.module = module
|
||||
if request:
|
||||
self.request = request
|
||||
else:
|
||||
self.request = {}
|
||||
|
||||
def to_request(self):
|
||||
return remove_nones_from_dict(
|
||||
{
|
||||
u'kind': self.request.get('kind'),
|
||||
u'nonExistence': self.request.get('non_existence'),
|
||||
u'state': self.request.get('state'),
|
||||
u'defaultKeySpecs': ManagedZoneDefaultkeyspecsArray(self.request.get('default_key_specs', []), self.module).to_request(),
|
||||
}
|
||||
)
|
||||
|
||||
def from_response(self):
|
||||
return remove_nones_from_dict(
|
||||
{
|
||||
u'kind': self.request.get(u'kind'),
|
||||
u'nonExistence': self.request.get(u'nonExistence'),
|
||||
u'state': self.request.get(u'state'),
|
||||
u'defaultKeySpecs': ManagedZoneDefaultkeyspecsArray(self.request.get(u'defaultKeySpecs', []), self.module).from_response(),
|
||||
}
|
||||
)
|
||||
|
||||
|
||||
class ManagedZoneDefaultkeyspecsArray(object):
|
||||
def __init__(self, request, module):
|
||||
self.module = module
|
||||
if request:
|
||||
self.request = request
|
||||
else:
|
||||
self.request = []
|
||||
|
||||
def to_request(self):
|
||||
items = []
|
||||
for item in self.request:
|
||||
items.append(self._request_for_item(item))
|
||||
return items
|
||||
|
||||
def from_response(self):
|
||||
items = []
|
||||
for item in self.request:
|
||||
items.append(self._response_from_item(item))
|
||||
return items
|
||||
|
||||
def _request_for_item(self, item):
|
||||
return remove_nones_from_dict(
|
||||
{u'algorithm': item.get('algorithm'), u'keyLength': item.get('key_length'), u'keyType': item.get('key_type'), u'kind': item.get('kind')}
|
||||
)
|
||||
|
||||
def _response_from_item(self, item):
|
||||
return remove_nones_from_dict(
|
||||
{u'algorithm': item.get(u'algorithm'), u'keyLength': item.get(u'keyLength'), u'keyType': item.get(u'keyType'), u'kind': item.get(u'kind')}
|
||||
)
|
||||
|
||||
|
||||
class ManagedZonePrivatevisibilityconfig(object):
|
||||
def __init__(self, request, module):
|
||||
self.module = module
|
||||
|
|
|
@ -73,6 +73,60 @@ resources:
|
|||
- The DNS name of this managed zone, for instance "example.com.".
|
||||
returned: success
|
||||
type: str
|
||||
dnssecConfig:
|
||||
description:
|
||||
- DNSSEC configuration.
|
||||
returned: success
|
||||
type: complex
|
||||
contains:
|
||||
kind:
|
||||
description:
|
||||
- Identifies what kind of resource this is.
|
||||
returned: success
|
||||
type: str
|
||||
nonExistence:
|
||||
description:
|
||||
- Specifies the mechanism used to provide authenticated denial-of-existence
|
||||
responses. Output only while state is not OFF. .
|
||||
returned: success
|
||||
type: str
|
||||
state:
|
||||
description:
|
||||
- Specifies whether DNSSEC is enabled, and what mode it is in.
|
||||
returned: success
|
||||
type: str
|
||||
defaultKeySpecs:
|
||||
description:
|
||||
- Specifies parameters that will be used for generating initial DnsKeys
|
||||
for this ManagedZone. Output only while state is not OFF .
|
||||
returned: success
|
||||
type: complex
|
||||
contains:
|
||||
algorithm:
|
||||
description:
|
||||
- String mnemonic specifying the DNSSEC algorithm of this key.
|
||||
returned: success
|
||||
type: str
|
||||
keyLength:
|
||||
description:
|
||||
- Length of the keys in bits.
|
||||
returned: success
|
||||
type: int
|
||||
keyType:
|
||||
description:
|
||||
- Specifies whether this is a key signing key (KSK) or a zone signing
|
||||
key (ZSK). Key signing keys have the Secure Entry Point flag set and,
|
||||
when active, will only be used to sign resource record sets of type
|
||||
DNSKEY. Zone signing keys do not have the Secure Entry Point flag
|
||||
set and will be used to sign all other types of resource record sets.
|
||||
.
|
||||
returned: success
|
||||
type: str
|
||||
kind:
|
||||
description:
|
||||
- Identifies what kind of resource this is.
|
||||
returned: success
|
||||
type: str
|
||||
id:
|
||||
description:
|
||||
- Unique identifier for the resource; defined by the server.
|
||||
|
|
Loading…
Add table
Reference in a new issue