Ovirt add managed storage domain (#57995)

* init managed storage domain

* add version added

* add no log for sensitive options

* add driver default types

* update docs

* update pep8 syntax

* update example syntax

* update example syntax

* set default domain_fucntion for managed_block_storage

* correct pep8 syntax

* update managed example

* update managed docs
This commit is contained in:
Martin Nečas 2019-06-18 20:05:48 +02:00 committed by ansibot
parent b768a0780c
commit b4d4f77963

View file

@ -158,6 +158,20 @@ options:
mount_options: mount_options:
description: description:
- Option which will be passed when mounting storage. - Option which will be passed when mounting storage.
managed_block_storage:
description:
- "Dictionary with values for managed block storage type"
- "Note: available from ovirt 4.3"
suboptions:
driver_options:
description:
- "The options to be passed when creating a storage domain using a cinder driver."
- "List of dictionary containing C(name) and C(value) of driver option"
driver_sensitive_options:
description:
- "Parameters containing sensitive information, to be passed when creating a storage domain using a cinder driver."
- "List of dictionary containing C(name) and C(value) of driver sensitive option"
version_added: "2.9"
fcp: fcp:
description: description:
- "Dictionary with values for fibre channel storage type:" - "Dictionary with values for fibre channel storage type:"
@ -325,6 +339,26 @@ EXAMPLES = '''
address: 10.34.63.199 address: 10.34.63.199
path: /path/iso path: /path/iso
# Create managed storage domain
# Available from ovirt 4.3 and ansible 2.9
- ovirt_storage_domain:
name: my_managed_domain
host: myhost
data_center: mydatacenter
managed_block_storage:
driver_options:
- name: rbd_pool
value: pool1
- name: rbd_user
value: admin
- name: volume_driver
value: cinder.volume.drivers.rbd.RBDDriver
- name: rbd_keyring_conf
value: /etc/ceph/keyring
driver_sensitive_options:
- name: secret_password
value: password
# Remove storage domain # Remove storage domain
- ovirt_storage_domain: - ovirt_storage_domain:
state: absent state: absent
@ -375,12 +409,12 @@ from ansible.module_utils.ovirt import (
class StorageDomainModule(BaseModule): class StorageDomainModule(BaseModule):
def _get_storage_type(self): def _get_storage_type(self):
for sd_type in ['nfs', 'iscsi', 'posixfs', 'glusterfs', 'fcp', 'localfs']: for sd_type in ['nfs', 'iscsi', 'posixfs', 'glusterfs', 'fcp', 'localfs', 'managed_block_storage']:
if self.param(sd_type) is not None: if self.param(sd_type) is not None:
return sd_type return sd_type
def _get_storage(self): def _get_storage(self):
for sd_type in ['nfs', 'iscsi', 'posixfs', 'glusterfs', 'fcp', 'localfs']: for sd_type in ['nfs', 'iscsi', 'posixfs', 'glusterfs', 'fcp', 'localfs', 'managed_block_storage']:
if self.param(sd_type) is not None: if self.param(sd_type) is not None:
return self.param(sd_type) return self.param(sd_type)
@ -433,10 +467,22 @@ class StorageDomainModule(BaseModule):
warning_low_space_indicator=self.param('warning_low_space'), warning_low_space_indicator=self.param('warning_low_space'),
import_=True if self.param('state') == 'imported' else None, import_=True if self.param('state') == 'imported' else None,
id=self.param('id') if self.param('state') == 'imported' else None, id=self.param('id') if self.param('state') == 'imported' else None,
type=otypes.StorageDomainType(self.param('domain_function')), type=otypes.StorageDomainType(storage_type if storage_type == 'managed_block_storage' else self.param('domain_function')),
host=otypes.Host(name=self.param('host')), host=otypes.Host(name=self.param('host')),
discard_after_delete=self.param('discard_after_delete'), discard_after_delete=self.param('discard_after_delete'),
storage=otypes.HostStorage( storage=otypes.HostStorage(
driver_options=[
otypes.Property(
name=do.get('name'),
value=do.get('value')
) for do in storage.get('driver_options')
] if storage.get('driver_options') else None,
driver_sensitive_options=[
otypes.Property(
name=dso.get('name'),
value=dso.get('value')
) for dso in storage.get('driver_sensitive_options')
] if storage.get('driver_sensitive_options') else None,
type=otypes.StorageType(storage_type), type=otypes.StorageType(storage_type),
logical_units=[ logical_units=[
otypes.LogicalUnit( otypes.LogicalUnit(
@ -671,6 +717,9 @@ def main():
localfs=dict(default=None, type='dict'), localfs=dict(default=None, type='dict'),
nfs=dict(default=None, type='dict'), nfs=dict(default=None, type='dict'),
iscsi=dict(default=None, type='dict'), iscsi=dict(default=None, type='dict'),
managed_block_storage=dict(default=None, type='dict', options=dict(
driver_options=dict(type='list'),
driver_sensitive_options=dict(type='list', no_log=True))),
posixfs=dict(default=None, type='dict'), posixfs=dict(default=None, type='dict'),
glusterfs=dict(default=None, type='dict'), glusterfs=dict(default=None, type='dict'),
fcp=dict(default=None, type='dict'), fcp=dict(default=None, type='dict'),