mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
a409f8fc2f
* fix(gandi_livedns): fix unsafe conditionals in tests * feat(gandi_livedns): support personal access tokens Fixes #7639
218 lines
5.9 KiB
Python
218 lines
5.9 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright (c) 2019 Gregory Thiemonge <gregory.thiemonge@gmail.com>
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
__metaclass__ = type
|
|
|
|
DOCUMENTATION = r'''
|
|
---
|
|
module: gandi_livedns
|
|
author:
|
|
- Gregory Thiemonge (@gthiemonge)
|
|
version_added: "2.3.0"
|
|
short_description: Manage Gandi LiveDNS records
|
|
description:
|
|
- "Manages DNS records by the Gandi LiveDNS API, see the docs: U(https://doc.livedns.gandi.net/)."
|
|
extends_documentation_fragment:
|
|
- community.general.attributes
|
|
attributes:
|
|
check_mode:
|
|
support: full
|
|
diff_mode:
|
|
support: none
|
|
options:
|
|
personal_access_token:
|
|
description:
|
|
- Scoped API token.
|
|
- One of O(personal_access_token) and O(api_key) must be specified.
|
|
type: str
|
|
version_added: 9.0.0
|
|
api_key:
|
|
description:
|
|
- Account API token.
|
|
- Note that these type of keys are deprecated and might stop working at some point.
|
|
Use personal access tokens instead.
|
|
- One of O(personal_access_token) and O(api_key) must be specified.
|
|
type: str
|
|
record:
|
|
description:
|
|
- Record to add.
|
|
type: str
|
|
required: true
|
|
state:
|
|
description:
|
|
- Whether the record(s) should exist or not.
|
|
type: str
|
|
choices: [ absent, present ]
|
|
default: present
|
|
ttl:
|
|
description:
|
|
- The TTL to give the new record.
|
|
- Required when O(state=present).
|
|
type: int
|
|
type:
|
|
description:
|
|
- The type of DNS record to create.
|
|
type: str
|
|
required: true
|
|
values:
|
|
description:
|
|
- The record values.
|
|
- Required when O(state=present).
|
|
type: list
|
|
elements: str
|
|
domain:
|
|
description:
|
|
- The name of the Domain to work with (for example, "example.com").
|
|
required: true
|
|
type: str
|
|
'''
|
|
|
|
EXAMPLES = r'''
|
|
- name: Create a test A record to point to 127.0.0.1 in the my.com domain
|
|
community.general.gandi_livedns:
|
|
domain: my.com
|
|
record: test
|
|
type: A
|
|
values:
|
|
- 127.0.0.1
|
|
ttl: 7200
|
|
personal_access_token: dummytoken
|
|
register: record
|
|
|
|
- name: Create a mail CNAME record to www.my.com domain
|
|
community.general.gandi_livedns:
|
|
domain: my.com
|
|
type: CNAME
|
|
record: mail
|
|
values:
|
|
- www
|
|
ttl: 7200
|
|
personal_access_token: dummytoken
|
|
state: present
|
|
|
|
- name: Change its TTL
|
|
community.general.gandi_livedns:
|
|
domain: my.com
|
|
type: CNAME
|
|
record: mail
|
|
values:
|
|
- www
|
|
ttl: 10800
|
|
personal_access_token: dummytoken
|
|
state: present
|
|
|
|
- name: Delete the record
|
|
community.general.gandi_livedns:
|
|
domain: my.com
|
|
type: CNAME
|
|
record: mail
|
|
personal_access_token: dummytoken
|
|
state: absent
|
|
|
|
- name: Use a (deprecated) API Key
|
|
community.general.gandi_livedns:
|
|
domain: my.com
|
|
record: test
|
|
type: A
|
|
values:
|
|
- 127.0.0.1
|
|
ttl: 7200
|
|
api_key: dummyapikey
|
|
'''
|
|
|
|
RETURN = r'''
|
|
record:
|
|
description: A dictionary containing the record data.
|
|
returned: success, except on record deletion
|
|
type: dict
|
|
contains:
|
|
values:
|
|
description: The record content (details depend on record type).
|
|
returned: success
|
|
type: list
|
|
elements: str
|
|
sample:
|
|
- 192.0.2.91
|
|
- 192.0.2.92
|
|
record:
|
|
description: The record name.
|
|
returned: success
|
|
type: str
|
|
sample: www
|
|
ttl:
|
|
description: The time-to-live for the record.
|
|
returned: success
|
|
type: int
|
|
sample: 300
|
|
type:
|
|
description: The record type.
|
|
returned: success
|
|
type: str
|
|
sample: A
|
|
domain:
|
|
description: The domain associated with the record.
|
|
returned: success
|
|
type: str
|
|
sample: my.com
|
|
'''
|
|
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
from ansible_collections.community.general.plugins.module_utils.gandi_livedns_api import GandiLiveDNSAPI
|
|
|
|
|
|
def main():
|
|
module = AnsibleModule(
|
|
argument_spec=dict(
|
|
api_key=dict(type='str', no_log=True),
|
|
personal_access_token=dict(type='str', no_log=True),
|
|
record=dict(type='str', required=True),
|
|
state=dict(type='str', default='present', choices=['absent', 'present']),
|
|
ttl=dict(type='int'),
|
|
type=dict(type='str', required=True),
|
|
values=dict(type='list', elements='str'),
|
|
domain=dict(type='str', required=True),
|
|
),
|
|
supports_check_mode=True,
|
|
required_if=[
|
|
('state', 'present', ['values', 'ttl']),
|
|
],
|
|
mutually_exclusive=[
|
|
('api_key', 'personal_access_token'),
|
|
],
|
|
required_one_of=[
|
|
('api_key', 'personal_access_token'),
|
|
],
|
|
)
|
|
|
|
gandi_api = GandiLiveDNSAPI(module)
|
|
|
|
if module.params['state'] == 'present':
|
|
ret, changed = gandi_api.ensure_dns_record(module.params['record'],
|
|
module.params['type'],
|
|
module.params['ttl'],
|
|
module.params['values'],
|
|
module.params['domain'])
|
|
else:
|
|
ret, changed = gandi_api.delete_dns_record(module.params['record'],
|
|
module.params['type'],
|
|
module.params['values'],
|
|
module.params['domain'])
|
|
|
|
result = dict(
|
|
changed=changed,
|
|
)
|
|
if ret:
|
|
result['record'] = gandi_api.build_result(ret,
|
|
module.params['domain'])
|
|
|
|
module.exit_json(**result)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|