dstandish commented on code in PR #44624: URL: https://github.com/apache/airflow/pull/44624#discussion_r1876515016
########## airflow/api_fastapi/core_api/routes/ui/backfills.py: ########## @@ -0,0 +1,66 @@ +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you 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. +from __future__ import annotations + +from typing import Annotated + +from fastapi import Depends, status +from sqlalchemy import select +from sqlalchemy.ext.asyncio import AsyncSession + +from airflow.api_fastapi.common.db.common import get_async_session, paginated_select_async +from airflow.api_fastapi.common.parameters import QueryLimit, QueryOffset, SortParam +from airflow.api_fastapi.common.router import AirflowRouter +from airflow.api_fastapi.core_api.datamodels.backfills import BackfillCollectionResponse +from airflow.api_fastapi.core_api.openapi.exceptions import ( + create_openapi_http_exception_doc, +) +from airflow.models.backfill import Backfill + +backfills_router = AirflowRouter(tags=["Backfill"], prefix="/backfills") + + +@backfills_router.get( + path="", + responses=create_openapi_http_exception_doc([status.HTTP_404_NOT_FOUND]), +) +async def list_backfills( + limit: QueryLimit, + offset: QueryOffset, + order_by: Annotated[ + SortParam, + Depends(SortParam(["id"], Backfill).dynamic_depends()), + ], + session: Annotated[AsyncSession, Depends(get_async_session)], + dag_id: str | None = None, +) -> BackfillCollectionResponse: Review Comment: my feelings on it are not super strong. the thing i hesitate on a bit is like there's no status field for backfills. so "active" is just define by not completed. and i hesitate to add "active" as a filter on the public api. anyway, having something in private makes it easier to add or make changes there, and avoids us falling into the trap of, increasing the public interface every time the webserver needs something. i like the idea of thinking through the interfaces independently. but that's just me so, i don't stand in the way if the decision is to do something public. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: [email protected] For queries about this service, please contact Infrastructure at: [email protected]
