All URIs are relative to /api/v1
Method | HTTP request | Description |
---|---|---|
get_xcom_entries | GET /dags/{dag_id}/dagRuns/{dag_run_id}/taskInstances/{task_id}/xcomEntries | List XCom entries |
get_xcom_entry | GET /dags/{dag_id}/dagRuns/{dag_run_id}/taskInstances/{task_id}/xcomEntries/{xcom_key} | Get an XCom entry |
XComCollection get_xcom_entries(dag_id, dag_run_id, task_id)
List XCom entries
This endpoint allows specifying ~
as the dag_id, dag_run_id, task_id to retrieve XCOM entries for for all DAGs, DAG runs and task instances. XCom values won't be returned as they can be large. Use this endpoint to get a list of XCom entries and then fetch individual entry to get value.
- Basic Authentication (Basic):
import time
import airflow_client.client
from airflow_client.client.api import x_com_api
from airflow_client.client.model.error import Error
from airflow_client.client.model.x_com_collection import XComCollection
from pprint import pprint
# Defining the host is optional and defaults to /api/v1
# See configuration.py for a list of all supported configuration parameters.
configuration = airflow_client.client.Configuration(
host = "/api/v1"
)
# The client must configure the authentication and authorization parameters
# in accordance with the API server security policy.
# Examples for each auth method are provided below, use the example that
# satisfies your auth use case.
# Configure HTTP basic authorization: Basic
configuration = airflow_client.client.Configuration(
username = 'YOUR_USERNAME',
password = 'YOUR_PASSWORD'
)
# Enter a context with an instance of the API client
with airflow_client.client.ApiClient(configuration) as api_client:
# Create an instance of the API class
api_instance = x_com_api.XComApi(api_client)
dag_id = "dag_id_example" # str | The DAG ID.
dag_run_id = "dag_run_id_example" # str | The DAG run ID.
task_id = "task_id_example" # str | The task ID.
map_index = 1 # int | Filter on map index for mapped task. (optional)
xcom_key = "xcom_key_example" # str | Only filter the XCom records which have the provided key. (optional)
limit = 100 # int | The numbers of items to return. (optional) if omitted the server will use the default value of 100
offset = 0 # int | The number of items to skip before starting to collect the result set. (optional)
# example passing only required values which don't have defaults set
try:
# List XCom entries
api_response = api_instance.get_xcom_entries(dag_id, dag_run_id, task_id)
pprint(api_response)
except airflow_client.client.ApiException as e:
print("Exception when calling XComApi->get_xcom_entries: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# List XCom entries
api_response = api_instance.get_xcom_entries(dag_id, dag_run_id, task_id, map_index=map_index, xcom_key=xcom_key, limit=limit, offset=offset)
pprint(api_response)
except airflow_client.client.ApiException as e:
print("Exception when calling XComApi->get_xcom_entries: %s\n" % e)
Name | Type | Description | Notes |
---|---|---|---|
dag_id | str | The DAG ID. | |
dag_run_id | str | The DAG run ID. | |
task_id | str | The task ID. | |
map_index | int | Filter on map index for mapped task. | [optional] |
xcom_key | str | Only filter the XCom records which have the provided key. | [optional] |
limit | int | The numbers of items to return. | [optional] if omitted the server will use the default value of 100 |
offset | int | The number of items to skip before starting to collect the result set. | [optional] |
- Content-Type: Not defined
- Accept: application/json
Status code | Description | Response headers |
---|---|---|
200 | Success. | - |
401 | Request not authenticated due to missing, invalid, authentication info. | - |
403 | Client does not have sufficient permission. | - |
[Back to top] [Back to API list] [Back to Model list] [Back to README]
XCom get_xcom_entry(dag_id, dag_run_id, task_id, xcom_key)
Get an XCom entry
- Basic Authentication (Basic):
import time
import airflow_client.client
from airflow_client.client.api import x_com_api
from airflow_client.client.model.x_com import XCom
from airflow_client.client.model.error import Error
from pprint import pprint
# Defining the host is optional and defaults to /api/v1
# See configuration.py for a list of all supported configuration parameters.
configuration = airflow_client.client.Configuration(
host = "/api/v1"
)
# The client must configure the authentication and authorization parameters
# in accordance with the API server security policy.
# Examples for each auth method are provided below, use the example that
# satisfies your auth use case.
# Configure HTTP basic authorization: Basic
configuration = airflow_client.client.Configuration(
username = 'YOUR_USERNAME',
password = 'YOUR_PASSWORD'
)
# Enter a context with an instance of the API client
with airflow_client.client.ApiClient(configuration) as api_client:
# Create an instance of the API class
api_instance = x_com_api.XComApi(api_client)
dag_id = "dag_id_example" # str | The DAG ID.
dag_run_id = "dag_run_id_example" # str | The DAG run ID.
task_id = "task_id_example" # str | The task ID.
xcom_key = "xcom_key_example" # str | The XCom key.
map_index = 1 # int | Filter on map index for mapped task. (optional)
deserialize = False # bool | Whether to deserialize an XCom value when using a custom XCom backend. The XCom API endpoint calls `orm_deserialize_value` by default since an XCom may contain value that is potentially expensive to deserialize in the web server. Setting this to true overrides the consideration, and calls `deserialize_value` instead. This parameter is not meaningful when using the default XCom backend. *New in version 2.4.0* (optional) if omitted the server will use the default value of False
stringify = True # bool | Whether to convert the XCom value to be a string. XCom values can be of Any data type. If set to true (default) the Any value will be returned as string, e.g. a Python representation of a dict. If set to false it will return the raw data as dict, list, string or whatever was stored. *New in version 2.10.0* (optional) if omitted the server will use the default value of True
# example passing only required values which don't have defaults set
try:
# Get an XCom entry
api_response = api_instance.get_xcom_entry(dag_id, dag_run_id, task_id, xcom_key)
pprint(api_response)
except airflow_client.client.ApiException as e:
print("Exception when calling XComApi->get_xcom_entry: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Get an XCom entry
api_response = api_instance.get_xcom_entry(dag_id, dag_run_id, task_id, xcom_key, map_index=map_index, deserialize=deserialize, stringify=stringify)
pprint(api_response)
except airflow_client.client.ApiException as e:
print("Exception when calling XComApi->get_xcom_entry: %s\n" % e)
Name | Type | Description | Notes |
---|---|---|---|
dag_id | str | The DAG ID. | |
dag_run_id | str | The DAG run ID. | |
task_id | str | The task ID. | |
xcom_key | str | The XCom key. | |
map_index | int | Filter on map index for mapped task. | [optional] |
deserialize | bool | Whether to deserialize an XCom value when using a custom XCom backend. The XCom API endpoint calls `orm_deserialize_value` by default since an XCom may contain value that is potentially expensive to deserialize in the web server. Setting this to true overrides the consideration, and calls `deserialize_value` instead. This parameter is not meaningful when using the default XCom backend. New in version 2.4.0 | [optional] if omitted the server will use the default value of False |
stringify | bool | Whether to convert the XCom value to be a string. XCom values can be of Any data type. If set to true (default) the Any value will be returned as string, e.g. a Python representation of a dict. If set to false it will return the raw data as dict, list, string or whatever was stored. New in version 2.10.0 | [optional] if omitted the server will use the default value of True |
- Content-Type: Not defined
- Accept: application/json
Status code | Description | Response headers |
---|---|---|
200 | Success. | - |
401 | Request not authenticated due to missing, invalid, authentication info. | - |
403 | Client does not have sufficient permission. | - |
404 | A specified resource is not found. | - |
[Back to top] [Back to API list] [Back to Model list] [Back to README]