summaryrefslogtreecommitdiff
path: root/lib/ansible/modules/cloud/hcloud/hcloud_volume.py
diff options
context:
space:
mode:
Diffstat (limited to 'lib/ansible/modules/cloud/hcloud/hcloud_volume.py')
-rw-r--r--lib/ansible/modules/cloud/hcloud/hcloud_volume.py344
1 files changed, 0 insertions, 344 deletions
diff --git a/lib/ansible/modules/cloud/hcloud/hcloud_volume.py b/lib/ansible/modules/cloud/hcloud/hcloud_volume.py
deleted file mode 100644
index db141b264d..0000000000
--- a/lib/ansible/modules/cloud/hcloud/hcloud_volume.py
+++ /dev/null
@@ -1,344 +0,0 @@
-#!/usr/bin/python
-# -*- coding: utf-8 -*-
-
-# Copyright: (c) 2019, Hetzner Cloud GmbH <info@hetzner-cloud.de>
-# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
-
-from __future__ import absolute_import, division, print_function
-
-__metaclass__ = type
-
-ANSIBLE_METADATA = {
- "metadata_version": "1.1",
- "status": ["preview"],
- "supported_by": "community",
-}
-
-DOCUMENTATION = """
----
-module: hcloud_volume
-
-short_description: Create and manage block Volume on the Hetzner Cloud.
-
-version_added: "2.8"
-
-description:
- - Create, update and attach/detach block Volume on the Hetzner Cloud.
-
-author:
- - Christopher Schmitt (@cschmitt-hcloud)
-
-options:
- id:
- description:
- - The ID of the Hetzner Cloud Block Volume to manage.
- - Only required if no volume I(name) is given
- type: int
- name:
- description:
- - The Name of the Hetzner Cloud Block Volume to manage.
- - Only required if no volume I(id) is given or a volume does not exists.
- type: str
- size:
- description:
- - The size of the Block Volume in GB.
- - Required if volume does not yet exists.
- type: int
- automount:
- description:
- - Automatically mount the Volume.
- type: bool
- format:
- description:
- - Automatically Format the volume on creation
- - Can only be used in case the Volume does not exists.
- type: str
- choices: [xfs, ext4]
- location:
- description:
- - Location of the Hetzner Cloud Volume.
- - Required if no I(server) is given and Volume does not exists.
- type: str
- server:
- description:
- - Server Name the Volume should be assigned to.
- - Required if no I(location) is given and Volume does not exists.
- type: str
- delete_protection:
- description:
- - Protect the Volume for deletion.
- type: bool
- version_added: "2.10"
- labels:
- description:
- - User-defined key-value pairs.
- type: dict
- state:
- description:
- - State of the Volume.
- default: present
- choices: [absent, present]
- type: str
-extends_documentation_fragment: hcloud
-"""
-
-EXAMPLES = """
-- name: Create a Volume
- hcloud_volume:
- name: my-volume
- location: fsn1
- size: 100
- state: present
-- name: Create a Volume and format it with ext4
- hcloud_volume:
- name: my-volume
- location: fsn
- format: ext4
- size: 100
- state: present
-- name: Mount a existing Volume and automount
- hcloud_volume:
- name: my-volume
- server: my-server
- automount: yes
- state: present
-- name: Mount a existing Volume and automount
- hcloud_volume:
- name: my-volume
- server: my-server
- automount: yes
- state: present
-- name: Ensure the Volume is absent (remove if needed)
- hcloud_volume:
- name: my-volume
- state: absent
-"""
-
-RETURN = """
-hcloud_volume:
- description: The block Volume
- returned: Always
- type: complex
- contains:
- id:
- description: ID of the Volume
- type: int
- returned: Always
- sample: 12345
- name:
- description: Name of the Volume
- type: str
- returned: Always
- sample: my-volume
- size:
- description: Size in GB of the Volume
- type: int
- returned: Always
- sample: 1337
- linux_device:
- description: Path to the device that contains the Volume.
- returned: always
- type: str
- sample: /dev/disk/by-id/scsi-0HC_Volume_12345
- version_added: "2.10"
- location:
- description: Location name where the Volume is located at
- type: str
- returned: Always
- sample: "fsn1"
- labels:
- description: User-defined labels (key-value pairs)
- type: dict
- returned: Always
- sample:
- key: value
- mylabel: 123
- server:
- description: Server name where the Volume is attached to
- type: str
- returned: Always
- sample: "my-server"
- delete_protection:
- description: True if Volume is protected for deletion
- type: bool
- returned: always
- sample: false
- version_added: "2.10"
-"""
-
-from ansible.module_utils.basic import AnsibleModule
-from ansible.module_utils._text import to_native
-from ansible.module_utils.hcloud import Hcloud
-
-try:
- from hcloud.volumes.domain import Volume
- from hcloud.servers.domain import Server
- import hcloud
-except ImportError:
- pass
-
-
-class AnsibleHcloudVolume(Hcloud):
- def __init__(self, module):
- Hcloud.__init__(self, module, "hcloud_volume")
- self.hcloud_volume = None
-
- def _prepare_result(self):
- server_name = None
- if self.hcloud_volume.server is not None:
- server_name = self.hcloud_volume.server.name
-
- return {
- "id": to_native(self.hcloud_volume.id),
- "name": to_native(self.hcloud_volume.name),
- "size": self.hcloud_volume.size,
- "location": to_native(self.hcloud_volume.location.name),
- "labels": self.hcloud_volume.labels,
- "server": to_native(server_name),
- "linux_device": to_native(self.hcloud_volume.linux_device),
- "delete_protection": self.hcloud_volume.protection["delete"],
- }
-
- def _get_volume(self):
- try:
- if self.module.params.get("id") is not None:
- self.hcloud_volume = self.client.volumes.get_by_id(
- self.module.params.get("id")
- )
- else:
- self.hcloud_volume = self.client.volumes.get_by_name(
- self.module.params.get("name")
- )
- except hcloud.APIException as e:
- self.module.fail_json(msg=e.message)
-
- def _create_volume(self):
- self.module.fail_on_missing_params(
- required_params=["name", "size"]
- )
- params = {
- "name": self.module.params.get("name"),
- "size": self.module.params.get("size"),
- "automount": self.module.params.get("automount"),
- "format": self.module.params.get("format"),
- "labels": self.module.params.get("labels")
- }
- if self.module.params.get("server") is not None:
- params['server'] = self.client.servers.get_by_name(self.module.params.get("server"))
- elif self.module.params.get("location") is not None:
- params['location'] = self.client.locations.get_by_name(self.module.params.get("location"))
- else:
- self.module.fail_json(msg="server or location is required")
-
- if not self.module.check_mode:
- resp = self.client.volumes.create(**params)
- resp.action.wait_until_finished()
- [action.wait_until_finished() for action in resp.next_actions]
-
- self._mark_as_changed()
- self._get_volume()
-
- def _update_volume(self):
- try:
- size = self.module.params.get("size")
- if size:
- if self.hcloud_volume.size < size:
- if not self.module.check_mode:
- self.hcloud_volume.resize(size).wait_until_finished()
- self._mark_as_changed()
- elif self.hcloud_volume.size > size:
- self.module.warn("Shrinking of volumes is not supported")
-
- server_name = self.module.params.get("server")
- if server_name:
- server = self.client.servers.get_by_name(server_name)
- if self.hcloud_volume.server is None or self.hcloud_volume.server.name != server.name:
- if not self.module.check_mode:
- automount = self.module.params.get("automount", False)
- self.hcloud_volume.attach(server, automount=automount).wait_until_finished()
- self._mark_as_changed()
- else:
- if self.hcloud_volume.server is not None:
- if not self.module.check_mode:
- self.hcloud_volume.detach().wait_until_finished()
- self._mark_as_changed()
-
- labels = self.module.params.get("labels")
- if labels is not None and labels != self.hcloud_volume.labels:
- if not self.module.check_mode:
- self.hcloud_volume.update(labels=labels)
- self._mark_as_changed()
-
- delete_protection = self.module.params.get("delete_protection")
- if delete_protection is not None and delete_protection != self.hcloud_volume.protection["delete"]:
- if not self.module.check_mode:
- self.hcloud_volume.change_protection(delete=delete_protection).wait_until_finished()
- self._mark_as_changed()
-
- self._get_volume()
- except hcloud.APIException as e:
- self.module.fail_json(msg=e.message)
-
- def present_volume(self):
- self._get_volume()
- if self.hcloud_volume is None:
- self._create_volume()
- else:
- self._update_volume()
-
- def delete_volume(self):
- try:
- self._get_volume()
- if self.hcloud_volume is not None:
- if not self.module.check_mode:
- self.client.volumes.delete(self.hcloud_volume)
- self._mark_as_changed()
- self.hcloud_volume = None
- except hcloud.APIException as e:
- self.module.fail_json(msg=e.message)
-
- @staticmethod
- def define_module():
- return AnsibleModule(
- argument_spec=dict(
- id={"type": "int"},
- name={"type": "str"},
- size={"type": "int"},
- location={"type": "str"},
- server={"type": "str"},
- labels={"type": "dict"},
- automount={"type": "bool", "default": False},
- format={"type": "str",
- "choices": ['xfs', 'ext4'],
- },
- delete_protection={"type": "bool"},
- state={
- "choices": ["absent", "present"],
- "default": "present",
- },
- **Hcloud.base_module_arguments()
- ),
- required_one_of=[['id', 'name']],
- mutually_exclusive=[["location", "server"]],
- supports_check_mode=True,
- )
-
-
-def main():
- module = AnsibleHcloudVolume.define_module()
-
- hcloud = AnsibleHcloudVolume(module)
- state = module.params.get("state")
- if state == "absent":
- module.fail_on_missing_params(
- required_params=["name"]
- )
- hcloud.delete_volume()
- else:
- hcloud.present_volume()
-
- module.exit_json(**hcloud.get_result())
-
-
-if __name__ == "__main__":
- main()