morphik-core/core/database/base_database.py

90 lines
2.2 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."""
@abstractmethod
async def store_document(self, document: Document) -> bool:
"""
Store document metadata.
Returns: Success status
"""
pass
@abstractmethod
async def get_document(self, document_id: str, auth: AuthContext) -> Optional[Document]:
"""
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
) -> 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
) -> bool:
"""
Update document metadata if user has access.
Returns: Success status
"""
pass
@abstractmethod
async def delete_document(
self,
document_id: str,
auth: AuthContext
) -> bool:
"""
Delete document metadata if user has admin access.
Returns: Success status
"""
pass
@abstractmethod
async def find_documents(
self,
auth: AuthContext,
filters: Optional[Dict[str, Any]] = None
) -> List[str]:
"""
Find document IDs matching filters that user has access to.
Returns: List of document IDs
"""
pass
@abstractmethod
async def check_access(
self,
document_id: str,
auth: AuthContext,
required_permission: str = "read"
) -> bool:
"""
Check if user has required permission for document.
Returns: True if user has required access, False otherwise
"""
pass