mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	[PR #9455/d887930e backport][stable-9] normalize docs in callback plugins (#9466)
normalize docs in callback plugins (#9455)
* normalize docs in callback plugins
Normalize doc blocks for plugins
* Apply suggestions from code review
Co-authored-by: Felix Fontein <felix@fontein.de>
---------
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit d887930e49)
Co-authored-by: Alexei Znamensky <103110+russoz@users.noreply.github.com>
	
	
This commit is contained in:
		
					parent
					
						
							
								015496fa9e
							
						
					
				
			
			
				commit
				
					
						6f3cfd3385
					
				
			
		
					 26 changed files with 1478 additions and 1489 deletions
				
			
		|  | @ -6,119 +6,120 @@ | |||
| from __future__ import (absolute_import, division, print_function) | ||||
| __metaclass__ = type | ||||
| 
 | ||||
| DOCUMENTATION = ''' | ||||
|     author: Victor Martinez (@v1v)  <VictorMartinezRubio@gmail.com> | ||||
|     name: opentelemetry | ||||
|     type: notification | ||||
|     short_description: Create distributed traces with OpenTelemetry | ||||
|     version_added: 3.7.0 | ||||
| DOCUMENTATION = r""" | ||||
| author: Victor Martinez (@v1v)  <VictorMartinezRubio@gmail.com> | ||||
| name: opentelemetry | ||||
| type: notification | ||||
| short_description: Create distributed traces with OpenTelemetry | ||||
| version_added: 3.7.0 | ||||
| description: | ||||
|   - This callback creates distributed traces for each Ansible task with OpenTelemetry. | ||||
|   - You can configure the OpenTelemetry exporter and SDK with environment variables. | ||||
|   - See U(https://opentelemetry-python.readthedocs.io/en/latest/exporter/otlp/otlp.html). | ||||
|   - See | ||||
|     U(https://opentelemetry-python.readthedocs.io/en/latest/sdk/environment_variables.html#opentelemetry-sdk-environment-variables). | ||||
| options: | ||||
|   hide_task_arguments: | ||||
|     default: false | ||||
|     type: bool | ||||
|     description: | ||||
|       - This callback creates distributed traces for each Ansible task with OpenTelemetry. | ||||
|       - You can configure the OpenTelemetry exporter and SDK with environment variables. | ||||
|       - See U(https://opentelemetry-python.readthedocs.io/en/latest/exporter/otlp/otlp.html). | ||||
|       - See U(https://opentelemetry-python.readthedocs.io/en/latest/sdk/environment_variables.html#opentelemetry-sdk-environment-variables). | ||||
|     options: | ||||
|       hide_task_arguments: | ||||
|         default: false | ||||
|         type: bool | ||||
|         description: | ||||
|           - Hide the arguments for a task. | ||||
|         env: | ||||
|           - name: ANSIBLE_OPENTELEMETRY_HIDE_TASK_ARGUMENTS | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: hide_task_arguments | ||||
|             version_added: 5.3.0 | ||||
|       enable_from_environment: | ||||
|         type: str | ||||
|         description: | ||||
|           - Whether to enable this callback only if the given environment variable exists and it is set to V(true). | ||||
|           - This is handy when you use Configuration as Code and want to send distributed traces | ||||
|             if running in the CI rather when running Ansible locally. | ||||
|           - For such, it evaluates the given O(enable_from_environment) value as environment variable | ||||
|             and if set to true this plugin will be enabled. | ||||
|         env: | ||||
|           - name: ANSIBLE_OPENTELEMETRY_ENABLE_FROM_ENVIRONMENT | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: enable_from_environment | ||||
|             version_added: 5.3.0 | ||||
|         version_added: 3.8.0 | ||||
|       otel_service_name: | ||||
|         default: ansible | ||||
|         type: str | ||||
|         description: | ||||
|           - The service name resource attribute. | ||||
|         env: | ||||
|           - name: OTEL_SERVICE_NAME | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: otel_service_name | ||||
|             version_added: 5.3.0 | ||||
|       traceparent: | ||||
|         default: None | ||||
|         type: str | ||||
|         description: | ||||
|           - The L(W3C Trace Context header traceparent,https://www.w3.org/TR/trace-context-1/#traceparent-header). | ||||
|         env: | ||||
|           - name: TRACEPARENT | ||||
|       disable_logs: | ||||
|         default: false | ||||
|         type: bool | ||||
|         description: | ||||
|           - Disable sending logs. | ||||
|         env: | ||||
|           - name: ANSIBLE_OPENTELEMETRY_DISABLE_LOGS | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: disable_logs | ||||
|         version_added: 5.8.0 | ||||
|       disable_attributes_in_logs: | ||||
|         default: false | ||||
|         type: bool | ||||
|         description: | ||||
|           - Disable populating span attributes to the logs. | ||||
|         env: | ||||
|           - name: ANSIBLE_OPENTELEMETRY_DISABLE_ATTRIBUTES_IN_LOGS | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: disable_attributes_in_logs | ||||
|         version_added: 7.1.0 | ||||
|       store_spans_in_file: | ||||
|         type: str | ||||
|         description: | ||||
|           -  It stores the exported spans in the given file | ||||
|         env: | ||||
|           - name: ANSIBLE_OPENTELEMETRY_STORE_SPANS_IN_FILE | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: store_spans_in_file | ||||
|         version_added: 9.0.0 | ||||
|       otel_exporter_otlp_traces_protocol: | ||||
|         type: str | ||||
|         description: | ||||
|           - E(OTEL_EXPORTER_OTLP_TRACES_PROTOCOL) represents the the transport protocol for spans. | ||||
|           - See | ||||
|             U(https://opentelemetry-python.readthedocs.io/en/latest/sdk/environment_variables.html#envvar-OTEL_EXPORTER_OTLP_TRACES_PROTOCOL). | ||||
|         default: grpc | ||||
|         choices: | ||||
|           - grpc | ||||
|           - http/protobuf | ||||
|         env: | ||||
|           - name: OTEL_EXPORTER_OTLP_TRACES_PROTOCOL | ||||
|         ini: | ||||
|           - section: callback_opentelemetry | ||||
|             key: otel_exporter_otlp_traces_protocol | ||||
|         version_added: 9.0.0 | ||||
|     requirements: | ||||
|       - opentelemetry-api (Python library) | ||||
|       - opentelemetry-exporter-otlp (Python library) | ||||
|       - opentelemetry-sdk (Python library) | ||||
| ''' | ||||
|       - Hide the arguments for a task. | ||||
|     env: | ||||
|       - name: ANSIBLE_OPENTELEMETRY_HIDE_TASK_ARGUMENTS | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: hide_task_arguments | ||||
|         version_added: 5.3.0 | ||||
|   enable_from_environment: | ||||
|     type: str | ||||
|     description: | ||||
|       - Whether to enable this callback only if the given environment variable exists and it is set to V(true). | ||||
|       - This is handy when you use Configuration as Code and want to send distributed traces if running in the CI rather when | ||||
|         running Ansible locally. | ||||
|       - For such, it evaluates the given O(enable_from_environment) value as environment variable and if set to true this | ||||
|         plugin will be enabled. | ||||
|     env: | ||||
|       - name: ANSIBLE_OPENTELEMETRY_ENABLE_FROM_ENVIRONMENT | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: enable_from_environment | ||||
|         version_added: 5.3.0 | ||||
|     version_added: 3.8.0 | ||||
|   otel_service_name: | ||||
|     default: ansible | ||||
|     type: str | ||||
|     description: | ||||
|       - The service name resource attribute. | ||||
|     env: | ||||
|       - name: OTEL_SERVICE_NAME | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: otel_service_name | ||||
|         version_added: 5.3.0 | ||||
|   traceparent: | ||||
|     default: None | ||||
|     type: str | ||||
|     description: | ||||
|       - The L(W3C Trace Context header traceparent,https://www.w3.org/TR/trace-context-1/#traceparent-header). | ||||
|     env: | ||||
|       - name: TRACEPARENT | ||||
|   disable_logs: | ||||
|     default: false | ||||
|     type: bool | ||||
|     description: | ||||
|       - Disable sending logs. | ||||
|     env: | ||||
|       - name: ANSIBLE_OPENTELEMETRY_DISABLE_LOGS | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: disable_logs | ||||
|     version_added: 5.8.0 | ||||
|   disable_attributes_in_logs: | ||||
|     default: false | ||||
|     type: bool | ||||
|     description: | ||||
|       - Disable populating span attributes to the logs. | ||||
|     env: | ||||
|       - name: ANSIBLE_OPENTELEMETRY_DISABLE_ATTRIBUTES_IN_LOGS | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: disable_attributes_in_logs | ||||
|     version_added: 7.1.0 | ||||
|   store_spans_in_file: | ||||
|     type: str | ||||
|     description: | ||||
|       - It stores the exported spans in the given file. | ||||
|     env: | ||||
|       - name: ANSIBLE_OPENTELEMETRY_STORE_SPANS_IN_FILE | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: store_spans_in_file | ||||
|     version_added: 9.0.0 | ||||
|   otel_exporter_otlp_traces_protocol: | ||||
|     type: str | ||||
|     description: | ||||
|       - E(OTEL_EXPORTER_OTLP_TRACES_PROTOCOL) represents the the transport protocol for spans. | ||||
|       - See | ||||
|         U(https://opentelemetry-python.readthedocs.io/en/latest/sdk/environment_variables.html#envvar-OTEL_EXPORTER_OTLP_TRACES_PROTOCOL). | ||||
|     default: grpc | ||||
|     choices: | ||||
|       - grpc | ||||
|       - http/protobuf | ||||
|     env: | ||||
|       - name: OTEL_EXPORTER_OTLP_TRACES_PROTOCOL | ||||
|     ini: | ||||
|       - section: callback_opentelemetry | ||||
|         key: otel_exporter_otlp_traces_protocol | ||||
|     version_added: 9.0.0 | ||||
| requirements: | ||||
|   - opentelemetry-api (Python library) | ||||
|   - opentelemetry-exporter-otlp (Python library) | ||||
|   - opentelemetry-sdk (Python library) | ||||
| """ | ||||
| 
 | ||||
| 
 | ||||
| EXAMPLES = ''' | ||||
| examples: | | ||||
| EXAMPLES = r""" | ||||
| examples: |- | ||||
|   Enable the plugin in ansible.cfg: | ||||
|     [defaults] | ||||
|     callbacks_enabled = community.general.opentelemetry | ||||
|  | @ -130,7 +131,7 @@ examples: | | |||
|     export OTEL_EXPORTER_OTLP_HEADERS="authorization=Bearer your_otel_token" | ||||
|     export OTEL_SERVICE_NAME=your_service_name | ||||
|     export ANSIBLE_OPENTELEMETRY_ENABLED=true | ||||
| ''' | ||||
| """ | ||||
| 
 | ||||
| import getpass | ||||
| import json | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue