2025-09-18 12:49:10 +08:00
|
|
|
from collections.abc import Mapping
|
|
|
|
|
from enum import Enum
|
|
|
|
|
from typing import Any
|
|
|
|
|
|
|
|
|
|
from pydantic import BaseModel, Field
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DatasourceStreamEvent(Enum):
|
|
|
|
|
"""
|
|
|
|
|
Datasource Stream event
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
PROCESSING = "datasource_processing"
|
|
|
|
|
COMPLETED = "datasource_completed"
|
|
|
|
|
ERROR = "datasource_error"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BaseDatasourceEvent(BaseModel):
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DatasourceErrorEvent(BaseDatasourceEvent):
|
2025-10-11 10:08:29 +09:00
|
|
|
event: DatasourceStreamEvent = DatasourceStreamEvent.ERROR
|
2025-09-18 12:49:10 +08:00
|
|
|
error: str = Field(..., description="error message")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DatasourceCompletedEvent(BaseDatasourceEvent):
|
2025-10-11 10:08:29 +09:00
|
|
|
event: DatasourceStreamEvent = DatasourceStreamEvent.COMPLETED
|
2025-09-18 12:49:10 +08:00
|
|
|
data: Mapping[str, Any] | list = Field(..., description="result")
|
|
|
|
|
total: int | None = Field(default=0, description="total")
|
|
|
|
|
completed: int | None = Field(default=0, description="completed")
|
|
|
|
|
time_consuming: float | None = Field(default=0.0, description="time consuming")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DatasourceProcessingEvent(BaseDatasourceEvent):
|
2025-10-11 10:08:29 +09:00
|
|
|
event: DatasourceStreamEvent = DatasourceStreamEvent.PROCESSING
|
2025-09-18 12:49:10 +08:00
|
|
|
total: int | None = Field(..., description="total")
|
|
|
|
|
completed: int | None = Field(..., description="completed")
|