awx/docs/docsite/rst/userguide/notification_parameters_supported.rst
Don Naro dc81aa46d0
Create AWX docsite with RST content (#14328)
Co-authored-by: Thanhnguyet Vo <tvo@ansible.com>
Co-authored-by: TVo <thavo@redhat.com>
2023-09-01 09:24:03 -06:00

126 lines
8.0 KiB
ReStructuredText

.. _ir_notifications_reference:
Supported Attributes for Custom Notifications
==============================================
.. index::
pair: notification;attributes
pair: notification messages;custom
This section describes the list of supported job attributes and the proper syntax for constructing the message text for notifications. The supported job attributes are:
- ``allow_simultaneous`` - (boolean) indicates if multiple jobs can run simultaneously from the JT associated with this job
- ``awx_node`` - (string) the instance that managed the isolated execution environment
- ``created`` - (datetime) timestamp when this job was created
- ``custom_virtualenv`` - (string) custom virtual environment used to execute job
- ``description`` - (string) optional description of the job
- ``diff_mode`` - (boolean) if enabled, textual changes made to any templated files on the host are shown in the standard output
- ``elapsed`` - (decimal) elapsed time in seconds that the job ran
- ``execution_node`` - (string) node the job executed on
- ``failed`` - (boolean) true if job failed
- ``finished`` - (datetime) date and time the job finished execution
- ``force_handlers`` - (boolean) when handlers are forced, they will run when notified even if a task fails on that host (note that some conditions - e.g. unreachable hosts - can still prevent handlers from running)
- ``forks`` - (int) number of forks requested for job
- ``id`` - (int) database id for this job
- ``job_explanation`` - (string) status field to indicate the state of the job if it wasn't able to run and capture stdout
- ``job_slice_count`` - (integer) if run as part of a sliced job, the total number of slices (if 1, job is not part of a sliced job)
- ``job_slice_number`` - (integer) if run as part of a sliced job, the ID of the inventory slice operated on (if not part of a sliced job, attribute is not used)
- ``job_tags`` - (string) only tasks with specified tags will execute
- ``job_type`` - (choice) run, check, or scan
- ``launch_type`` - (choice) manual, relaunch, callback, scheduled, dependency, workflow, sync, or scm
- ``limit`` - (string) playbook execution limited to this set of hosts, if specified
- ``modified`` - (datetime) timestamp when this job was last modified
- ``name`` - (string) name of this job
- ``playbook`` - (string) playbook executed
- ``scm_revision`` - (string) scm revision from the project used for this job, if available
- ``skip_tags`` - (string) playbook execution skips over this set of tag(s), if specified
- ``start_at_task`` - (string) playbook execution begins at the task matching this name, if specified
- ``started`` - (datetime) date and time the job was queued for starting
- ``status`` - (choice) new, pending, waiting, running, successful, failed, error, canceled
- ``timeout`` - (int) amount of time (in seconds) to run before the task is canceled
- ``type`` - (choice) data type for this job
- ``url`` - (string) URL for this job
- ``use_fact_cache`` - (boolean) if enabled for job, AWX acts as an Ansible Fact Cache Plugin, persisting facts at the end of a playbook run to the database and caching facts for use by Ansible
- ``verbosity`` - (choice) 0 through 5 (corresponding to Normal through WinRM Debug)
- ``host_status_counts`` (count of hosts uniquely assigned to each status)
- ``skipped`` (integer)
- ``ok`` (integer)
- ``changed`` (integer)
- ``failures`` (integer)
- ``dark`` (integer)
- ``processed`` (integer)
- ``rescued`` (integer)
- ``ignored`` (integer)
- ``failed`` (boolean)
- ``summary_fields``:
- ``inventory``
- ``id`` - (integer) database ID for inventory
- ``name`` - (string) name of the inventory
- ``description`` - (string) optional description of the inventory
- ``has_active_failures`` - (boolean) (deprecated) flag indicating whether any hosts in this inventory have failed
- ``total_hosts`` - (deprecated) (int) total number of hosts in this inventory.
- ``hosts_with_active_failures`` - (deprecated) (int) number of hosts in this inventory with active failures
- ``total_groups`` - (deprecated) (int) total number of groups in this inventory
- ``groups_with_active_failures`` - (deprecated) (int) number of hosts in this inventory with active failures
- ``has_inventory_sources`` - (deprecated) (boolean) flag indicating whether this inventory has external inventory sources
- ``total_inventory_sources`` - (int) total number of external inventory sources configured within this inventory
- ``inventory_sources_with_failures`` - (int) number of external inventory sources in this inventory with failures
- ``organization_id`` - (id) organization containing this inventory
- ``kind`` - (choice) (empty string) (indicating hosts have direct link with inventory) or 'smart'
- ``project``
- ``id`` - (int) database ID for project
- ``name`` - (string) name of the project
- ``description`` - (string) optional description of the project
- ``status`` - (choices) one of new, pending, waiting, running, successful, failed, error, canceled, never updated, ok, or missing
- ``scm_type (choice)`` - one of (empty string), git, hg, svn, insights
- ``job_template``
- ``id`` - (int) database ID for job template
- ``name`` - (string) name of job template
- ``description`` - (string) optional description for the job template
- ``unified_job_template``
- ``id`` - (int) database ID for unified job template
- ``name`` - (string) name of unified job template
- ``description`` - (string) optional description for the unified job template
- ``unified_job_type`` - (choice) unified job type (job, workflow_job, project_update, etc.)
- ``instance_group``
- ``id`` - (int) database ID for instance group
- ``name`` - (string) name of instance group
- ``created_by``
- ``id`` - (int) database ID of user that launched the operation
- ``username`` - (string) username that launched the operation
- ``first_name`` - (string) first name
- ``last_name`` - (string) last name
- ``labels``
- ``count`` - (int) number of labels
- ``results`` - list of dictionaries representing labels (e.g. {"id": 5, "name": "database jobs"})
Information about a job can be referenced in a custom notification message using grouped curly braces ``{{ }}``. Specific job attributes are accessed using dotted notation, for example ``{{ job.summary_fields.inventory.name }}``. Any characters used in front or around the braces, or plain text, can be added for clarification, such as '#' for job ID and single-quotes to denote some descriptor. Custom messages can include a number of variables throughout the message::
{{ job_friendly_name }} {{ job.id }} ran on {{ job.execution_node }} in {{ job.elapsed }} seconds.
In addition to the job attributes, there are some other variables that can be added to the template:
- ``approval_node_name`` - (string) the approval node name
- ``approval_status`` - (choice) one of approved, denied, and timed_out
- ``url`` - (string) URL of the job for which the notification is emitted (this applies to start, success, fail, and approval notifications)
- ``workflow_url`` - (string) URL to the relevant approval node. This allows the notification recipient to go to the relevant workflow job page to see what's going on (i.e., ``This node can be viewed at: {{ workflow_url }}``). In cases of approval-related notifications, both ``url`` and ``workflow_url`` are the same.
- ``job_friendly_name`` - (string) the friendly name of the job
- ``job_metadata`` - (string) job metadata as a JSON string, for example::
{'url': 'https://awxhost/$/jobs/playbook/13',
'traceback': '',
'status': 'running',
'started': '2019-08-07T21:46:38.362630+00:00',
'project': 'Stub project',
'playbook': 'ping.yml',
'name': 'Stub Job Template',
'limit': '',
'inventory': 'Stub Inventory',
'id': 42,
'hosts': {},
'friendly_name': 'Job',
'finished': False,
'credential': 'Stub credential',
'created_by': 'admin'}