mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-11-04 04:29:13 +00:00 
			
		
		
		
	* Paginate last dag logs * clean logic * Prep pagination * Prep pagination * Format * Update docker/local-metadata/docker-compose.yml Co-authored-by: Nahuel <nahuel@getcollate.io> * UI : Add pagination support for airflow logs * Addressing review comments Co-authored-by: Nahuel <nahuel@getcollate.io> Co-authored-by: Sachin Chaurasiya <sachinchaurasiyachotey87@gmail.com>
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#  Copyright 2021 Collate
 | 
						|
#  Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
#  you may not use this file except in compliance with the License.
 | 
						|
#  You may obtain a copy of the License at
 | 
						|
#  http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
#  Unless required by applicable law or agreed to in writing, software
 | 
						|
#  distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
#  See the License for the specific language governing permissions and
 | 
						|
#  limitations under the License.
 | 
						|
"""
 | 
						|
Return the last DagRun logs for each task
 | 
						|
"""
 | 
						|
import traceback
 | 
						|
from typing import Callable
 | 
						|
 | 
						|
from flask import Blueprint, Response, request
 | 
						|
from openmetadata_managed_apis.api.response import ApiResponse
 | 
						|
from openmetadata_managed_apis.api.utils import get_arg_dag_id, get_request_arg
 | 
						|
from openmetadata_managed_apis.operations.last_dag_logs import last_dag_logs
 | 
						|
from openmetadata_managed_apis.utils.logger import routes_logger
 | 
						|
 | 
						|
logger = routes_logger()
 | 
						|
 | 
						|
 | 
						|
def get_fn(blueprint: Blueprint) -> Callable:
 | 
						|
    """
 | 
						|
    Return the function loaded to a route
 | 
						|
    :param blueprint: Flask Blueprint to assign route to
 | 
						|
    :return: routed function
 | 
						|
    """
 | 
						|
 | 
						|
    # Lazy import the requirements
 | 
						|
    # pylint: disable=import-outside-toplevel
 | 
						|
    from airflow.api_connexion import security
 | 
						|
    from airflow.security import permissions
 | 
						|
    from airflow.www.app import csrf
 | 
						|
 | 
						|
    @blueprint.route("/last_dag_logs", methods=["GET"])
 | 
						|
    @csrf.exempt
 | 
						|
    @security.requires_access([(permissions.ACTION_CAN_READ, permissions.RESOURCE_DAG)])
 | 
						|
    def last_logs() -> Response:
 | 
						|
        """
 | 
						|
        Retrieve all logs from the task instances of a last DAG run
 | 
						|
        """
 | 
						|
 | 
						|
        dag_id = get_arg_dag_id()
 | 
						|
        task_id = get_request_arg(request, "task_id")
 | 
						|
        after = get_request_arg(request, "after", raise_missing=False)
 | 
						|
 | 
						|
        try:
 | 
						|
            return last_dag_logs(dag_id=dag_id, task_id=task_id, after=after)
 | 
						|
 | 
						|
        except Exception as exc:
 | 
						|
            logger.debug(traceback.format_exc())
 | 
						|
            logger.error(f"Failed to get last run logs for [{dag_id}]: {exc}")
 | 
						|
            return ApiResponse.error(
 | 
						|
                status=ApiResponse.STATUS_SERVER_ERROR,
 | 
						|
                error=f"Failed to get last run logs for [{dag_id}] due to [{exc}] ",
 | 
						|
            )
 | 
						|
 | 
						|
    return last_logs
 |