"""
Database schemas for email_management_Integrated_Mail_and_Calendar_Client

This module contains all database schema classes for the email_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 pydantic import PrivateAttr, Field, validator
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("draft_id")
class EmailDraft(BaseModel, ThreadSafeBase["EmailDraft"]):
    draft_id: str = Field(..., description="Unique identifier of the email draft")
    subject: str = Field(..., description="Subject line of the email")
    body: str = Field(..., description="Main content of the email message")
    to_recipients: List[str] = Field(..., description="List of primary recipient email addresses")
    cc_recipients: Optional[List[str]] = Field(default=None, description="List of CC recipient email addresses")
    bcc_recipients: Optional[List[str]] = Field(default=None, description="List of BCC recipient email addresses")
    priority: Optional[Literal["low", "normal", "high"]] = Field(default="normal", description="Priority level of the email")
    created_at: datetime = Field(..., description="Timestamp when draft was created")
    parent_message_id: Optional[str] = Field(default=None, description="Reference to original message if this is a reply or forward")
    is_reply: Optional[bool] = Field(default=False, description="Whether this draft is a reply")
    is_forward: Optional[bool] = Field(default=False, description="Whether this draft is a forward")

@with_instance_key("message_id")
class EmailMessage(BaseModel, ThreadSafeBase["EmailMessage"]):
    message_id: str = Field(..., description="Unique identifier of the email message")
    subject: str = Field(..., description="Subject of the email")
    body: str = Field(..., description="Email body content")
    from_address: str = Field(..., description="Sender email address")
    to_recipients: List[str] = Field(..., description="List of recipient email addresses")
    cc_recipients: Optional[List[str]] = Field(default=None, description="List of CC recipient email addresses")
    bcc_recipients: Optional[List[str]] = Field(default=None, description="List of BCC recipient email addresses")
    sent_at: Optional[datetime] = Field(default=None, description="Timestamp when email was sent")
    received_at: Optional[datetime] = Field(default=None, description="Timestamp when email was received")
    is_read: bool = Field(default=False, description="Whether the email has been read")
    is_flagged: bool = Field(default=False, description="Whether the email is flagged for follow-up")
    is_archived: bool = Field(default=False, description="Whether the email is archived")
    is_spam: bool = Field(default=False, description="Whether the email is marked as spam")
    is_deleted: bool = Field(default=False, description="Whether the email is deleted")
    folder_id: str = Field(..., description="Current folder containing the email")
    priority: Optional[Literal["low", "normal", "high"]] = Field(default="normal", description="Priority level of the email")

@with_instance_key("folder_id")
class EmailFolder(BaseModel, ThreadSafeBase["EmailFolder"]):
    folder_id: str = Field(..., description="Unique identifier of the folder")
    folder_name: str = Field(..., description="Name of the folder")
    parent_folder_id: Optional[str] = Field(default=None, description="Identifier of parent folder for nested structure")
    is_system_folder: bool = Field(default=False, description="Whether this is a system folder like inbox or trash")
    created_at: datetime = Field(..., description="Timestamp when folder was created")

@with_instance_key("rule_id")
class EmailFilterRule(BaseModel, ThreadSafeBase["EmailFilterRule"]):      
    rule_id: str = Field(..., description="Unique identifier of the filter rule")
    rule_name: str = Field(..., description="Name of the filter rule")
    condition_field: Literal["subject", "sender", "body", "recipient"] = Field(..., description="Email field to apply condition on")
    condition_operator: Literal["contains", "equals", "starts_with", "ends_with"] = Field(..., description="Comparison operator for the condition")
    condition_value: str = Field(..., description="Value to match against")
    action_type: Literal["move_to_folder", "mark_as_read", "add_label", "delete"] = Field(..., description="Action to perform when condition matches")
    action_parameter: Optional[str] = Field(default=None, description="Parameter for the action")
    is_active: bool = Field(default=True, description="Whether the rule is currently active")
    created_at: datetime = Field(..., description="Timestamp when rule was created")

@with_instance_key("attachment_id")
class EmailAttachment(BaseModel, ThreadSafeBase["EmailAttachment"]):
    attachment_id: str = Field(..., description="Unique identifier of the attachment")
    message_id: Optional[str] = Field(default=None, description="Identifier of the email containing attachment")
    draft_id: Optional[str] = Field(default=None, description="Identifier of the draft containing attachment")
    file_name: str = Field(..., description="Display name for the attachment")
    file_path: str = Field(..., description="Path to the file")
    file_size: int = Field(..., description="Size of file in bytes")
    mime_type: Optional[str] = Field(default=None, description="MIME type of the attachment")
    created_at: datetime = Field(..., description="Timestamp when attachment was added")

@with_instance_key("event_id")
class CalendarEvent(BaseModel, ThreadSafeBase["CalendarEvent"]):
    event_id: str = Field(..., description="Unique identifier of the calendar event")
    title: str = Field(..., description="Title of the calendar event")
    description: Optional[str] = Field(default=None, description="Detailed description of the event")
    start_time: datetime = Field(..., description="Start time of event")
    end_time: datetime = Field(..., description="End time of event")
    location: Optional[str] = Field(default=None, description="Location of the event")
    attendees: Optional[List[str]] = Field(default=None, description="List of attendee email addresses")
    is_recurring: bool = Field(default=False, description="Whether this is a recurring event")
    series_id: Optional[str] = Field(default=None, description="Identifier of recurring event series")
    created_at: datetime = Field(..., description="Timestamp when event was created")

@with_instance_key("series_id")
class RecurringEventSeries(BaseModel, ThreadSafeBase["RecurringEventSeries"]):
    series_id: str = Field(..., description="Unique identifier of the recurring event series")
    title: str = Field(..., description="Title of the recurring event")
    recurrence_pattern: Literal["daily", "weekly", "monthly", "yearly"] = Field(..., description="Pattern of recurrence")
    recurrence_interval: int = Field(1, description="Interval between occurrences")
    recurrence_end_date: Optional[date] = Field(None, description="End date for recurrence")
    created_at: datetime = Field(..., description="Timestamp when series was created")

@with_instance_key("reminder_id")
class EventReminder(BaseModel, ThreadSafeBase["EventReminder"]):
    reminder_id: str = Field(..., description="Unique identifier of the reminder")
    event_id: str = Field(..., description="Identifier of the event")
    reminder_minutes: int = Field(..., description="Minutes before event to trigger reminder")
    reminder_method: Literal["email", "popup", "notification"] = Field(
        default="popup", description="Method of reminder delivery"
    )
    created_at: datetime = Field(..., description="Timestamp when reminder was created")

@with_instance_key("label_id")
class EmailLabel(BaseModel, ThreadSafeBase["EmailLabel"]):
    label_id: str = Field(..., description="Unique identifier of the label")
    label_name: str = Field(..., description="Name of the label")
    color: Optional[str] = Field(default=None, description="Color code for the label display")
    is_system_label: bool = Field(default=False, description="Whether this is a system label")
    created_at: datetime = Field(..., description="Timestamp when label was created")

@with_instance_key("message_label_id")
class MessageLabel(BaseModel, ThreadSafeBase["MessageLabel"]):
    message_label_id: str = Field(..., description="Unique identifier of the message-label relationship")
    message_id: str = Field(..., description="Identifier of the email")
    label_id: str = Field(..., description="Identifier of the label")
    created_at: datetime = Field(..., description="Timestamp when label was added to message")

@with_instance_key("signature_id")
class EmailSignature(BaseModel, ThreadSafeBase["EmailSignature"]):
    signature_id: str = Field(..., description="Unique identifier of the signature")
    signature_name: str = Field(..., description="Name to identify the signature")
    signature_content: str = Field(..., description="HTML or plain text content of the signature")
    is_default: bool = Field(default=False, description="Whether this is the default signature")
    created_at: datetime = Field(..., description="Timestamp when signature was created")

    @validator("created_at", pre=True)
    def strip_created_at(cls, v):
        # Remove leading/trailing spaces from the datetime string before parsing
        if isinstance(v, str):
            v = v.strip()
        return v

@with_instance_key("scheduled_id")
class ScheduledEmail(BaseModel, ThreadSafeBase["ScheduledEmail"]):
    scheduled_id: str = Field(..., description="Unique identifier of the scheduled send")
    draft_id: str = Field(..., description="Identifier of the draft to send")
    scheduled_time: datetime = Field(..., description="Time to send the email")
    is_sent: bool = Field(default=False, description="Whether the email has been sent")
    is_cancelled: bool = Field(default=False, description="Whether the scheduled send has been cancelled")
    created_at: datetime = Field(..., description="Timestamp when schedule was created")

@with_instance_key("config_id")
class OutOfOfficeConfig(BaseModel, ThreadSafeBase["OutOfOfficeConfig"]):
    config_id: str = Field(..., description="Unique identifier of the configuration")
    message: str = Field(..., description="Auto-reply message content")
    start_date: datetime = Field(..., description="Start date for auto-reply")
    end_date: datetime = Field(..., description="End date for auto-reply")
    reply_to_internal_only: bool = Field(default=False, description="Whether to only reply to internal senders")
    is_active: bool = Field(default=True, description="Whether the configuration is currently active")
    created_at: datetime = Field(..., description="Timestamp when configuration was created")

class EmailManagementDB(DB):
    """Database containing all email_management_Integrated_Mail_and_Calendar_Client-related data"""
    email_draft: Optional[Dict[str, EmailDraft]] = Field(
        default=None,
        description="Schema EmailDraft"
    )
    email_message: Optional[Dict[str, EmailMessage]] = Field(
        default=None,
        description="Schema EmailMessage"
    )
    email_folder: Optional[Dict[str, EmailFolder]] = Field(
        default=None,
        description="Schema EmailFolder"
    )
    email_filter_rule: Optional[Dict[str, EmailFilterRule]] = Field(
        default=None,
        description="Schema EmailFilterRule"
    )
    email_attachment: Optional[Dict[str, EmailAttachment]] = Field(
        default=None,
        description="Schema EmailAttachment"
    )
    calendar_event: Optional[Dict[str, CalendarEvent]] = Field(
        default=None,
        description="Schema CalendarEvent"
    )
    recurring_event_series: Optional[Dict[str, RecurringEventSeries]] = Field(
        default=None,
        description="Schema RecurringEventSeries"
    )
    event_reminder: Optional[Dict[str, EventReminder]] = Field(
        default=None,
        description="Schema EventReminder"
    )
    email_label: Optional[Dict[str, EmailLabel]] = Field(
        default=None,
        description="Schema EmailLabel"
    )
    message_label: Optional[Dict[str, MessageLabel]] = Field(
        default=None,
        description="Schema MessageLabel"
    )
    email_signature: Optional[Dict[str, EmailSignature]] = Field(
        default=None,
        description="Schema EmailSignature"
    )
    scheduled_email: Optional[Dict[str, ScheduledEmail]] = Field(
        default=None,
        description="Schema ScheduledEmail"
    )
    out_of_office_config: Optional[Dict[str, OutOfOfficeConfig]] = Field(
        default=None,
        description="Schema OutOfOfficeConfig"
    )