#!/usr/bin/python # -*- coding: utf-8 -*- # Copyright (c) 2016-2017 Hewlett Packard Enterprise Development LP # GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt) # SPDX-License-Identifier: GPL-3.0-or-later from __future__ import (absolute_import, division, print_function) __metaclass__ = type DOCUMENTATION = ''' --- module: oneview_fc_network_info short_description: Retrieve the information about one or more of the OneView Fibre Channel Networks description: - Retrieve the information about one or more of the Fibre Channel Networks from OneView. - This module was called C(oneview_fc_network_facts) before Ansible 2.9, returning C(ansible_facts). Note that the M(community.general.oneview_fc_network_info) module no longer returns C(ansible_facts)! requirements: - hpOneView >= 2.0.1 author: - Felipe Bulsoni (@fgbulsoni) - Thiago Miotto (@tmiotto) - Adriane Cardozo (@adriane-cardozo) attributes: check_mode: version_added: 3.3.0 # This was backported to 2.5.4 and 1.3.11 as well, since this was a bugfix options: name: description: - Fibre Channel Network name. type: str extends_documentation_fragment: - community.general.oneview - community.general.oneview.factsparams - community.general.attributes - community.general.attributes.info_module ''' EXAMPLES = ''' - name: Gather information about all Fibre Channel Networks community.general.oneview_fc_network_info: config: /etc/oneview/oneview_config.json delegate_to: localhost register: result - name: Print fetched information about Fibre Channel Networks ansible.builtin.debug: msg: "{{ result.fc_networks }}" - name: Gather paginated, filtered and sorted information about Fibre Channel Networks community.general.oneview_fc_network_info: config: /etc/oneview/oneview_config.json params: start: 1 count: 3 sort: 'name:descending' filter: 'fabricType=FabricAttach' delegate_to: localhost register: result - name: Print fetched information about paginated, filtered and sorted list of Fibre Channel Networks ansible.builtin.debug: msg: "{{ result.fc_networks }}" - name: Gather information about a Fibre Channel Network by name community.general.oneview_fc_network_info: config: /etc/oneview/oneview_config.json name: network name delegate_to: localhost register: result - name: Print fetched information about Fibre Channel Network found by name ansible.builtin.debug: msg: "{{ result.fc_networks }}" ''' RETURN = ''' fc_networks: description: Has all the OneView information about the Fibre Channel Networks. returned: Always, but can be null. type: dict ''' from ansible_collections.community.general.plugins.module_utils.oneview import OneViewModuleBase class FcNetworkInfoModule(OneViewModuleBase): def __init__(self): argument_spec = dict( name=dict(required=False, type='str'), params=dict(required=False, type='dict') ) super(FcNetworkInfoModule, self).__init__( additional_arg_spec=argument_spec, supports_check_mode=True, ) def execute_module(self): if self.module.params['name']: fc_networks = self.oneview_client.fc_networks.get_by('name', self.module.params['name']) else: fc_networks = self.oneview_client.fc_networks.get_all(**self.facts_params) return dict(changed=False, fc_networks=fc_networks) def main(): FcNetworkInfoModule().run() if __name__ == '__main__': main()