
    Vhx                     d    d dl mZmZmZ eZdZdZdZd dl	m
Z
 ddlmZmZ d Zed	k(  r e        y
y
)    )absolute_importdivisionprint_functionu?  
---
module: dns_domain
short_description: Manages DNS domains on Vultr
description:
  - Create and remove DNS domains.
version_added: "1.0.0"
author: "René Moser (@resmo)"
options:
  domain:
    description:
      - The domain name.
    required: true
    aliases: [ name ]
    type: str
  ip:
    description:
      - The default server IP.
      - Use M(vultr.cloud.dns_record) to change it once the domain is created.
      - Required if C(state=present).
    type: str
    aliases: [ server_ip ]
  dns_sec:
    description:
      - Ensure DNSSEC is enabled or disabled.
    type: str
    choices: [ enabled, disabled ]
    default: disabled
  state:
    description:
      - State of the DNS domain.
    default: present
    choices: [ present, absent ]
    type: str
extends_documentation_fragment:
  - vultr.cloud.vultr_v2
z
- name: Ensure a domain exists with DNSSEC
  vultr.cloud.dns_domain:
    name: example.com
    dns_sec: enabled
    server_ip: 10.10.10.10

- name: Ensure a domain is absent
  vultr.cloud.dns_domain:
    name: example.com
    state: absent
a  
---
vultr_api:
  description: Response from Vultr API with a few additions/modification.
  returned: success
  type: dict
  contains:
    api_timeout:
      description: Timeout used for the API requests.
      returned: success
      type: int
      sample: 60
    api_retries:
      description: Amount of max retries for the API requests.
      returned: success
      type: int
      sample: 5
    api_retry_max_delay:
      description: Exponential backoff delay in seconds between retries up to this max delay value.
      returned: success
      type: int
      sample: 12
    api_endpoint:
      description: Endpoint used for the API requests.
      returned: success
      type: str
      sample: "https://api.vultr.com/v2"
vultr_dns_domain:
  description: Response from Vultr API.
  returned: success
  type: dict
  contains:
    name:
      description: Name of the DNS Domain.
      returned: success
      type: str
      sample: example.com
    dns_sec:
      description: Whether DNSSEC is enabled or disabled.
      returned: success
      type: str
      sample: disabled
    date_created:
      description: Date the DNS domain was created.
      returned: success
      type: str
      sample: "2020-10-10T01:56:20+00:00"
)AnsibleModule   )AnsibleVultrvultr_argument_specc                     t               } | j                  t        t        dddg      t        ddg      t        dddgd	      t        dd
dgd
	                   t        | dd
dgfgd      }t	        |dddg dddgddd	      }|j
                  j                  d      dk(  r|j                          y |j                          y )NstrTname)typerequiredaliases	server_ip)r   r   enableddisabled)r   choicesdefaultpresentabsent)domainipdns_secstater   r   )argument_specrequired_ifsupports_check_modevultr_dns_domainz/domainsr   )r   r   r   r   PUT)	module	namespaceresource_pathressource_result_key_singularresource_create_param_keysresource_update_param_keysresource_key_nameresource_key_idresource_update_method)	r	   updatedictr   r   paramsgetr   r   )r   r    vultrs      j/home/dcms/DCMS/lib/python3.12/site-packages/ansible_collections/vultr/cloud/plugins/modules/dns_domain.pymainr/   u   s    ')MUTF8D6ei-DjYEIx+@)T		
 #i$(
 !F $ &.#>$,i#8" $
E }}!X-    __main__N)
__future__r   r   r   r   __metaclass__DOCUMENTATIONEXAMPLESRETURNansible.module_utils.basicr   module_utils.vultr_v2r   r	   r/   __name__ r0   r.   <module>r;      sL    A @$L/
b 5 E"J zF r0   