morphik-core/core/database/base_database.py

75 lines
2.1 KiB
Python
Raw Normal View History

2024-11-22 18:56:22 -05:00
from abc import ABC, abstractmethod
from typing import List, Optional, Dict, Any
from ..models.documents import Document
from ..models.auth import AuthContext
class BaseDatabase(ABC):
"""Base interface for document metadata storage."""
2024-11-22 18:56:22 -05:00
@abstractmethod
async def store_document(self, document: Document) -> bool:
"""
Store document metadata.
Returns: Success status
"""
pass
@abstractmethod
2024-12-29 12:48:41 +05:30
async def get_document(self, document_id: str, auth: AuthContext) -> Optional[Document]:
2024-11-22 18:56:22 -05:00
"""
Retrieve document metadata by ID if user has access.
Returns: Document if found and accessible, None otherwise
"""
pass
@abstractmethod
async def get_documents(
self,
auth: AuthContext,
skip: int = 0,
limit: int = 100,
filters: Optional[Dict[str, Any]] = None,
2024-11-22 18:56:22 -05:00
) -> List[Document]:
"""
List documents the user has access to.
Supports pagination and filtering.
"""
pass
@abstractmethod
async def update_document(
self, document_id: str, updates: Dict[str, Any], auth: AuthContext
2024-11-22 18:56:22 -05:00
) -> bool:
"""
Update document metadata if user has access.
Returns: Success status
"""
pass
@abstractmethod
async def delete_document(self, document_id: str, auth: AuthContext) -> bool:
2024-11-22 18:56:22 -05:00
"""
Delete document metadata if user has admin access.
Returns: Success status
"""
pass
2024-11-22 18:56:22 -05:00
@abstractmethod
async def find_authorized_and_filtered_documents(
self, auth: AuthContext, filters: Optional[Dict[str, Any]] = None
2024-11-22 18:56:22 -05:00
) -> List[str]:
"""Find document IDs matching filters that user has access to."""
2024-11-22 18:56:22 -05:00
pass
@abstractmethod
async def check_access(
self, document_id: str, auth: AuthContext, required_permission: str = "read"
2024-11-22 18:56:22 -05:00
) -> bool:
"""
Check if user has required permission for document.
Returns: True if user has required access, False otherwise
"""
pass