ovirt_storage_connection: Fix issue in detaching the connection (#50005)
Currently deleting the storage connection just tries to delete the connection but it doesn't detach the connection from storage domain. The patch first tries to detach the connection from storage domain before attempting to delete the same if the storage domain parameter is provided.
This commit is contained in:
parent
7845373f96
commit
449fdf44b9
1 changed files with 24 additions and 8 deletions
|
@ -147,19 +147,22 @@ class StorageConnectionModule(BaseModule):
|
||||||
vfs_type=self.param('vfs_type'),
|
vfs_type=self.param('vfs_type'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def _get_storage_domain_service(self):
|
||||||
|
sds_service = self._connection.system_service().storage_domains_service()
|
||||||
|
sd = search_by_name(sds_service, self.param('storage'))
|
||||||
|
if sd is None:
|
||||||
|
raise Exception(
|
||||||
|
"Storage '%s' was not found." % self.param('storage')
|
||||||
|
)
|
||||||
|
return sd, sds_service.storage_domain_service(sd.id)
|
||||||
|
|
||||||
def post_present(self, entity_id):
|
def post_present(self, entity_id):
|
||||||
if self.param('storage'):
|
if self.param('storage'):
|
||||||
sds_service = self._connection.system_service().storage_domains_service()
|
sd, sd_service = self._get_storage_domain_service()
|
||||||
sd = search_by_name(sds_service, self.param('storage'))
|
|
||||||
if sd is None:
|
|
||||||
raise Exception(
|
|
||||||
"Storage '%s' was not found." % self.param('storage')
|
|
||||||
)
|
|
||||||
|
|
||||||
if entity_id not in [
|
if entity_id not in [
|
||||||
sd_conn.id for sd_conn in self._connection.follow_link(sd.storage_connections)
|
sd_conn.id for sd_conn in self._connection.follow_link(sd.storage_connections)
|
||||||
]:
|
]:
|
||||||
scs_service = sds_service.storage_domain_service(sd.id).storage_connections_service()
|
scs_service = sd_service.storage_connections_service()
|
||||||
if not self._module.check_mode:
|
if not self._module.check_mode:
|
||||||
scs_service.add(
|
scs_service.add(
|
||||||
connection=otypes.StorageConnection(
|
connection=otypes.StorageConnection(
|
||||||
|
@ -168,6 +171,18 @@ class StorageConnectionModule(BaseModule):
|
||||||
)
|
)
|
||||||
self.changed = True
|
self.changed = True
|
||||||
|
|
||||||
|
def pre_remove(self, entity_id):
|
||||||
|
if self.param('storage'):
|
||||||
|
sd, sd_service = self._get_storage_domain_service()
|
||||||
|
if entity_id in [
|
||||||
|
sd_conn.id for sd_conn in self._connection.follow_link(sd.storage_connections)
|
||||||
|
]:
|
||||||
|
scs_service = sd_service.storage_connections_service()
|
||||||
|
sc_service = scs_service.connection_service(entity_id)
|
||||||
|
if not self._module.check_mode:
|
||||||
|
sc_service.remove()
|
||||||
|
self.changed = True
|
||||||
|
|
||||||
def update_check(self, entity):
|
def update_check(self, entity):
|
||||||
return (
|
return (
|
||||||
equal(self.param('address'), entity.address) and
|
equal(self.param('address'), entity.address) and
|
||||||
|
@ -254,6 +269,7 @@ def main():
|
||||||
)
|
)
|
||||||
storage_connection_module.post_present(ret['id'])
|
storage_connection_module.post_present(ret['id'])
|
||||||
elif state == 'absent':
|
elif state == 'absent':
|
||||||
|
storage_connection_module.pre_remove(module.params['id'])
|
||||||
ret = storage_connection_module.remove(entity=entity)
|
ret = storage_connection_module.remove(entity=entity)
|
||||||
|
|
||||||
module.exit_json(**ret)
|
module.exit_json(**ret)
|
||||||
|
|
Loading…
Reference in a new issue