
    Vh                     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: firewall_group
short_description: Manages firewall groups on Vultr
description:
  - Create and remove firewall groups.
version_added: "1.0.0"
author: "René Moser (@resmo)"
options:
  description:
    description:
      - Description of the firewall group.
    required: true
    aliases: [ name ]
    type: str
  state:
    description:
      - State of the firewall group.
    default: present
    choices: [ present, absent ]
    type: str
extends_documentation_fragment:
  - vultr.cloud.vultr_v2
z
- name: ensure a firewall group is present
  vultr.cloud.firewall_group:
    description: my http firewall.

- name: ensure a firewall group is absent
  vultr.cloud.firewall_group:
    description: my http firewall.
    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_firewall_group:
  description: Response from Vultr API.
  returned: success
  type: dict
  contains:
    id:
      description: ID of the firewall group.
      returned: success
      type: str
      sample: cb676a46-66fd-4dfb-b839-443f2e6c0b60
    description:
      description: Description (name) of the firewall group
      returned: success
      type: str
      sample: my firewall group
    date_created:
      description: Date the firewall group was created.
      returned: success
      type: str
      sample: "2020-10-10T01:56:20+00:00"
    date_modified:
      description: Date the firewall group was modified.
      returned: success
      type: str
      sample: "2020-10-10T01:56:20+00:00"
)AnsibleModule   )AnsibleVultrvultr_argument_specc            
      F   t               } | j                  t        t        dddg      t        dddgd                   t        | d	      }t	        |d
dddgdgd      }|j
                  j                  d      dk(  r|j                          y |j                          y )NstrTname)typerequiredaliasespresentabsent)r   choicesdefault)descriptionstate)argument_specsupports_check_modevultr_firewall_groupz
/firewallsfirewall_groupr   )module	namespaceresource_pathressource_result_key_singularresource_create_param_keysresource_update_param_keysresource_key_namer   )	r	   updatedictr   r   paramsgetr   r   )r   r   vultrs      n/home/dcms/DCMS/lib/python3.12/site-packages/ansible_collections/vultr/cloud/plugins/modules/firewall_group.pymainr'   k   s    ')M%$IEIx+@)T	
 # F
 ("&6$1?$1?'E }}!X-    __main__N)
__future__r   r   r   r   __metaclass__DOCUMENTATIONEXAMPLESRETURNansible.module_utils.basicr   module_utils.vultr_v2r   r	   r'   __name__ r(   r&   <module>r3      sJ    A @2	4
l 5 E< zF r(   