mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Bug Fix: na_elementsw_cluster_pair.py check if clusters are allready paired (#52379)
* Revert "changes to clusteR" This reverts commit 33ee1b71e4bc8435fb315762a871f8c4cb6c5f80. * Revert "Revert "changes to clusteR"" This reverts commit f1104a37b42886aebb4d2b2ab27c91c96d97858a. * bug fix * bug fixes * bug fix
This commit is contained in:
parent
e21ca4a00d
commit
9c54649449
1 changed files with 24 additions and 11 deletions
|
@ -127,16 +127,26 @@ class ElementSWClusterPair(object):
|
||||||
self.dest_elem = netapp_utils.create_sf_connection(module=self.module)
|
self.dest_elem = netapp_utils.create_sf_connection(module=self.module)
|
||||||
self.dest_elementsw_helper = NaElementSWModule(self.dest_elem)
|
self.dest_elementsw_helper = NaElementSWModule(self.dest_elem)
|
||||||
|
|
||||||
def check_if_already_paired(self):
|
def check_if_already_paired(self, paired_clusters, hostname):
|
||||||
|
for pair in paired_clusters.cluster_pairs:
|
||||||
|
if pair.mvip == hostname:
|
||||||
|
return pair.cluster_pair_id
|
||||||
|
return None
|
||||||
|
|
||||||
|
def get_src_pair_id(self):
|
||||||
"""
|
"""
|
||||||
Check for idempotency
|
Check for idempotency
|
||||||
"""
|
"""
|
||||||
# src cluster and dest cluster exist
|
# src cluster and dest cluster exist
|
||||||
paired_clusters = self.elem.list_cluster_pairs()
|
paired_clusters = self.elem.list_cluster_pairs()
|
||||||
for pair in paired_clusters.cluster_pairs:
|
return self.check_if_already_paired(paired_clusters, self.parameters['dest_mvip'])
|
||||||
if pair.mvip == self.parameters['dest_mvip']:
|
|
||||||
return pair.cluster_pair_id
|
def get_dest_pair_id(self):
|
||||||
return None
|
"""
|
||||||
|
Getting destination cluster_pair_id
|
||||||
|
"""
|
||||||
|
paired_clusters = self.dest_elem.list_cluster_pairs()
|
||||||
|
return self.check_if_already_paired(paired_clusters, self.parameters['hostname'])
|
||||||
|
|
||||||
def pair_clusters(self):
|
def pair_clusters(self):
|
||||||
"""
|
"""
|
||||||
|
@ -152,13 +162,13 @@ class ElementSWClusterPair(object):
|
||||||
self.parameters['dest_mvip']),
|
self.parameters['dest_mvip']),
|
||||||
exception=to_native(err))
|
exception=to_native(err))
|
||||||
|
|
||||||
def unpair_clusters(self, pair_id):
|
def unpair_clusters(self, pair_id_source, pair_id_dest):
|
||||||
"""
|
"""
|
||||||
Delete cluster pair
|
Delete cluster pair
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
self.elem.remove_cluster_pair(cluster_pair_id=pair_id)
|
self.elem.remove_cluster_pair(cluster_pair_id=pair_id_source)
|
||||||
self.dest_elem.remove_cluster_pair(cluster_pair_id=pair_id)
|
self.dest_elem.remove_cluster_pair(cluster_pair_id=pair_id_dest)
|
||||||
except solidfire.common.ApiServerError as err:
|
except solidfire.common.ApiServerError as err:
|
||||||
self.module.fail_json(msg="Error unpairing cluster %s and %s"
|
self.module.fail_json(msg="Error unpairing cluster %s and %s"
|
||||||
% (self.parameters['hostname'],
|
% (self.parameters['hostname'],
|
||||||
|
@ -169,13 +179,16 @@ class ElementSWClusterPair(object):
|
||||||
"""
|
"""
|
||||||
Call create / delete cluster pair methods
|
Call create / delete cluster pair methods
|
||||||
"""
|
"""
|
||||||
pair_id = self.check_if_already_paired()
|
pair_id_source = self.get_src_pair_id()
|
||||||
|
# If already paired, find the cluster_pair_id of destination cluster
|
||||||
|
if pair_id_source:
|
||||||
|
pair_id_dest = self.get_dest_pair_id()
|
||||||
# calling helper to determine action
|
# calling helper to determine action
|
||||||
cd_action = self.na_helper.get_cd_action(pair_id, self.parameters)
|
cd_action = self.na_helper.get_cd_action(pair_id_source, self.parameters)
|
||||||
if cd_action == "create":
|
if cd_action == "create":
|
||||||
self.pair_clusters()
|
self.pair_clusters()
|
||||||
elif cd_action == "delete":
|
elif cd_action == "delete":
|
||||||
self.unpair_clusters(pair_id)
|
self.unpair_clusters(pair_id_source, pair_id_dest)
|
||||||
self.module.exit_json(changed=self.na_helper.changed)
|
self.module.exit_json(changed=self.na_helper.changed)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue