From 765d8ce92736095dd64d9494dad7ed055f33d3fe Mon Sep 17 00:00:00 2001 From: Sean Sullivan Date: Sun, 10 Nov 2024 10:04:53 -0500 Subject: [PATCH 1/2] update collection arguments --- awx_collection/plugins/doc_fragments/auth.py | 11 ++--- .../plugins/doc_fragments/auth_plugin.py | 16 +++----- .../plugins/module_utils/controller_api.py | 40 +++++++++++++++---- 3 files changed, 45 insertions(+), 22 deletions(-) diff --git a/awx_collection/plugins/doc_fragments/auth.py b/awx_collection/plugins/doc_fragments/auth.py index 763fe94dcddf..40df8509ee30 100644 --- a/awx_collection/plugins/doc_fragments/auth.py +++ b/awx_collection/plugins/doc_fragments/auth.py @@ -19,19 +19,19 @@ class ModuleDocFragment(object): - If value not set, will try environment variable C(CONTROLLER_HOST) and then config files - If value not specified by any means, the value of C(127.0.0.1) will be used type: str - aliases: [ tower_host ] + aliases: [ tower_host, aap_hostname ] controller_username: description: - Username for your controller instance. - If value not set, will try environment variable C(CONTROLLER_USERNAME) and then config files type: str - aliases: [ tower_username ] + aliases: [ tower_username, aap_username ] controller_password: description: - Password for your controller instance. - If value not set, will try environment variable C(CONTROLLER_PASSWORD) and then config files type: str - aliases: [ tower_password ] + aliases: [ tower_password , aap_password ] controller_oauthtoken: description: - The OAuth token to use. @@ -41,7 +41,7 @@ class ModuleDocFragment(object): - If value not set, will try environment variable C(CONTROLLER_OAUTH_TOKEN) and then config files type: raw version_added: "3.7.0" - aliases: [ tower_oauthtoken ] + aliases: [ tower_oauthtoken, aap_token ] validate_certs: description: - Whether to allow insecure connections to AWX. @@ -49,12 +49,13 @@ class ModuleDocFragment(object): - This should only be used on personally controlled sites using self-signed certificates. - If value not set, will try environment variable C(CONTROLLER_VERIFY_SSL) and then config files type: bool - aliases: [ tower_verify_ssl ] + aliases: [ tower_verify_ssl, aap_validate_certs ] request_timeout: description: - Specify the timeout Ansible should use in requests to the controller host. - Defaults to 10s, but this is handled by the shared module_utils code type: float + aliases: [ aap_request_timeout ] controller_config_file: description: - Path to the controller config file. diff --git a/awx_collection/plugins/doc_fragments/auth_plugin.py b/awx_collection/plugins/doc_fragments/auth_plugin.py index b46eaf6bbf03..6914dfab9cec 100644 --- a/awx_collection/plugins/doc_fragments/auth_plugin.py +++ b/awx_collection/plugins/doc_fragments/auth_plugin.py @@ -17,43 +17,39 @@ class ModuleDocFragment(object): description: The network address of your Automation Platform Controller host. env: - name: CONTROLLER_HOST - - name: TOWER_HOST deprecated: collection_name: 'awx.awx' version: '4.0.0' why: Collection name change - alternatives: 'CONTROLLER_HOST' + alternatives: 'TOWER_HOST, AAP_HOSTNAME' username: description: The user that you plan to use to access inventories on the controller. env: - name: CONTROLLER_USERNAME - - name: TOWER_USERNAME deprecated: collection_name: 'awx.awx' version: '4.0.0' why: Collection name change - alternatives: 'CONTROLLER_USERNAME' + alternatives: 'TOWER_USERNAME, AAP_USERNAME' password: description: The password for your controller user. env: - name: CONTROLLER_PASSWORD - - name: TOWER_PASSWORD deprecated: collection_name: 'awx.awx' version: '4.0.0' why: Collection name change - alternatives: 'CONTROLLER_PASSWORD' + alternatives: 'TOWER_PASSWORD, AAP_PASSWORD' oauth_token: description: - The OAuth token to use. env: - name: CONTROLLER_OAUTH_TOKEN - - name: TOWER_OAUTH_TOKEN deprecated: collection_name: 'awx.awx' version: '4.0.0' why: Collection name change - alternatives: 'CONTROLLER_OAUTH_TOKEN' + alternatives: 'TOWER_OAUTH_TOKEN, AAP_TOKEN' verify_ssl: description: - Specify whether Ansible should verify the SSL certificate of the controller host. @@ -61,12 +57,11 @@ class ModuleDocFragment(object): type: bool env: - name: CONTROLLER_VERIFY_SSL - - name: TOWER_VERIFY_SSL deprecated: collection_name: 'awx.awx' version: '4.0.0' why: Collection name change - alternatives: 'CONTROLLER_VERIFY_SSL' + alternatives: 'TOWER_VERIFY_SSL, AAP_VALIDATE_CERTS' aliases: [ validate_certs ] request_timeout: description: @@ -76,6 +71,7 @@ class ModuleDocFragment(object): type: float env: - name: CONTROLLER_REQUEST_TIMEOUT + alternatives: 'AAP_REQUEST_TIMEOUT' notes: - If no I(config_file) is provided we will attempt to use the tower-cli library diff --git a/awx_collection/plugins/module_utils/controller_api.py b/awx_collection/plugins/module_utils/controller_api.py index c2681a49afe9..e08e9a4dfc82 100644 --- a/awx_collection/plugins/module_utils/controller_api.py +++ b/awx_collection/plugins/module_utils/controller_api.py @@ -50,15 +50,41 @@ class ItemNotDefined(Exception): class ControllerModule(AnsibleModule): url = None AUTH_ARGSPEC = dict( - controller_host=dict(required=False, aliases=['tower_host'], fallback=(env_fallback, ['CONTROLLER_HOST', 'TOWER_HOST'])), - controller_username=dict(required=False, aliases=['tower_username'], fallback=(env_fallback, ['CONTROLLER_USERNAME', 'TOWER_USERNAME'])), - controller_password=dict(no_log=True, aliases=['tower_password'], required=False, fallback=(env_fallback, ['CONTROLLER_PASSWORD', 'TOWER_PASSWORD'])), - validate_certs=dict(type='bool', aliases=['tower_verify_ssl'], required=False, fallback=(env_fallback, ['CONTROLLER_VERIFY_SSL', 'TOWER_VERIFY_SSL'])), - request_timeout=dict(type='float', required=False, fallback=(env_fallback, ['CONTROLLER_REQUEST_TIMEOUT'])), + controller_host=dict( + required=False, + aliases=['tower_host', 'aap_hostname'], + fallback=(env_fallback, ['CONTROLLER_HOST', 'TOWER_HOST', 'AAP_HOSTNAME'])), + controller_username=dict( + required=False, + aliases=['tower_username', 'aap_username'], + fallback=(env_fallback, ['CONTROLLER_USERNAME', 'TOWER_USERNAME', 'AAP_USERNAME'])), + controller_password=dict( + no_log=True, + aliases=['tower_password', 'aap_password'], + required=False, + fallback=(env_fallback, ['CONTROLLER_PASSWORD', 'TOWER_PASSWORD', 'AAP_PASSWORD'])), + validate_certs=dict( + type='bool', + aliases=['tower_verify_ssl', 'aap_validate_certs'], + required=False, + fallback=(env_fallback, ['CONTROLLER_VERIFY_SSL', 'TOWER_VERIFY_SSL', 'AAP_VALIDATE_CERTS'])), + request_timeout=dict( + type='float', + aliases=['aap_request_timeout'], + required=False, + fallback=(env_fallback, ['CONTROLLER_REQUEST_TIMEOUT', 'AAP_REQUEST_TIMEOUT'])), controller_oauthtoken=dict( - type='raw', no_log=True, aliases=['tower_oauthtoken'], required=False, fallback=(env_fallback, ['CONTROLLER_OAUTH_TOKEN', 'TOWER_OAUTH_TOKEN']) + type='raw', + no_log=True, + aliases=['tower_oauthtoken', 'aap_token'], + required=False, + fallback=(env_fallback, ['CONTROLLER_OAUTH_TOKEN', 'TOWER_OAUTH_TOKEN', 'AAP_TOKEN']) ), - controller_config_file=dict(type='path', aliases=['tower_config_file'], required=False, default=None), + controller_config_file=dict( + type='path', + aliases=['tower_config_file'], + required=False, + default=None), ) # Associations of these types are ordered and have special consideration in the modified associations function ordered_associations = ['instance_groups', 'galaxy_credentials'] From 84109a6ab1fdbaef689d2be0c937df79d701d6c9 Mon Sep 17 00:00:00 2001 From: Alan Rominger Date: Thu, 2 Jan 2025 15:23:20 -0500 Subject: [PATCH 2/2] Add integration testing for new param --- .../tests/integration/targets/params/tasks/main.yml | 11 +++++++++++ 1 file changed, 11 insertions(+) create mode 100644 awx_collection/tests/integration/targets/params/tasks/main.yml diff --git a/awx_collection/tests/integration/targets/params/tasks/main.yml b/awx_collection/tests/integration/targets/params/tasks/main.yml new file mode 100644 index 000000000000..86e8688c02d1 --- /dev/null +++ b/awx_collection/tests/integration/targets/params/tasks/main.yml @@ -0,0 +1,11 @@ +- name: Perform an action with a different hostname via aap_hostname + inventory: + name: "Demo Inventory" + organization: Default + aap_hostname: https://foohostbar.invalid + ignore_errors: true + register: result + +- assert: + that: + - "'foohostbar' in result.msg"