mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
[PR #7364/8a51a3c3 backport][stable-7] Add option force_delete module gitlab_group (#7368)
Add option force_delete module gitlab_group (#7364)
* Update gitlab_group.py
- Add option force (default value: false) to delete group even if projects exists in it.
* Create 7364-add-option-force-gitlab-group.yml
* Update 7364-add-option-force-gitlab-group.yml
* Update plugins/modules/gitlab_group.py
Co-authored-by: Felix Fontein <felix@fontein.de>
* Update changelogs/fragments/7364-add-option-force-gitlab-group.yml
Co-authored-by: Felix Fontein <felix@fontein.de>
* Update plugins/modules/gitlab_group.py
Co-authored-by: Felix Fontein <felix@fontein.de>
* Update gitlab_group.py
- Add message in projects inside group
* Update plugins/modules/gitlab_group.py
Co-authored-by: Felix Fontein <felix@fontein.de>
* Update gitlab_group.py
Split lines
* Update gitlab_group.py
---------
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit 8a51a3c30c
)
Co-authored-by: paytroff <paytroff@gmail.com>
This commit is contained in:
parent
d18092a128
commit
00efbe6ea2
2 changed files with 22 additions and 5 deletions
|
@ -0,0 +1,2 @@
|
|||
minor_changes:
|
||||
- "gitlab_group - add option ``force_delete`` (default: false) which allows delete group even if projects exists in it (https://github.com/ansible-collections/community.general/pull/7364)."
|
|
@ -94,6 +94,13 @@ options:
|
|||
- This option is only used on creation, not for updates.
|
||||
type: path
|
||||
version_added: 4.2.0
|
||||
force_delete:
|
||||
description:
|
||||
- Force delete group even if projects in it.
|
||||
- Used only when O(state=absent).
|
||||
type: bool
|
||||
default: false
|
||||
version_added: 7.5.0
|
||||
'''
|
||||
|
||||
EXAMPLES = '''
|
||||
|
@ -279,12 +286,18 @@ class GitLabGroup(object):
|
|||
|
||||
return (changed, group)
|
||||
|
||||
def delete_group(self):
|
||||
'''
|
||||
@param force To delete even if projects inside
|
||||
'''
|
||||
def delete_group(self, force=False):
|
||||
group = self.group_object
|
||||
|
||||
if len(group.projects.list(all=False)) >= 1:
|
||||
if not force and len(group.projects.list(all=False)) >= 1:
|
||||
self._module.fail_json(
|
||||
msg="There are still projects in this group. These needs to be moved or deleted before this group can be removed.")
|
||||
msg=("There are still projects in this group. "
|
||||
"These needs to be moved or deleted before this group can be removed. "
|
||||
"Use 'force_delete' to 'true' to force deletion of existing projects.")
|
||||
)
|
||||
else:
|
||||
if self._module.check_mode:
|
||||
return True
|
||||
|
@ -295,7 +308,7 @@ class GitLabGroup(object):
|
|||
self._module.fail_json(msg="Failed to delete group: %s " % to_native(e))
|
||||
|
||||
'''
|
||||
@param name Name of the groupe
|
||||
@param name Name of the group
|
||||
@param full_path Complete path of the Group including parent group path. <parent_path>/<group_path>
|
||||
'''
|
||||
def exists_group(self, project_identifier):
|
||||
|
@ -322,6 +335,7 @@ def main():
|
|||
subgroup_creation_level=dict(type='str', choices=['maintainer', 'owner']),
|
||||
require_two_factor_authentication=dict(type='bool'),
|
||||
avatar_path=dict(type='path'),
|
||||
force_delete=dict(type='bool', default=False),
|
||||
))
|
||||
|
||||
module = AnsibleModule(
|
||||
|
@ -354,6 +368,7 @@ def main():
|
|||
subgroup_creation_level = module.params['subgroup_creation_level']
|
||||
require_two_factor_authentication = module.params['require_two_factor_authentication']
|
||||
avatar_path = module.params['avatar_path']
|
||||
force_delete = module.params['force_delete']
|
||||
|
||||
gitlab_instance = gitlab_authentication(module)
|
||||
|
||||
|
@ -375,7 +390,7 @@ def main():
|
|||
|
||||
if state == 'absent':
|
||||
if group_exists:
|
||||
gitlab_group.delete_group()
|
||||
gitlab_group.delete_group(force=force_delete)
|
||||
module.exit_json(changed=True, msg="Successfully deleted group %s" % group_name)
|
||||
else:
|
||||
module.exit_json(changed=False, msg="Group deleted or does not exists")
|
||||
|
|
Loading…
Reference in a new issue