mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-10-09 10:18:11 +02:00
feat(bbb/schema): auto-generate etherpad_api_key; set fsesl_password to alphanumeric_32 test(unit): add InventoryManager tests (Option B) expecting feature-generated creds as plain strings docs: full autocreation of credentials for BigBlueButton now enabled See: https://chatgpt.com/share/68d69ee8-3fd4-800f-9209-60026b338934
Shared Utility Code (module_utils/
) for Infinito.Nexus
This directory contains shared Python utility code (also known as "library code") for use by custom Ansible modules, plugins, or roles in the Infinito.Nexus project.
When to Use module_utils
- Shared logic: Use
module_utils
to define functions, classes, or helpers that are shared across multiple custom modules, plugins, or filter/lookups in your project. - Reduce duplication: Centralize code such as API clients, input validation, complex calculations, or protocol helpers.
- Maintainability: If you find yourself repeating code in different custom modules/plugins, refactor it into
module_utils/
.
Examples
- Shared HTTP(S) connection handler for multiple modules.
- Common validation or transformation functions for user input.
- Utility functions for interacting with Docker, LDAP, etc.
Usage Example
In a custom Ansible module or plugin:
from ansible.module_utils.infinito_utils import my_shared_function
When not to Use module_utils
- Do not place standalone Ansible modules or plugins here—those go into
library/
,filter_plugins/
, orlookup_plugins/
respectively. - Only use for code that will be imported by other plugins or modules.