
    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: ssh_key
short_description: Manages ssh keys on Vultr.
description:
  - Create, update and remove ssh keys.
version_added: "1.0.0"
author: "René Moser (@resmo)"
options:
  name:
    description:
      - Name of the ssh key.
    required: true
    type: str
  ssh_key:
    description:
      - SSH public key.
      - Required if C(state=present).
    type: str
  state:
    description:
      - State of the ssh key.
    default: present
    choices: [ present, absent ]
    type: str
extends_documentation_fragment:
  - vultr.cloud.vultr_v2

z
- name: ensure an SSH key is present
  vultr.cloud.ssh_key:
    name: my ssh key
    ssh_key: "{{ lookup('file', '~/.ssh/id_rsa.pub') }}"

- name: ensure an SSH key is absent
  vultr.cloud.ssh_key:
    name: my ssh key
    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_ssh_key:
  description: Response from Vultr API.
  returned: success
  type: dict
  contains:
    id:
      description: ID of the ssh key.
      returned: success
      type: str
      sample: cb676a46-66fd-4dfb-b839-443f2e6c0b60
    name:
      description: Name of the ssh key.
      returned: success
      type: str
      sample: my ssh key
    date_created:
      description: Date the ssh key was created.
      returned: success
      type: str
      sample: "2020-10-10T01:56:20+00:00"
    ssh_key:
      description: SSH public key.
      returned: success
      type: str
      sample: ssh-rsa AA... someother@example.com
)AnsibleModule   )AnsibleVultrvultr_argument_specc                  j   t               } | j                  t        t        dd      t        dd      t        dddgd      	             t        | d
ddgfgd      }t	        |dddddgddgd      }|j
                  j                  d
      dk(  r|j                          y |j                          y )NstrT)typerequiredF)r   no_logpresentabsent)r   choicesdefault)namessh_keystater   r   )argument_specrequired_ifsupports_check_modevultr_ssh_keyz	/ssh-keysr   )module	namespaceresource_pathressource_result_key_singularresource_create_param_keysresource_update_param_keysresource_key_name)	r	   updatedictr   r   paramsgetr   r   )r   r   vultrs      g/home/dcms/DCMS/lib/python3.12/site-packages/ansible_collections/vultr/cloud/plugins/modules/ssh_key.pymainr'   q   s    ')M540eE2EIx+@)T	
 #i)-
 !F !!&/$*I#6$*I#6 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      sK    A @<
4
l 5 ED zF r(   