"""
Database schemas for knowledge_management_Document_Library_System

This module contains all database schema classes for the knowledge_management domain.
All classes are Pydantic BaseModel subclasses.

Generated by ClassDBAgent.
"""

import json
from datetime import datetime
from datetime import datetime, date
from pathlib import Path
from pydantic import Field
from pydantic import PrivateAttr, Field
from scale_env.data_model.thread_safe_base import ThreadSafeBase, with_instance_key
from scale_env.environment.db import DB, DictAccessMixin as BaseModel
from typing import Dict, List, Any, Optional
from typing import Dict, List, Any, Optional, Literal

@with_instance_key("document_id")
class Document(BaseModel, ThreadSafeBase["Document"]):
    document_id: str = Field(..., description="Unique identifier for the document")
    title: str = Field(..., description="Title of the document")
    content: str = Field(..., description="Main content of the document")
    author: str = Field(..., description="Author name of the document")
    category: Optional[str] = Field(default=None, description="Category of the document")
    folder_id: Optional[str] = Field(default=None, description="Identifier of the folder containing the document")
    is_archived: bool = Field(default=False, description="Indicates whether the document is archived")
    file_size: Optional[int] = Field(default=None, description="Size of the document in bytes")
    created_at: datetime = Field(..., description="Timestamp when the document was created")
    updated_at: datetime = Field(..., description="Timestamp when the document was last updated")
    archived_at: Optional[datetime] = Field(default=None, description="Timestamp when the document was archived")

@with_instance_key("document_id")
class DocumentTag(BaseModel, ThreadSafeBase["DocumentTag"]):      
    document_id: str = Field(default=..., description="Identifier of the document")
    tag: str = Field(default=..., description="Tag name for categorizing the document")

@with_instance_key("version_id")
class DocumentVersion(BaseModel, ThreadSafeBase["DocumentVersion"]):
    version_id: str = Field(..., description="Unique identifier for the version")
    document_id: str = Field(..., description="Identifier of the parent document")
    version_number: str = Field(..., description="Version number of the document")
    content: str = Field(..., description="Content of this version")
    version_note: Optional[str] = Field(None, description="Note describing changes in this version") # optional field
    created_at: datetime = Field(..., description="Timestamp when the version was created")

@with_instance_key("folder_id")
class Folder(BaseModel, ThreadSafeBase["Folder"]):
    folder_id: str = Field(..., description="Unique identifier for the folder")
    folder_name: str = Field(..., description="Name of the folder")
    parent_folder_id: Optional[str] = Field(default=None, description="Identifier of the parent folder")
    description: Optional[str] = Field(default=None, description="Description of the folder purpose")
    created_at: datetime = Field(..., description="Timestamp when the folder was created")

@with_instance_key("document_id")
class DocumentPermission(BaseModel, ThreadSafeBase["DocumentPermission"]):
    document_id: str = Field(..., description="Identifier of the document")
    user_id: str = Field(..., description="Identifier of the user")
    permission_level: Literal["read", "write", "admin"] = Field(..., description="Level of permission granted")
    updated_at: datetime = Field(..., description="Timestamp when permission was last updated")

@with_instance_key("comment_id")
class DocumentComment(BaseModel, ThreadSafeBase["DocumentComment"]):
    comment_id: str = Field(default=..., description="Unique identifier for the comment")
    document_id: str = Field(default=..., description="Identifier of the document")
    user_id: str = Field(default=..., description="Identifier of the user who added the comment")
    comment_text: str = Field(default=..., description="Text content of the comment")
    created_at: datetime = Field(default=..., description="Timestamp when the comment was created")

@with_instance_key("template_id")
class DocumentTemplate(BaseModel, ThreadSafeBase["DocumentTemplate"]):
    template_id: str = Field(..., description="Unique identifier for the template")
    template_name: str = Field(..., description="Name of the template")
    content_structure: str = Field(..., description="Structure or outline of the template content")
    category: Optional[str] = Field(None, description="Category of the template") # category is optional
    created_at: datetime = Field(..., description="Timestamp when the template was created")

@with_instance_key("document_id")
class DocumentLock(BaseModel, ThreadSafeBase["DocumentLock"]):
    document_id: str = Field(..., description="Identifier of the locked document")
    user_id: str = Field(..., description="Identifier of the user who locked the document")
    locked_at: datetime = Field(..., description="Timestamp when the document was locked")

@with_instance_key("link_id")
class DocumentLink(BaseModel, ThreadSafeBase["DocumentLink"]):
    link_id: str = Field(..., description="Unique identifier for the link")
    source_document_id: str = Field(..., description="Identifier of the source document")
    target_document_id: str = Field(..., description="Identifier of the target document")
    link_type: Literal["references", "related", "supersedes", "depends_on"] = Field(
        ..., description="Type of relationship between documents"
    )
    created_at: datetime = Field(..., description="Timestamp when the link was created")

@with_instance_key("attachment_id")
class DocumentAttachment(BaseModel, ThreadSafeBase["DocumentAttachment"]):
    attachment_id: str = Field(default=..., description="Unique identifier for the attachment")
    document_id: str = Field(default=..., description="Identifier of the parent document")
    file_path: str = Field(default=..., description="Path or URL to the attachment file")
    file_name: str = Field(default=..., description="Name of the attachment file")
    file_type: Optional[str] = Field(default=None, description="MIME type of the attachment")
    created_at: datetime = Field(default=..., description="Timestamp when the attachment was added")

class KnowledgeManagementDB(DB):
    """Database containing all knowledge_management_Document_Library_System-related data"""
    document: Optional[Dict[str, Document]] = Field(
        default=None,
        description="Schema Document"
    )
    document_tag: Optional[Dict[str, DocumentTag]] = Field(
        default=None,
        description="Schema DocumentTag"
    )
    document_version: Optional[Dict[str, DocumentVersion]] = Field(
        default=None,
        description="Schema DocumentVersion"
    )
    folder: Optional[Dict[str, Folder]] = Field(
        default=None,
        description="Schema Folder"
    )
    document_permission: Optional[Dict[str, DocumentPermission]] = Field(
        default=None,
        description="Schema DocumentPermission"
    )
    document_comment: Optional[Dict[str, DocumentComment]] = Field(
        default=None,
        description="Schema DocumentComment"
    )
    document_template: Optional[Dict[str, DocumentTemplate]] = Field(
        default=None,
        description="Schema DocumentTemplate"
    )
    document_lock: Optional[Dict[str, DocumentLock]] = Field(
        default=None,
        description="Schema DocumentLock"
    )
    document_link: Optional[Dict[str, DocumentLink]] = Field(
        default=None,
        description="Schema DocumentLink"
    )
    document_attachment: Optional[Dict[str, DocumentAttachment]] = Field(
        default=None,
        description="Schema DocumentAttachment"
    )