reparse_dag_file
Triggers re-parsing of a DAG file in Apache Airflow using its file token, ensuring updated configurations are applied without manual intervention.
Instructions
Request re-parsing of a DAG file
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| file_token | Yes |
Implementation Reference
- src/airflow/dag.py:272-276 (handler)The main handler function that executes the reparse_dag_file tool by calling the Airflow DAG API's reparse_dag_file method with the provided file_token and returning the response as text content.async def reparse_dag_file( file_token: str, ) -> List[Union[types.TextContent, types.ImageContent, types.EmbeddedResource]]: response = dag_api.reparse_dag_file(file_token=file_token) return [types.TextContent(type="text", text=str(response.to_dict()))]
- src/airflow/dag.py:15-33 (registration)The get_all_functions() in dag.py defines the list of tools for DAG API, including the registration tuple for reparse_dag_file.def get_all_functions() -> list[tuple[Callable, str, str, bool]]: """Return list of (function, name, description, is_read_only) tuples for registration.""" return [ (get_dags, "fetch_dags", "Fetch all DAGs", True), (get_dag, "get_dag", "Get a DAG by ID", True), (get_dag_details, "get_dag_details", "Get a simplified representation of DAG", True), (get_dag_source, "get_dag_source", "Get a source code", True), (pause_dag, "pause_dag", "Pause a DAG by ID", False), (unpause_dag, "unpause_dag", "Unpause a DAG by ID", False), (get_dag_tasks, "get_dag_tasks", "Get tasks for DAG", True), (get_task, "get_task", "Get a task by ID", True), (get_tasks, "get_tasks", "Get tasks for DAG", True), (patch_dag, "patch_dag", "Update a DAG", False), (patch_dags, "patch_dags", "Update multiple DAGs", False), (delete_dag, "delete_dag", "Delete a DAG", False), (clear_task_instances, "clear_task_instances", "Clear a set of task instances", False), (set_task_instances_state, "set_task_instances_state", "Set a state of task instances", False), (reparse_dag_file, "reparse_dag_file", "Request re-parsing of a DAG file", False), ]
- src/main.py:83-97 (registration)The main registration loop in main.py that adds all tools from get_all_functions() of each module, including dag.py's reparse_dag_file, using app.add_tool.for api in apis: logging.debug(f"Adding API: {api}") get_function = APITYPE_TO_FUNCTIONS[APIType(api)] try: functions = get_function() except NotImplementedError: continue # Filter functions for read-only mode if requested if read_only: functions = filter_functions_for_read_only(functions) for func, name, description, *_ in functions: app.add_tool(Tool.from_function(func, name=name, description=description))