1st draft really documenting common return vals (#17351)

* 1st draft really documenting common return vals

* fixed typo
This commit is contained in:
Brian Coca 2016-09-01 12:21:07 -04:00 committed by GitHub
parent c8431e334b
commit d647b0118d

View file

@ -8,35 +8,68 @@ Common Return Values
Ansible modules normally return a data structure that can be registered into a variable, or seen directly when using Ansible modules normally return a data structure that can be registered into a variable, or seen directly when using
the `ansible` program as output. Here we document the values common to all modules, each module can optionally document the `ansible` program as output. Here we document the values common to all modules, each module can optionally document
its own unique returns. If these docs exist they will be visible through ansible-doc and https://docs.ansible.com. its own unique returns. If these docs exist they will be visible through ansible-doc and https://docs.ansible.com.
Some of these keys might be set by Ansible itself once it processes the module's return information.
.. _facts:
Facts
`````
Some modules return 'facts' to ansible (i.e setup), this is done through a 'ansible_facts' key and anything inside
will automatically be available for the current host directly as a variable and there is no need to
register this data.
.. _status: changed
```````
A boolean that indicates if the task had to effect changes or not.
Status failed
`````` ``````
A boolean that indicates if the task was failed or not.
Every module must return a status, saying if the module was successful, if anything changed or not. Ansible itself invocation
will return a status if it skips the module due to a user condition (when: ) or running in check mode when the module ``````````
does not support it. Information on how the module was invoked.
msg
```
A string with a generic message relayed to user.
.. _other: rc
``
Some modules execute command line utilities or are geared for executing commands directly (raw, shell, command, etc), this field contains 'return code' of these utilities.
Other common returns results
```````````````````` ```````
If this key exists, it indicates that a loop was present for the task and that it contains a list of the normal module 'result' per item.
It is common on failure or success to return a 'msg' that either explains the failure or makes a note about the execution. skipped
Some modules, specifically those that execute shell or commands directly, will return stdout and stderr, if ansible sees ```````
a stdout in the results it will append a stdout_lines which is just a list or the lines in stdout. A boolean that indicates if the task was skipped or not
stderr
``````
Some modules execute command line utilities or are geared for executing commands directly (raw, shell, command, etc), this field contains the error output of these utilities.
stderr_lines
````````````
When c(stderr) is returned we also always provide this field which is a list of strings, one item per line from the original.
stdout
``````
Some modules execute command line utilities or are geared for executing commands directly (raw, shell, command, etc), this field contains the normal output of these utilities.
stdout_lines
````````````
When c(stdout) is returned we also always provide this field which is a list of strings, one item per line from the original.
Internal use
============
These keys can be added by modules but will be removed from registered variables, they are 'consumed' by Ansible itself.
ansible_facts
`````````````
This key should contain a dictionary which will be appended to the facts assigned to the host. These will be directly accessible and don't require using a registered variable.
exception
`````````
This key can contain traceback information caused by an exception in a module, it will only be displayed on high verbosity (-vvv).
warnings
````````
This key contains a list of strings that will be presented to the user.
.. seealso:: .. seealso::