mirror of
https://github.com/ansible/awx.git
synced 2026-03-13 23:17:32 -02:30
Adding more documenation and added existing_token_id param
This commit is contained in:
@@ -26,6 +26,10 @@ description:
|
|||||||
tower_* modules as the parameter tower_oauthtoken. See examples for usage.
|
tower_* modules as the parameter tower_oauthtoken. See examples for usage.
|
||||||
- Because of the sensitive nature of tokens, the created token value is only available once
|
- Because of the sensitive nature of tokens, the created token value is only available once
|
||||||
through the Ansible fact. (See RETURN for details)
|
through the Ansible fact. (See RETURN for details)
|
||||||
|
- Due to the nature of tokens in Tower this module is not idempotent. A second will
|
||||||
|
with the same parameters will create a new token.
|
||||||
|
- If you are creating a temporary token for use with modules you should delete the token
|
||||||
|
when you are done with it. See the example for how to do it.
|
||||||
options:
|
options:
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
@@ -46,8 +50,11 @@ options:
|
|||||||
default: 'write'
|
default: 'write'
|
||||||
choices: ["read", "write"]
|
choices: ["read", "write"]
|
||||||
existing_token:
|
existing_token:
|
||||||
description: An existing token (for use with state absent)
|
description: The data structure produced from tower_token in create mode to be used with state absent.
|
||||||
type: dict
|
type: dict
|
||||||
|
existing_token_id:
|
||||||
|
description: A token ID (number) which can be used to delete an arbitrary token with state absent.
|
||||||
|
type: str
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- Desired state of the resource.
|
- Desired state of the resource.
|
||||||
@@ -89,6 +96,11 @@ EXAMPLES = '''
|
|||||||
existing_token: "{{ tower_token }}"
|
existing_token: "{{ tower_token }}"
|
||||||
state: absent
|
state: absent
|
||||||
when: tower_token is defined
|
when: tower_token is defined
|
||||||
|
|
||||||
|
- name: Delete a token by its id
|
||||||
|
tower_toekn:
|
||||||
|
existing_token_id: 4
|
||||||
|
state: absent
|
||||||
'''
|
'''
|
||||||
|
|
||||||
RETURN = '''
|
RETURN = '''
|
||||||
@@ -99,6 +111,9 @@ tower_token:
|
|||||||
token:
|
token:
|
||||||
description: The token that was generated. This token can never be accessed again, make sure this value is noted before it is lost.
|
description: The token that was generated. This token can never be accessed again, make sure this value is noted before it is lost.
|
||||||
type: str
|
type: str
|
||||||
|
id:
|
||||||
|
description: The numeric ID of the token created
|
||||||
|
type: str
|
||||||
returned: on successful create
|
returned: on successful create
|
||||||
'''
|
'''
|
||||||
|
|
||||||
@@ -123,6 +138,7 @@ def main():
|
|||||||
application=dict(),
|
application=dict(),
|
||||||
scope=dict(choices=['read', 'write'], default='write'),
|
scope=dict(choices=['read', 'write'], default='write'),
|
||||||
existing_token=dict(type='dict'),
|
existing_token=dict(type='dict'),
|
||||||
|
existing_token_id=dict(),
|
||||||
state=dict(choices=['present', 'absent'], default='present'),
|
state=dict(choices=['present', 'absent'], default='present'),
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -134,9 +150,19 @@ def main():
|
|||||||
application = module.params.get('application')
|
application = module.params.get('application')
|
||||||
scope = module.params.get('scope')
|
scope = module.params.get('scope')
|
||||||
existing_token = module.params.get('existing_token')
|
existing_token = module.params.get('existing_token')
|
||||||
|
existing_token_id = module.params.get('existing_token_id')
|
||||||
state = module.params.get('state')
|
state = module.params.get('state')
|
||||||
|
|
||||||
if state == 'absent':
|
if state == 'absent':
|
||||||
|
if not existing_token:
|
||||||
|
if not existing_token_id:
|
||||||
|
module.fail_json(msg='When deleting a token you specify either the parameter existing_token or existing_token_id')
|
||||||
|
existing_token = module.get_one('tokens', **{
|
||||||
|
'data': {
|
||||||
|
'id': existing_token_id,
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
# If the state was absent we can let the module delete it if needed, the module will handle exiting from this
|
# If the state was absent we can let the module delete it if needed, the module will handle exiting from this
|
||||||
module.delete_if_needed(existing_token)
|
module.delete_if_needed(existing_token)
|
||||||
|
|
||||||
|
|||||||
@@ -27,6 +27,17 @@
|
|||||||
- results is failed
|
- results is failed
|
||||||
- '"The provided tower_oauthtoken type was not valid (list). Valid options are str or dict." == results.msg'
|
- '"The provided tower_oauthtoken type was not valid (list). Valid options are str or dict." == results.msg'
|
||||||
|
|
||||||
|
- name: Try to delete a token with no existing_token or existing_token_id
|
||||||
|
tower_token:
|
||||||
|
state: absent
|
||||||
|
register: results
|
||||||
|
ignore_errors: True
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- results is failed
|
||||||
|
- '"When deleting a token you specify either the parameter existing_token or existing_token_id" == results.msg'
|
||||||
|
|
||||||
- block:
|
- block:
|
||||||
- name: Create a Token
|
- name: Create a Token
|
||||||
tower_token:
|
tower_token:
|
||||||
@@ -52,3 +63,33 @@
|
|||||||
tower_oauthtoken: "{{ tower_token }}"
|
tower_oauthtoken: "{{ tower_token }}"
|
||||||
state: absent
|
state: absent
|
||||||
when: tower_token is defined
|
when: tower_token is defined
|
||||||
|
register: results
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- results is changed or results is skipped
|
||||||
|
|
||||||
|
- block:
|
||||||
|
- name: Create a second token
|
||||||
|
tower_token:
|
||||||
|
description: '{{ token_description }}'
|
||||||
|
scope: "write"
|
||||||
|
state: present
|
||||||
|
register: results
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- results is changed
|
||||||
|
|
||||||
|
always:
|
||||||
|
- name: Delete the second Token with our own token
|
||||||
|
tower_token:
|
||||||
|
existing_token_id: "{{ tower_token['id'] }}"
|
||||||
|
tower_oauthtoken: "{{ tower_token }}"
|
||||||
|
state: absent
|
||||||
|
when: tower_token is defined
|
||||||
|
register: results
|
||||||
|
|
||||||
|
- assert:
|
||||||
|
that:
|
||||||
|
- results is changed or resuslts is skipped
|
||||||
|
|||||||
Reference in New Issue
Block a user