mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	Relocating extras into lib/ansible/modules/ after merge
This commit is contained in:
		
					parent
					
						
							
								c65ba07d2c
							
						
					
				
			
			
				commit
				
					
						011ea55a8f
					
				
			
		
					 596 changed files with 0 additions and 266 deletions
				
			
		
							
								
								
									
										223
									
								
								lib/ansible/modules/cloud/cloudstack/cs_securitygroup.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										223
									
								
								lib/ansible/modules/cloud/cloudstack/cs_securitygroup.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,223 @@ | |||
| #!/usr/bin/python | ||||
| # -*- coding: utf-8 -*- | ||||
| # | ||||
| # (c) 2015, René Moser <mail@renemoser.net> | ||||
| # | ||||
| # This file is part of Ansible | ||||
| # | ||||
| # Ansible is free software: you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation, either version 3 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # Ansible is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with Ansible. If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| ANSIBLE_METADATA = {'status': ['stableinterface'], | ||||
|                     'supported_by': 'community', | ||||
|                     'version': '1.0'} | ||||
| 
 | ||||
| DOCUMENTATION = ''' | ||||
| --- | ||||
| module: cs_securitygroup | ||||
| short_description: Manages security groups on Apache CloudStack based clouds. | ||||
| description: | ||||
|     - Create and remove security groups. | ||||
| version_added: '2.0' | ||||
| author: "René Moser (@resmo)" | ||||
| options: | ||||
|   name: | ||||
|     description: | ||||
|       - Name of the security group. | ||||
|     required: true | ||||
|   description: | ||||
|     description: | ||||
|       - Description of the security group. | ||||
|     required: false | ||||
|     default: null | ||||
|   state: | ||||
|     description: | ||||
|       - State of the security group. | ||||
|     required: false | ||||
|     default: 'present' | ||||
|     choices: [ 'present', 'absent' ] | ||||
|   domain: | ||||
|     description: | ||||
|       - Domain the security group is related to. | ||||
|     required: false | ||||
|     default: null | ||||
|   account: | ||||
|     description: | ||||
|       - Account the security group is related to. | ||||
|     required: false | ||||
|     default: null | ||||
|   project: | ||||
|     description: | ||||
|       - Name of the project the security group to be created in. | ||||
|     required: false | ||||
|     default: null | ||||
| extends_documentation_fragment: cloudstack | ||||
| ''' | ||||
| 
 | ||||
| EXAMPLES = ''' | ||||
| # Create a security group | ||||
| - local_action: | ||||
|     module: cs_securitygroup | ||||
|     name: default | ||||
|     description: default security group | ||||
| 
 | ||||
| # Remove a security group | ||||
| - local_action: | ||||
|     module: cs_securitygroup | ||||
|     name: default | ||||
|     state: absent | ||||
| ''' | ||||
| 
 | ||||
| RETURN = ''' | ||||
| --- | ||||
| id: | ||||
|   description: UUID of the security group. | ||||
|   returned: success | ||||
|   type: string | ||||
|   sample: a6f7a5fc-43f8-11e5-a151-feff819cdc9f | ||||
| name: | ||||
|   description: Name of security group. | ||||
|   returned: success | ||||
|   type: string | ||||
|   sample: app | ||||
| description: | ||||
|   description: Description of security group. | ||||
|   returned: success | ||||
|   type: string | ||||
|   sample: application security group | ||||
| tags: | ||||
|   description: List of resource tags associated with the security group. | ||||
|   returned: success | ||||
|   type: dict | ||||
|   sample: '[ { "key": "foo", "value": "bar" } ]' | ||||
| project: | ||||
|   description: Name of project the security group is related to. | ||||
|   returned: success | ||||
|   type: string | ||||
|   sample: Production | ||||
| domain: | ||||
|   description: Domain the security group is related to. | ||||
|   returned: success | ||||
|   type: string | ||||
|   sample: example domain | ||||
| account: | ||||
|   description: Account the security group is related to. | ||||
|   returned: success | ||||
|   type: string | ||||
|   sample: example account | ||||
| ''' | ||||
| 
 | ||||
| # import cloudstack common | ||||
| from ansible.module_utils.cloudstack import * | ||||
| 
 | ||||
| 
 | ||||
| class AnsibleCloudStackSecurityGroup(AnsibleCloudStack): | ||||
| 
 | ||||
|     def __init__(self, module): | ||||
|         super(AnsibleCloudStackSecurityGroup, self).__init__(module) | ||||
|         self.security_group = None | ||||
| 
 | ||||
| 
 | ||||
|     def get_security_group(self): | ||||
|         if not self.security_group: | ||||
| 
 | ||||
|             args = {} | ||||
|             args['projectid'] = self.get_project(key='id') | ||||
|             args['account'] = self.get_account(key='name') | ||||
|             args['domainid'] = self.get_domain(key='id') | ||||
|             args['securitygroupname'] = self.module.params.get('name') | ||||
| 
 | ||||
|             sgs = self.cs.listSecurityGroups(**args) | ||||
|             if sgs: | ||||
|                 self.security_group = sgs['securitygroup'][0] | ||||
|         return self.security_group | ||||
| 
 | ||||
| 
 | ||||
|     def create_security_group(self): | ||||
|         security_group = self.get_security_group() | ||||
|         if not security_group: | ||||
|             self.result['changed'] = True | ||||
| 
 | ||||
|             args = {} | ||||
|             args['name'] = self.module.params.get('name') | ||||
|             args['projectid'] = self.get_project(key='id') | ||||
|             args['account'] = self.get_account(key='name') | ||||
|             args['domainid'] = self.get_domain(key='id') | ||||
|             args['description'] = self.module.params.get('description') | ||||
| 
 | ||||
|             if not self.module.check_mode: | ||||
|                 res = self.cs.createSecurityGroup(**args) | ||||
|                 if 'errortext' in res: | ||||
|                     self.module.fail_json(msg="Failed: '%s'" % res['errortext']) | ||||
|                 security_group = res['securitygroup'] | ||||
| 
 | ||||
|         return security_group | ||||
| 
 | ||||
| 
 | ||||
|     def remove_security_group(self): | ||||
|         security_group = self.get_security_group() | ||||
|         if security_group: | ||||
|             self.result['changed'] = True | ||||
| 
 | ||||
|             args = {} | ||||
|             args['name'] = self.module.params.get('name') | ||||
|             args['projectid'] = self.get_project(key='id') | ||||
|             args['account'] = self.get_account(key='name') | ||||
|             args['domainid'] = self.get_domain(key='id') | ||||
| 
 | ||||
|             if not self.module.check_mode: | ||||
|                 res = self.cs.deleteSecurityGroup(**args) | ||||
|                 if 'errortext' in res: | ||||
|                     self.module.fail_json(msg="Failed: '%s'" % res['errortext']) | ||||
| 
 | ||||
|         return security_group | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     argument_spec = cs_argument_spec() | ||||
|     argument_spec.update(dict( | ||||
|         name = dict(required=True), | ||||
|         description = dict(default=None), | ||||
|         state = dict(choices=['present', 'absent'], default='present'), | ||||
|         project = dict(default=None), | ||||
|         account = dict(default=None), | ||||
|         domain = dict(default=None), | ||||
|     )) | ||||
| 
 | ||||
|     module = AnsibleModule( | ||||
|         argument_spec=argument_spec, | ||||
|         required_together=cs_required_together(), | ||||
|         supports_check_mode=True | ||||
|     ) | ||||
| 
 | ||||
|     try: | ||||
|         acs_sg = AnsibleCloudStackSecurityGroup(module) | ||||
| 
 | ||||
|         state = module.params.get('state') | ||||
|         if state in ['absent']: | ||||
|             sg = acs_sg.remove_security_group() | ||||
|         else: | ||||
|             sg = acs_sg.create_security_group() | ||||
| 
 | ||||
|         result = acs_sg.get_result(sg) | ||||
| 
 | ||||
|     except CloudStackException as e: | ||||
|         module.fail_json(msg='CloudStackException: %s' % str(e)) | ||||
| 
 | ||||
|     module.exit_json(**result) | ||||
| 
 | ||||
| # import module snippets | ||||
| from ansible.module_utils.basic import * | ||||
| if __name__ == '__main__': | ||||
|     main() | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue