| from __future__ import annotations |
|
|
| import httpx |
| from typing import Literal |
|
|
|
|
| class APIStatusError(Exception): |
| """Raised when an API response has a status code of 4xx or 5xx.""" |
|
|
| response: httpx.Response |
| status_code: int |
| request_id: str | None |
|
|
| def __init__( |
| self, message: str, *, response: httpx.Response, body: object | None |
| ) -> None: |
| super().__init__(message, response.request, body=body) |
| self.response = response |
| self.status_code = response.status_code |
| self.request_id = response.headers.get("x-request-id") |
|
|
|
|
| class APIConnectionError(Exception): |
| def __init__( |
| self, *, message: str = "Connection error.", request: httpx.Request |
| ) -> None: |
| super().__init__(message, request, body=None) |
|
|
|
|
| class BadRequestError(APIStatusError): |
| status_code: Literal[400] = 400 |
|
|
|
|
| class AuthenticationError(APIStatusError): |
| status_code: Literal[401] = 401 |
|
|
|
|
| class PermissionDeniedError(APIStatusError): |
| status_code: Literal[403] = 403 |
|
|
|
|
| class NotFoundError(APIStatusError): |
| status_code: Literal[404] = 404 |
|
|
|
|
| class ConflictError(APIStatusError): |
| status_code: Literal[409] = 409 |
|
|
|
|
| class UnprocessableEntityError(APIStatusError): |
| status_code: Literal[422] = 422 |
|
|
|
|
| class RateLimitError(APIStatusError): |
| status_code: Literal[429] = 429 |
|
|
|
|
| class APITimeoutError(APIConnectionError): |
| def __init__(self, request: httpx.Request) -> None: |
| super().__init__(message="Request timed out.", request=request) |
|
|
|
|
| class StorageNotInitializedError(RuntimeError): |
| """Raised when storage operations are attempted before initialization.""" |
|
|
| def __init__(self, storage_type: str = "Storage"): |
| super().__init__( |
| f"{storage_type} not initialized. Please ensure proper initialization:\n" |
| f"\n" |
| f" rag = LightRAG(...)\n" |
| f" await rag.initialize_storages() # Required\n" |
| f" \n" |
| f" from lightrag.kg.shared_storage import initialize_pipeline_status\n" |
| f" await initialize_pipeline_status() # Required for pipeline operations\n" |
| f"\n" |
| f"See: https://github.com/HKUDS/LightRAG#important-initialization-requirements" |
| ) |
|
|
|
|
| class PipelineNotInitializedError(KeyError): |
| """Raised when pipeline status is accessed before initialization.""" |
|
|
| def __init__(self, namespace: str = ""): |
| msg = ( |
| f"Pipeline namespace '{namespace}' not found. " |
| f"This usually means pipeline status was not initialized.\n" |
| f"\n" |
| f"Please call 'await initialize_pipeline_status()' after initializing storages:\n" |
| f"\n" |
| f" from lightrag.kg.shared_storage import initialize_pipeline_status\n" |
| f" await initialize_pipeline_status()\n" |
| f"\n" |
| f"Full initialization sequence:\n" |
| f" rag = LightRAG(...)\n" |
| f" await rag.initialize_storages()\n" |
| f" await initialize_pipeline_status()" |
| ) |
| super().__init__(msg) |
|
|