From 4bdec575c006096ce7a6420aad24f0d42db838ff Mon Sep 17 00:00:00 2001 From: Yanis Guenane Date: Tue, 14 Aug 2018 23:15:21 +0200 Subject: [PATCH] scaleway: Introduce scaleway_security_group_facts module MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Rémy Leone --- .../scaleway/scaleway_security_group_facts.py | 85 +++++++++++++++++++ .../tasks/main.yml | 12 +++ test/legacy/scaleway.yml | 5 +- 3 files changed, 99 insertions(+), 3 deletions(-) create mode 100644 lib/ansible/modules/cloud/scaleway/scaleway_security_group_facts.py create mode 100644 test/legacy/roles/scaleway_security_group_facts/tasks/main.yml diff --git a/lib/ansible/modules/cloud/scaleway/scaleway_security_group_facts.py b/lib/ansible/modules/cloud/scaleway/scaleway_security_group_facts.py new file mode 100644 index 00000000000..a539c13250c --- /dev/null +++ b/lib/ansible/modules/cloud/scaleway/scaleway_security_group_facts.py @@ -0,0 +1,85 @@ +#!/usr/bin/python +# -*- coding: utf-8 -*- +# +# (c) 2018, Yanis Guenane +# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) + +from __future__ import (absolute_import, division, print_function) +__metaclass__ = type + +ANSIBLE_METADATA = {'metadata_version': '1.1', + 'status': ['preview'], + 'supported_by': 'community'} + +DOCUMENTATION = r''' +--- +module: scaleway_security_group_facts +short_description: Gather facts about the Scaleway security groups available. +description: + - Gather facts about the Scaleway security groups available. +version_added: "2.7" +author: + - "Yanis Guenane (@Spredzy)" + - "Remy Leone (@sieben)" +extends_documentation_fragment: scaleway +''' + +EXAMPLES = r''' +- name: Gather Scaleway security groups facts + scaleway_security_group_facts: +''' + +RETURN = r''' +--- +scaleway_security_group_facts: + description: Response from Scaleway API + returned: success + type: complex + contains: + "scaleway_security_group_facts": [ + { + "description": "test-ams", + "enable_default_security": true, + "id": "7fcde327-8bed-43a6-95c4-6dfbc56d8b51", + "name": "test-ams", + "organization": "3f709602-5e6c-4619-b80c-e841c89734af", + "organization_default": false, + "servers": [ + { + "id": "12f19bc7-108c-4517-954c-e6b3d0311363", + "name": "scw-e0d158" + } + ] + } + ] +''' + +from ansible.module_utils.basic import AnsibleModule +from ansible.module_utils.scaleway import ( + Scaleway, ScalewayException, scaleway_argument_spec +) + + +class ScalewaySecurityGroupFacts(Scaleway): + + def __init__(self, module): + super(ScalewaySecurityGroupFacts, self).__init__(module) + self.name = 'security_groups' + + +def main(): + module = AnsibleModule( + argument_spec=scaleway_argument_spec(), + supports_check_mode=True, + ) + + try: + module.exit_json( + ansible_facts={'scaleway_security_group_facts': ScalewaySecurityGroupFacts(module).get_resources()} + ) + except ScalewayException as exc: + module.fail_json(msg=exc.message) + + +if __name__ == '__main__': + main() diff --git a/test/legacy/roles/scaleway_security_group_facts/tasks/main.yml b/test/legacy/roles/scaleway_security_group_facts/tasks/main.yml new file mode 100644 index 00000000000..6c2663949f3 --- /dev/null +++ b/test/legacy/roles/scaleway_security_group_facts/tasks/main.yml @@ -0,0 +1,12 @@ +- name: Get security group informations and register it in a variable + scaleway_security_group_facts: + register: security_groups + +- name: Display security_groups variable + debug: + var: security_groups + +- name: Ensure retrieval of security groups facts is success + assert: + that: + - security_groups is success diff --git a/test/legacy/scaleway.yml b/test/legacy/scaleway.yml index c88e5465880..6cc5c6c0bb0 100644 --- a/test/legacy/scaleway.yml +++ b/test/legacy/scaleway.yml @@ -2,12 +2,11 @@ - hosts: localhost gather_facts: no connection: local - environment: - SCW_API_KEY: "{{ lookup('env', 'SCW_API_KEY') }}" vars: scw_org: "{{ lookup('env', 'SCW_ORG') }}" roles: + - { role: scaleway_compute, tags: test_scaleway_compute } + - { role: scaleway_security_group_facts, tags: test_scaleway_security_group_facts } - { role: scaleway_ssh, tags: test_scaleway_ssh } - { role: scaleway_volume, tags: test_scaleway_volume } - - { role: scaleway_compute, tags: test_scaleway_compute }