ansible/docs/docsite/rst/dev_guide/developing_module_utilities.rst
Sandra McCann ceb474bb9e [WIP] Backport/2.7/batch port (#45859)
Batch of docs backports:

* docs: Clarify include_task v import_tasks with conditionals (#43856)
(cherry picked from commit 6be42a2a0e)

* Add single quotes around package name (#45152)
(cherry picked from commit 0d81386144)

* prefer ansible_facts namespace and dict notation (#44980)
(cherry picked from commit 44510448b0)

* fix cherrypick conflict - scenario_guides

* Update implicit_localhost.rst (#45455)
(cherry picked from commit f68cd1acc6)

* updated fbsd install instructions (#45309)
(cherry picked from commit e9c2695ce7)

* Change "Defaulting Undefined Variables" (#41379)
(cherry picked from commit e35c4be1c1)

* adds license details to dev guide pages (#45574)
(cherry picked from commit 6e68d77f6d)

* FAQ: fix a typo, add link to 'vars' lookup (#42412)
(cherry picked from commit 95649dc793)

* Fix link and toctree (#45595)
(cherry picked from commit 6999bf318f)

* Improve the local toctree (and title) (#45590)
(cherry picked from commit afea00fa9f)

* Add undocumented configuration parameter and explain in porting guide (#36059)
(cherry picked from commit a892a6ef03)

* Simplify PPA installation for Ubuntu (#45690)
(cherry picked from commit 78e9f452a5)

* adding git+ssh uri scheme (#36025)
(cherry picked from commit 84a4257774)

* Add workaround for non-standard kerberos environments (#41465)
(cherry picked from commit 4e532e0ad9)

* Restore license agreement (#45809)
(cherry picked from commit f430f60541)

* partial cherry-pick - lenovo doc update PR 45483
2018-09-19 22:02:01 -05:00

6.4 KiB

Appendix: Module Utilities

Ansible provides a number of module utilities that provide helper functions that you can use when developing your own modules. The basic.py module utility provides the main entry point for accessing the Ansible library, and all Python Ansible modules must, at minimum, import AnsibleModule:

from ansible.module_utils.basic import AnsibleModule

The following is a list of module_utils files and a general description. The module utility source code lives in the ./lib/ansible/module_utils directory under your main Ansible path - for more details on any specific module utility, please see the source code.

  • api.py - Adds shared support for generic API modules.
  • azure_rm_common.py - Definitions and utilities for Microsoft Azure Resource Manager template deployments.
  • basic.py - General definitions and helper utilities for Ansible modules.
  • cloudstack.py - Utilities for CloudStack modules.
  • database.py - Miscellaneous helper functions for PostGRES and MySQL
  • docker_common.py - Definitions and helper utilities for modules working with Docker.
  • ec2.py - Definitions and utilities for modules working with Amazon EC2
  • facts/- Folder containing helper functions for modules that return facts. See https://github.com/ansible/ansible/pull/23012 for more information.
  • gce.py - Definitions and helper functions for modules that work with Google Compute Engine resources.
  • ismount.py - Contains single helper function that fixes os.path.ismount
  • keycloak.py - Definitions and helper functions for modules working with the Keycloak API
  • known_hosts.py - utilities for working with known_hosts file
  • manageiq.py - Functions and utilities for modules that work with ManageIQ platform and its resources.
  • memset.py - Helper functions and utilities for interacting with Memset's API.
  • mysql.py - Allows modules to connect to a MySQL instance
  • netapp.py - Functions and utilities for modules that work with the NetApp storage platforms.
  • network/a10/a10.py - Utilities used by the a10_server module to manage A10 Networks devices.
  • network/aci/aci.py - Definitions and helper functions for modules that manage Cisco ACI Fabrics.
  • network/aireos/aireos.py - Definitions and helper functions for modules that manage Cisco WLC devices.
  • network/aos/aos.py - Module support utilities for managing Apstra AOS Server.
  • network/aruba/aruba.py - Helper functions for modules working with Aruba networking devices.
  • network/asa/asa.py - Module support utilities for managing Cisco ASA network devices.
  • network/avi/avi.py - Helper functions for modules working with AVI networking devices.
  • network/bigswitch/bigswitch_utils.py - Utilities used by the bigswitch module to manage Big Switch Networks devices.
  • network/cloudengine/ce.py - Module support utilities for managing Huawei Cloudengine switch.
  • network/cnos/cnos.py - Helper functions for modules working on devices running Lenovo CNOS.
  • network/common/config.py - Configuration utility functions for use by networking modules
  • network/common/netconf.py - Definitions and helper functions for modules that use Netconf transport.
  • network/common/parsing.py - Definitions and helper functions for Network modules.
  • network/common/network.py - Functions for running commands on networking devices
  • network/common/utils.py - Defines commands and comparison operators and other utilises for use in networking modules
  • network/dellos6/dellos6.py - Module support utilities for managing device running Dell OS6.
  • network/dellos9/dellos9.py - Module support utilities for managing device running Dell OS9.
  • network/dellos10/dellos10.py - Module support utilities for managing device running Dell OS10.
  • network/enos/enos.py - Helper functions for modules working with Lenovo ENOS devices.
  • network/eos/eos.py - Helper functions for modules working with EOS networking devices.
  • network/fortios/fortios.py - Module support utilities for managing FortiOS devices.
  • network/ios/ios.py - Definitions and helper functions for modules that manage Cisco IOS networking devices
  • network/iosxr/iosxr.py - Definitions and helper functions for modules that manage Cisco IOS-XR networking devices.
  • network/ironware/ironware.py - Module support utilities for managing Brocade IronWare devices.
  • network/junos/junos.py - Definitions and helper functions for modules that manage Junos networking devices.
  • network/meraki/meraki.py - Utilities specifically for the Meraki network modules.
  • network/netscaler/netscaler.py - Utilities specifically for the netscaler network modules.
  • network/nso/nso.py - Utilities for modules that work with Cisco NSO.
  • network/nxos/nxos.py - Contains definitions and helper functions specific to Cisco NXOS networking devices.
  • network/onyx/onyx.py - Definitions and helper functions for modules that manage Mellanox ONYX networking devices.
  • network/ordance/ordance.py - Module support utilities for managing Ordnance devices.
  • network/sros/sros.py - Helper functions for modules working with Open vSwitch bridges.
  • network/vyos/vyos.py - Definitions and functions for working with VyOS networking
  • openstack.py - Utilities for modules that work with Openstack instances.
  • openswitch.py - Definitions and helper functions for modules that manage OpenSwitch devices
  • powershell.ps1 - Utilities for working with Microsoft Windows clients
  • pure.py - Functions and utilities for modules that work with the Pure Storage storage platforms.
  • pycompat24.py - Exception workaround for Python 2.4.
  • rax.py - Definitions and helper functions for modules that work with Rackspace resources.
  • redhat.py - Functions for modules that manage Red Hat Network registration and subscriptions
  • service.py - Contains utilities to enable modules to work with Linux services (placeholder, not in use).
  • shell.py - Functions to allow modules to create shells and work with shell commands
  • six/__init__.py - Bundled copy of the Six Python library to aid in writing code compatible with both Python 2 and Python 3.
  • splitter.py - String splitting and manipulation utilities for working with Jinja2 templates
  • urls.py - Utilities for working with http and https requests
  • vca.py - Contains utilities for modules that work with VMware vCloud Air
  • vmware.py - Contains utilities for modules that work with VMware vSphere VMs