{
  "domain": "email_management",
  "databases": [
    {
      "table_name": "email_draft",
      "description": "Stores email draft information including subject, body, recipients, and metadata",
      "schema": {
        "columns": [
          {
            "name": "draft_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the email draft",
            "optional": false
          },
          {
            "name": "subject",
            "type": "TEXT",
            "description": "Subject line of the email",
            "optional": false
          },
          {
            "name": "body",
            "type": "TEXT",
            "description": "Main content of the email message",
            "optional": false
          },
          {
            "name": "to_recipients",
            "type": "JSON",
            "description": "List of primary recipient email addresses",
            "optional": false
          },
          {
            "name": "cc_recipients",
            "type": "JSON",
            "description": "List of CC recipient email addresses",
            "optional": true
          },
          {
            "name": "bcc_recipients",
            "type": "JSON",
            "description": "List of BCC recipient email addresses",
            "optional": true
          },
          {
            "name": "priority",
            "type": "VARCHAR(10)",
            "description": "Priority level of the email",
            "default": "normal",
            "optional": true,
            "enum": [
              "low",
              "normal",
              "high"
            ]
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when draft was created",
            "optional": false
          },
          {
            "name": "parent_message_id",
            "type": "VARCHAR(10)",
            "description": "Reference to original message if this is a reply or forward",
            "optional": true,
            "references": "email_message.message_id"
          },
          {
            "name": "is_reply",
            "type": "BOOLEAN",
            "description": "Whether this draft is a reply",
            "default": "false",
            "optional": true
          },
          {
            "name": "is_forward",
            "type": "BOOLEAN",
            "description": "Whether this draft is a forward",
            "default": "false",
            "optional": true
          }
        ],
        "primary_key": "draft_id"
      }
    },
    {
      "table_name": "email_message",
      "description": "Stores sent and received email messages with complete metadata",
      "schema": {
        "columns": [
          {
            "name": "message_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the email message",
            "optional": false
          },
          {
            "name": "subject",
            "type": "TEXT",
            "description": "Subject of the email",
            "optional": false
          },
          {
            "name": "body",
            "type": "TEXT",
            "description": "Email body content",
            "optional": false
          },
          {
            "name": "from_address",
            "type": "VARCHAR(255)",
            "description": "Sender email address",
            "optional": false
          },
          {
            "name": "to_recipients",
            "type": "JSON",
            "description": "List of recipient email addresses",
            "optional": false
          },
          {
            "name": "cc_recipients",
            "type": "JSON",
            "description": "List of CC recipient email addresses",
            "optional": true
          },
          {
            "name": "bcc_recipients",
            "type": "JSON",
            "description": "List of BCC recipient email addresses",
            "optional": true
          },
          {
            "name": "sent_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when email was sent",
            "optional": true
          },
          {
            "name": "received_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when email was received",
            "optional": true
          },
          {
            "name": "is_read",
            "type": "BOOLEAN",
            "description": "Whether the email has been read",
            "default": "false",
            "optional": false
          },
          {
            "name": "is_flagged",
            "type": "BOOLEAN",
            "description": "Whether the email is flagged for follow-up",
            "default": "false",
            "optional": false
          },
          {
            "name": "is_archived",
            "type": "BOOLEAN",
            "description": "Whether the email is archived",
            "default": "false",
            "optional": false
          },
          {
            "name": "is_spam",
            "type": "BOOLEAN",
            "description": "Whether the email is marked as spam",
            "default": "false",
            "optional": false
          },
          {
            "name": "is_deleted",
            "type": "BOOLEAN",
            "description": "Whether the email is deleted",
            "default": "false",
            "optional": false
          },
          {
            "name": "folder_id",
            "type": "VARCHAR(10)",
            "description": "Current folder containing the email",
            "optional": false,
            "references": "email_folder.folder_id"
          },
          {
            "name": "priority",
            "type": "VARCHAR(10)",
            "description": "Priority level of the email",
            "default": "normal",
            "optional": true,
            "enum": [
              "low",
              "normal",
              "high"
            ]
          }
        ],
        "primary_key": "message_id"
      }
    },
    {
      "table_name": "email_folder",
      "description": "Stores email folder structure for organizing emails",
      "schema": {
        "columns": [
          {
            "name": "folder_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the folder",
            "optional": false
          },
          {
            "name": "folder_name",
            "type": "VARCHAR(255)",
            "description": "Name of the folder",
            "optional": false
          },
          {
            "name": "parent_folder_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of parent folder for nested structure",
            "optional": true,
            "references": "email_folder.folder_id"
          },
          {
            "name": "is_system_folder",
            "type": "BOOLEAN",
            "description": "Whether this is a system folder like inbox or trash",
            "default": "false",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when folder was created",
            "optional": false
          }
        ],
        "primary_key": "folder_id"
      }
    },
    {
      "table_name": "email_filter_rule",
      "description": "Stores automatic filter rules for organizing incoming emails",
      "schema": {
        "columns": [
          {
            "name": "rule_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the filter rule",
            "optional": false
          },
          {
            "name": "rule_name",
            "type": "VARCHAR(255)",
            "description": "Name of the filter rule",
            "optional": false
          },
          {
            "name": "condition_field",
            "type": "VARCHAR(50)",
            "description": "Email field to apply condition on",
            "optional": false,
            "enum": [
              "subject",
              "sender",
              "body",
              "recipient"
            ]
          },
          {
            "name": "condition_operator",
            "type": "VARCHAR(50)",
            "description": "Comparison operator for the condition",
            "optional": false,
            "enum": [
              "contains",
              "equals",
              "starts_with",
              "ends_with"
            ]
          },
          {
            "name": "condition_value",
            "type": "TEXT",
            "description": "Value to match against",
            "optional": false
          },
          {
            "name": "action_type",
            "type": "VARCHAR(50)",
            "description": "Action to perform when condition matches",
            "optional": false,
            "enum": [
              "move_to_folder",
              "mark_as_read",
              "add_label",
              "delete"
            ]
          },
          {
            "name": "action_parameter",
            "type": "VARCHAR(255)",
            "description": "Parameter for the action",
            "optional": true
          },
          {
            "name": "is_active",
            "type": "BOOLEAN",
            "description": "Whether the rule is currently active",
            "default": "true",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when rule was created",
            "optional": false
          }
        ],
        "primary_key": "rule_id"
      }
    },
    {
      "table_name": "email_attachment",
      "description": "Stores email attachment metadata and references",
      "schema": {
        "columns": [
          {
            "name": "attachment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the attachment",
            "optional": false
          },
          {
            "name": "message_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the email containing attachment",
            "optional": true,
            "references": "email_message.message_id"
          },
          {
            "name": "draft_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the draft containing attachment",
            "optional": true,
            "references": "email_draft.draft_id"
          },
          {
            "name": "file_name",
            "type": "VARCHAR(255)",
            "description": "Display name for the attachment",
            "optional": false
          },
          {
            "name": "file_path",
            "type": "TEXT",
            "description": "Path to the file",
            "optional": false
          },
          {
            "name": "file_size",
            "type": "BIGINT",
            "description": "Size of file in bytes",
            "optional": false
          },
          {
            "name": "mime_type",
            "type": "VARCHAR(100)",
            "description": "MIME type of the attachment",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when attachment was added",
            "optional": false
          }
        ],
        "primary_key": "attachment_id"
      }
    },
    {
      "table_name": "calendar_event",
      "description": "Stores calendar events with time, attendees, and metadata",
      "schema": {
        "columns": [
          {
            "name": "event_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the calendar event",
            "optional": false
          },
          {
            "name": "title",
            "type": "VARCHAR(255)",
            "description": "Title of the calendar event",
            "optional": false
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Detailed description of the event",
            "optional": true
          },
          {
            "name": "start_time",
            "type": "TIMESTAMP",
            "description": "Start time of event",
            "optional": false
          },
          {
            "name": "end_time",
            "type": "TIMESTAMP",
            "description": "End time of event",
            "optional": false
          },
          {
            "name": "location",
            "type": "VARCHAR(255)",
            "description": "Location of the event",
            "optional": true
          },
          {
            "name": "attendees",
            "type": "JSON",
            "description": "List of attendee email addresses",
            "optional": true
          },
          {
            "name": "is_recurring",
            "type": "BOOLEAN",
            "description": "Whether this is a recurring event",
            "default": "false",
            "optional": false
          },
          {
            "name": "series_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of recurring event series",
            "optional": true,
            "references": "recurring_event_series.series_id"
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when event was created",
            "optional": false
          }
        ],
        "primary_key": "event_id"
      }
    },
    {
      "table_name": "recurring_event_series",
      "description": "Stores recurring event series configuration",
      "schema": {
        "columns": [
          {
            "name": "series_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the recurring event series",
            "optional": false
          },
          {
            "name": "title",
            "type": "VARCHAR(255)",
            "description": "Title of the recurring event",
            "optional": false
          },
          {
            "name": "recurrence_pattern",
            "type": "VARCHAR(50)",
            "description": "Pattern of recurrence",
            "optional": false,
            "enum": [
              "daily",
              "weekly",
              "monthly",
              "yearly"
            ]
          },
          {
            "name": "recurrence_interval",
            "type": "INTEGER",
            "description": "Interval between occurrences",
            "default": "1",
            "optional": false
          },
          {
            "name": "recurrence_end_date",
            "type": "DATE",
            "description": "End date for recurrence",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when series was created",
            "optional": false
          }
        ],
        "primary_key": "series_id"
      }
    },
    {
      "table_name": "event_reminder",
      "description": "Stores reminder notifications for calendar events",
      "schema": {
        "columns": [
          {
            "name": "reminder_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the reminder",
            "optional": false
          },
          {
            "name": "event_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the event",
            "optional": false,
            "references": "calendar_event.event_id"
          },
          {
            "name": "reminder_minutes",
            "type": "INTEGER",
            "description": "Minutes before event to trigger reminder",
            "optional": false
          },
          {
            "name": "reminder_method",
            "type": "VARCHAR(50)",
            "description": "Method of reminder delivery",
            "default": "popup",
            "optional": false,
            "enum": [
              "email",
              "popup",
              "notification"
            ]
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when reminder was created",
            "optional": false
          }
        ],
        "primary_key": "reminder_id"
      }
    },
    {
      "table_name": "email_label",
      "description": "Stores custom labels for email categorization",
      "schema": {
        "columns": [
          {
            "name": "label_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the label",
            "optional": false
          },
          {
            "name": "label_name",
            "type": "VARCHAR(255)",
            "description": "Name of the label",
            "optional": false
          },
          {
            "name": "color",
            "type": "VARCHAR(7)",
            "description": "Color code for the label display",
            "optional": true
          },
          {
            "name": "is_system_label",
            "type": "BOOLEAN",
            "description": "Whether this is a system label",
            "default": "false",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when label was created",
            "optional": false
          }
        ],
        "primary_key": "label_id"
      }
    },
    {
      "table_name": "message_label",
      "description": "Junction table linking emails to labels",
      "schema": {
        "columns": [
          {
            "name": "message_label_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the message-label relationship",
            "optional": false
          },
          {
            "name": "message_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the email",
            "optional": false,
            "references": "email_message.message_id"
          },
          {
            "name": "label_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the label",
            "optional": false,
            "references": "email_label.label_id"
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when label was added to message",
            "optional": false
          }
        ],
        "primary_key": "message_label_id"
      }
    },
    {
      "table_name": "email_signature",
      "description": "Stores custom email signature templates",
      "schema": {
        "columns": [
          {
            "name": "signature_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the signature",
            "optional": false
          },
          {
            "name": "signature_name",
            "type": "VARCHAR(255)",
            "description": "Name to identify the signature",
            "optional": false
          },
          {
            "name": "signature_content",
            "type": "TEXT",
            "description": "HTML or plain text content of the signature",
            "optional": false
          },
          {
            "name": "is_default",
            "type": "BOOLEAN",
            "description": "Whether this is the default signature",
            "default": "false",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when signature was created",
            "optional": false
          }
        ],
        "primary_key": "signature_id"
      }
    },
    {
      "table_name": "scheduled_email",
      "description": "Stores emails scheduled to be sent at a future time",
      "schema": {
        "columns": [
          {
            "name": "scheduled_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the scheduled send",
            "optional": false
          },
          {
            "name": "draft_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the draft to send",
            "optional": false,
            "references": "email_draft.draft_id"
          },
          {
            "name": "scheduled_time",
            "type": "TIMESTAMP",
            "description": "Time to send the email",
            "optional": false
          },
          {
            "name": "is_sent",
            "type": "BOOLEAN",
            "description": "Whether the email has been sent",
            "default": "false",
            "optional": false
          },
          {
            "name": "is_cancelled",
            "type": "BOOLEAN",
            "description": "Whether the scheduled send has been cancelled",
            "default": "false",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when schedule was created",
            "optional": false
          }
        ],
        "primary_key": "scheduled_id"
      }
    },
    {
      "table_name": "out_of_office_config",
      "description": "Stores out-of-office automatic reply configuration",
      "schema": {
        "columns": [
          {
            "name": "config_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the configuration",
            "optional": false
          },
          {
            "name": "message",
            "type": "TEXT",
            "description": "Auto-reply message content",
            "optional": false
          },
          {
            "name": "start_date",
            "type": "TIMESTAMP",
            "description": "Start date for auto-reply",
            "optional": false
          },
          {
            "name": "end_date",
            "type": "TIMESTAMP",
            "description": "End date for auto-reply",
            "optional": false
          },
          {
            "name": "reply_to_internal_only",
            "type": "BOOLEAN",
            "description": "Whether to only reply to internal senders",
            "default": "false",
            "optional": false
          },
          {
            "name": "is_active",
            "type": "BOOLEAN",
            "description": "Whether the configuration is currently active",
            "default": "true",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when configuration was created",
            "optional": false
          }
        ],
        "primary_key": "config_id"
      }
    }
  ],
  "tools": [
    {
      "name": "schedule_email_send",
      "description": "Schedule an email to be sent at a specific future time",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "execution_control",
      "pre_condition": "Draft exists and scheduled time is in the future",
      "post_condition": "Email is scheduled for sending at specified time",
      "parameters": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Identifier of the draft to schedule",
            "type": "string",
            "examples": [
              "draft_789xyz"
            ]
          },
          "scheduled_time": {
            "description": "Time to send the email in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 09:00:00"
            ]
          }
        },
        "required": [
          "draft_id",
          "scheduled_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "scheduled_id": {
            "description": "Unique identifier of the scheduled send",
            "type": "string",
            "examples": [
              "sched_456"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_draft",
        "email_folder",
        "scheduled_email"
      ]
    },
    {
      "name": "get_mailbox_storage_quota",
      "description": "Retrieve current mailbox storage usage and quota information",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "monitoring",
      "pre_condition": "Mailbox is accessible",
      "post_condition": "Storage quota information is returned",
      "parameters": {
        "type": "object",
        "properties": {},
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "used_storage_mb": {
            "description": "Current storage used in megabytes",
            "type": "number",
            "examples": [
              2048.5
            ]
          },
          "total_quota_mb": {
            "description": "Total storage quota in megabytes",
            "type": "number",
            "examples": [
              15360.0
            ]
          },
          "usage_percentage": {
            "description": "Percentage of quota used",
            "type": "number",
            "examples": [
              13.3
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "remove_label_from_email",
      "description": "Remove a label or tag from an email",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "label_management",
      "action_category": "data_management",
      "pre_condition": "Email has the specified label",
      "post_condition": "Label is removed from email",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "label_name": {
            "description": "Name of the label to remove",
            "type": "string",
            "examples": [
              "Important"
            ]
          }
        },
        "required": [
          "message_id",
          "label_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the label was removed successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_label",
        "message_label"
      ]
    },
    {
      "name": "mark_email_as_spam",
      "description": "Mark an email as spam and move it to spam folder",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email exists in mailbox",
      "post_condition": "Email is marked as spam and moved to spam folder",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email to mark as spam",
            "type": "string",
            "examples": [
              "msg_spam123"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "cancel_scheduled_email",
      "description": "Cancel a previously scheduled email send",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "execution_control",
      "pre_condition": "Scheduled send exists and has not been sent yet",
      "post_condition": "Scheduled send is cancelled",
      "parameters": {
        "type": "object",
        "properties": {
          "scheduled_id": {
            "description": "Identifier of the scheduled send to cancel",
            "type": "string",
            "examples": [
              "sched_456"
            ]
          }
        },
        "required": [
          "scheduled_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the cancellation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "scheduled_email"
      ]
    },
    {
      "name": "delete_calendar_event",
      "description": "Delete a calendar event",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Event exists in calendar",
      "post_condition": "Event is deleted from calendar",
      "parameters": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Identifier of the event to delete",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          },
          "notify_attendees": {
            "description": "Whether to send cancellation notice to attendees",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "event_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the deletion succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "filter_emails_by_sender",
      "description": "Filter emails from a specific sender address",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Valid sender email address is provided",
      "post_condition": "List of emails from sender is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "email_address": {
            "description": "Email address of the sender",
            "type": "string",
            "examples": [
              "boss@example.com"
            ]
          },
          "folder_id": {
            "description": "Specific folder to search in",
            "type": "string",
            "examples": [
              "inbox"
            ]
          }
        },
        "required": [
          "email_address"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "message_ids": {
            "description": "List of email message IDs from the sender",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "msg_111",
                "msg_222"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "disable_out_of_office_reply",
      "description": "Disable the automatic out-of-office reply",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "configuration",
      "pre_condition": "Out-of-office reply is currently enabled",
      "post_condition": "Out-of-office reply is disabled",
      "parameters": {
        "type": "object",
        "properties": {},
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the disable operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "out_of_office_config"
      ]
    },
    {
      "name": "list_email_filter_rules",
      "description": "Retrieve all configured email filter rules",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "filter_rule_management",
      "action_category": "data_management",
      "pre_condition": "Mailbox is accessible",
      "post_condition": "List of filter rules is returned",
      "parameters": {
        "type": "object",
        "properties": {},
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "rules": {
            "description": "List of filter rule objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "rule_id": "rule_123",
                  "rule_name": "Move newsletters"
                }
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "email_filter_rule"
      ]
    },
    {
      "name": "add_label_to_email",
      "description": "Add a custom label or tag to an email for categorization",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "label_management",
      "action_category": "data_management",
      "pre_condition": "Email and label both exist",
      "post_condition": "Label is added to email",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "label_name": {
            "description": "Name of the label to add",
            "type": "string",
            "examples": [
              "Important"
            ]
          }
        },
        "required": [
          "message_id",
          "label_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the label was added successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_label",
        "message_label"
      ]
    },
    {
      "name": "update_calendar_event",
      "description": "Update details of an existing calendar event",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Event exists in calendar",
      "post_condition": "Event details are updated",
      "parameters": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Identifier of the event to update",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          },
          "title": {
            "description": "New title for the event",
            "type": "string",
            "examples": [
              "Updated Team Meeting"
            ]
          },
          "start_time": {
            "description": "New start time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 15:00:00"
            ]
          },
          "end_time": {
            "description": "New end time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 16:00:00"
            ]
          }
        },
        "required": [
          "event_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the update succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "filter_emails_by_date_range",
      "description": "Filter emails within a specific date range",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Valid date range is provided",
      "post_condition": "Filtered email list is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "start_date": {
            "description": "Start date of the range in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-01 00:00:00"
            ]
          },
          "end_date": {
            "description": "End date of the range in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-31 23:59:59"
            ]
          },
          "folder_id": {
            "description": "Specific folder to search in",
            "type": "string",
            "examples": [
              "inbox"
            ]
          }
        },
        "required": [
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "message_ids": {
            "description": "List of email message IDs in the date range",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "msg_123",
                "msg_456"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "create_recurring_event",
      "description": "Create a recurring calendar event with specified recurrence pattern",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Valid event details and recurrence pattern are provided",
      "post_condition": "Recurring event series is created",
      "parameters": {
        "type": "object",
        "properties": {
          "title": {
            "description": "Title of the recurring event",
            "type": "string",
            "examples": [
              "Weekly Team Standup"
            ]
          },
          "start_time": {
            "description": "Start time of first occurrence in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:00:00"
            ]
          },
          "end_time": {
            "description": "End time of first occurrence in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "recurrence_pattern": {
            "description": "Pattern of recurrence",
            "type": "string",
            "enum": [
              "daily",
              "weekly",
              "monthly",
              "yearly"
            ],
            "examples": [
              "weekly"
            ]
          },
          "recurrence_interval": {
            "description": "Interval between occurrences",
            "type": "integer",
            "examples": [
              1
            ]
          },
          "recurrence_end_date": {
            "description": "End date for recurrence in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        },
        "required": [
          "title",
          "start_time",
          "end_time",
          "recurrence_pattern"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "series_id": {
            "description": "Unique identifier of the recurring event series",
            "type": "string",
            "examples": [
              "series_789"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "recurring_event_series",
        "calendar_event"
      ]
    },
    {
      "name": "set_out_of_office_reply",
      "description": "Configure automatic out-of-office reply message",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "configuration",
      "pre_condition": "Valid date range and message are provided",
      "post_condition": "Out-of-office reply is configured and activated",
      "parameters": {
        "type": "object",
        "properties": {
          "message": {
            "description": "Auto-reply message content",
            "type": "string",
            "examples": [
              "I am currently out of office and will return on January 25th."
            ]
          },
          "start_date": {
            "description": "Start date for auto-reply in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 00:00:00"
            ]
          },
          "end_date": {
            "description": "End date for auto-reply in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-25 23:59:59"
            ]
          },
          "reply_to_internal_only": {
            "description": "Whether to only reply to internal senders",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "message",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the configuration succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "out_of_office_config"
      ]
    },
    {
      "name": "delete_email_filter_rule",
      "description": "Delete an existing email filter rule",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "filter_rule_management",
      "action_category": "data_management",
      "pre_condition": "Filter rule exists",
      "post_condition": "Filter rule is deleted and no longer applied",
      "parameters": {
        "type": "object",
        "properties": {
          "rule_id": {
            "description": "Identifier of the rule to delete",
            "type": "string",
            "examples": [
              "rule_123"
            ]
          }
        },
        "required": [
          "rule_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the deletion succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_filter_rule"
      ]
    },
    {
      "name": "delete_email",
      "description": "Move an email to trash folder or permanently delete it",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Email exists in mailbox",
      "post_condition": "Email is moved to trash or permanently deleted",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "permanent": {
            "description": "Whether to permanently delete or move to trash",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the deletion succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "unmark_email_as_spam",
      "description": "Remove spam marking from an email and move it back to inbox",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email is currently marked as spam",
      "post_condition": "Spam marking is removed and email is moved to inbox",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email to unmark",
            "type": "string",
            "examples": [
              "msg_spam123"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "create_calendar_event",
      "description": "Create a new calendar event with title, time, and attendees",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Valid event details are provided",
      "post_condition": "Calendar event is created",
      "parameters": {
        "type": "object",
        "properties": {
          "title": {
            "description": "Title of the calendar event",
            "type": "string",
            "examples": [
              "Team Meeting"
            ]
          },
          "start_time": {
            "description": "Start time of event in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 14:00:00"
            ]
          },
          "end_time": {
            "description": "End time of event in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 15:00:00"
            ]
          },
          "location": {
            "description": "Location of the event",
            "type": "string",
            "examples": [
              "Conference Room A"
            ]
          },
          "attendees": {
            "description": "List of attendee email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "john@example.com",
                "jane@example.com"
              ]
            ]
          },
          "description": {
            "description": "Detailed description of the event",
            "type": "string",
            "examples": [
              "Quarterly planning discussion"
            ]
          }
        },
        "required": [
          "title",
          "start_time",
          "end_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Unique identifier of the created event",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "create_email_filter_rule",
      "description": "Create an automatic filter rule to organize incoming emails",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "filter_rule_management",
      "action_category": "data_management",
      "pre_condition": "Valid filter criteria and action are provided",
      "post_condition": "Filter rule is created and activated",
      "parameters": {
        "type": "object",
        "properties": {
          "rule_name": {
            "description": "Name of the filter rule",
            "type": "string",
            "examples": [
              "Move newsletters to folder"
            ]
          },
          "condition_field": {
            "description": "Email field to apply condition on",
            "type": "string",
            "enum": [
              "subject",
              "sender",
              "body",
              "recipient"
            ],
            "examples": [
              "subject"
            ]
          },
          "condition_operator": {
            "description": "Comparison operator for the condition",
            "type": "string",
            "enum": [
              "contains",
              "equals",
              "starts_with",
              "ends_with"
            ],
            "examples": [
              "contains"
            ]
          },
          "condition_value": {
            "description": "Value to match against",
            "type": "string",
            "examples": [
              "newsletter"
            ]
          },
          "action_type": {
            "description": "Action to perform when condition matches",
            "type": "string",
            "enum": [
              "move_to_folder",
              "mark_as_read",
              "add_label",
              "delete"
            ],
            "examples": [
              "move_to_folder"
            ]
          },
          "action_parameter": {
            "description": "Parameter for the action (e.g., folder_id for move)",
            "type": "string",
            "examples": [
              "folder_newsletters"
            ]
          }
        },
        "required": [
          "rule_name",
          "condition_field",
          "condition_operator",
          "condition_value",
          "action_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "rule_id": {
            "description": "Unique identifier of the created rule",
            "type": "string",
            "examples": [
              "rule_123"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_filter_rule"
      ]
    },
    {
      "name": "search_emails_by_keyword",
      "description": "Search emails by keyword in subject, body, or sender fields",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Mailbox is accessible and indexed",
      "post_condition": "List of matching emails is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "keyword": {
            "description": "Search keyword or phrase",
            "type": "string",
            "examples": [
              "project update"
            ]
          },
          "search_fields": {
            "description": "Fields to search in",
            "type": "array",
            "items": {
              "type": "string",
              "enum": [
                "subject",
                "body",
                "sender",
                "recipients"
              ]
            },
            "examples": [
              [
                "subject",
                "body"
              ]
            ]
          },
          "limit": {
            "description": "Maximum number of results to return",
            "type": "integer",
            "examples": [
              50
            ]
          }
        },
        "required": [
          "keyword"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "results": {
            "description": "List of matching email message IDs",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "msg_456abc",
                "msg_789def"
              ]
            ]
          },
          "total_count": {
            "description": "Total number of matching emails",
            "type": "integer",
            "examples": [
              25
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "send_email",
      "description": "Send an email immediately with specified recipients and content",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "communication",
      "pre_condition": "Valid email account is configured and connected",
      "post_condition": "Email is sent and moved to sent folder",
      "parameters": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Identifier of the draft to send",
            "type": "string",
            "examples": [
              "draft_789xyz"
            ]
          }
        },
        "required": [
          "draft_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the sent message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "sent_at": {
            "description": "Timestamp when email was sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:35:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "email_draft",
        "email_message"
      ]
    },
    {
      "name": "forward_email",
      "description": "Create a forward draft of an existing email to new recipients",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Original email exists in mailbox",
      "post_condition": "Forward draft is created with original content",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email being forwarded",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "forward_to": {
            "description": "List of recipient email addresses for forwarding",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "colleague@example.com"
              ]
            ]
          },
          "forward_message": {
            "description": "Additional message to include with the forward",
            "type": "string",
            "examples": [
              "FYI - Please review this update"
            ]
          }
        },
        "required": [
          "message_id",
          "forward_to"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Unique identifier of the forward draft",
            "type": "string",
            "examples": [
              "draft_fwd_456"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_draft"
      ]
    },
    {
      "name": "format_email_date",
      "description": "Format a date string into standard email date format",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Valid date string is provided",
      "post_condition": "Formatted date string is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "date_string": {
            "description": "Date string to format in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "format_type": {
            "description": "Desired output format type",
            "type": "string",
            "enum": [
              "rfc2822",
              "iso8601",
              "human_readable"
            ],
            "examples": [
              "rfc2822"
            ]
          }
        },
        "required": [
          "date_string",
          "format_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "formatted_date": {
            "description": "Date formatted in requested format",
            "type": "string",
            "examples": [
              "Mon, 15 Jan 2024 10:30:00 +0000"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "list_email_attachments",
      "description": "Get list of all attachments in an email",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "attachment_management",
      "action_category": "data_management",
      "pre_condition": "Email exists",
      "post_condition": "List of attachments is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "attachments": {
            "description": "List of attachment metadata",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "attachment_id": "attach_789",
                  "file_name": "report.pdf",
                  "size": 2048576
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_attachment"
      ]
    },
    {
      "name": "check_calendar_availability",
      "description": "Check if a time slot is available in the calendar",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "validation",
      "pre_condition": "Valid time range is provided",
      "post_condition": "Availability status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "start_time": {
            "description": "Start time to check in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 14:00:00"
            ]
          },
          "end_time": {
            "description": "End time to check in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 15:00:00"
            ]
          }
        },
        "required": [
          "start_time",
          "end_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_available": {
            "description": "Whether the time slot is available",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "conflicting_events": {
            "description": "List of event IDs that conflict with the time slot",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "delete_email_signature",
      "description": "Delete an email signature",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "signature_management",
      "action_category": "data_management",
      "pre_condition": "Signature exists",
      "post_condition": "Signature is deleted",
      "parameters": {
        "type": "object",
        "properties": {
          "signature_id": {
            "description": "Identifier of the signature to delete",
            "type": "string",
            "examples": [
              "sig_123"
            ]
          }
        },
        "required": [
          "signature_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the deletion succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_signature"
      ]
    },
    {
      "name": "list_email_folders",
      "description": "Retrieve list of all email folders in the mailbox",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "folder_management",
      "action_category": "data_management",
      "pre_condition": "Mailbox is accessible",
      "post_condition": "List of folders is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "include_system_folders": {
            "description": "Whether to include system folders like inbox and trash",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "folders": {
            "description": "List of folder objects with id and name",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "folder_id": "inbox",
                  "name": "Inbox"
                },
                {
                  "folder_id": "sent",
                  "name": "Sent"
                }
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "email_folder"
      ]
    },
    {
      "name": "mark_email_as_unread",
      "description": "Mark a specific email message as unread",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email exists and is currently read",
      "post_condition": "Email is marked as unread",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "reply_to_email",
      "description": "Create a reply draft to an existing email with quoted original content",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Original email exists in mailbox",
      "post_condition": "Reply draft is created with proper references",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email being replied to",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "reply_body": {
            "description": "Content of the reply message",
            "type": "string",
            "examples": [
              "Thank you for the update. I will review the documents..."
            ]
          },
          "reply_all": {
            "description": "Whether to reply to all recipients or just sender",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "message_id",
          "reply_body"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Unique identifier of the reply draft",
            "type": "string",
            "examples": [
              "draft_reply_123"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_draft"
      ]
    },
    {
      "name": "update_email_signature",
      "description": "Update an existing email signature",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "signature_management",
      "action_category": "data_management",
      "pre_condition": "Signature exists",
      "post_condition": "Signature content is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "signature_id": {
            "description": "Identifier of the signature to update",
            "type": "string",
            "examples": [
              "sig_123"
            ]
          },
          "signature_content": {
            "description": "New content for the signature",
            "type": "string",
            "examples": [
              "Kind regards,<br>John Doe<br>Senior Engineer"
            ]
          }
        },
        "required": [
          "signature_id",
          "signature_content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the update succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_signature"
      ]
    },
    {
      "name": "extract_email_addresses_from_text",
      "description": "Extract all email addresses from a text string",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Text string is provided",
      "post_condition": "List of extracted email addresses is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "text": {
            "description": "Text to extract email addresses from",
            "type": "string",
            "examples": [
              "Contact us at support@example.com or sales@example.com"
            ]
          }
        },
        "required": [
          "text"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "email_addresses": {
            "description": "List of extracted email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "support@example.com",
                "sales@example.com"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "archive_email",
      "description": "Archive an email to remove it from inbox while keeping it searchable",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email exists in inbox",
      "post_condition": "Email is archived and removed from inbox",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Identifier of the email to archive",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the archiving succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "set_event_reminder",
      "description": "Set a reminder notification for a calendar event",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "configuration",
      "pre_condition": "Event exists in calendar",
      "post_condition": "Reminder is configured for event",
      "parameters": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Identifier of the event",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          },
          "reminder_minutes": {
            "description": "Minutes before event to trigger reminder",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "reminder_method": {
            "description": "Method of reminder delivery",
            "type": "string",
            "enum": [
              "email",
              "popup",
              "notification"
            ],
            "examples": [
              "popup"
            ]
          }
        },
        "required": [
          "event_id",
          "reminder_minutes"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reminder_id": {
            "description": "Unique identifier of the reminder",
            "type": "string",
            "examples": [
              "reminder_456"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event",
        "event_reminder"
      ]
    },
    {
      "name": "delete_email_folder",
      "description": "Delete an email folder and optionally its contents",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "folder_management",
      "action_category": "data_management",
      "pre_condition": "Folder exists and is not a system folder",
      "post_condition": "Folder is deleted from mailbox",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "Identifier of the folder to delete",
            "type": "string",
            "examples": [
              "folder_old"
            ]
          },
          "delete_contents": {
            "description": "Whether to delete all emails in the folder",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "folder_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the deletion succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_folder"
      ]
    },
    {
      "name": "parse_email_headers",
      "description": "Parse and extract structured information from email headers",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Raw email headers are provided",
      "post_condition": "Parsed header information is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "raw_headers": {
            "description": "Raw email headers as string",
            "type": "string",
            "examples": [
              "From: sender@example.com\\nTo: recipient@example.com\\nSubject: Test"
            ]
          }
        },
        "required": [
          "raw_headers"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "parsed_headers": {
            "description": "Dictionary of parsed header fields",
            "type": "object",
            "examples": [
              {
                "from": "sender@example.com",
                "to": "recipient@example.com"
              }
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "remove_attendee_from_event",
      "description": "Remove an attendee from a calendar event",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Event and attendee both exist",
      "post_condition": "Attendee is removed from event",
      "parameters": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Identifier of the event",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          },
          "email_address": {
            "description": "Email address of the attendee to remove",
            "type": "string",
            "examples": [
              "person@example.com"
            ]
          }
        },
        "required": [
          "event_id",
          "email_address"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the attendee was removed successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "mark_email_as_read",
      "description": "Mark a specific email message as read",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email exists and is currently unread",
      "post_condition": "Email is marked as read",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "create_email_signature",
      "description": "Create a custom email signature template",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "signature_management",
      "action_category": "data_management",
      "pre_condition": "Signature content is provided",
      "post_condition": "Email signature is created and saved",
      "parameters": {
        "type": "object",
        "properties": {
          "signature_name": {
            "description": "Name to identify the signature",
            "type": "string",
            "examples": [
              "Professional Signature"
            ]
          },
          "signature_content": {
            "description": "HTML or plain text content of the signature",
            "type": "string",
            "examples": [
              "Best regards,<br>John Doe<br>Software Engineer"
            ]
          },
          "is_default": {
            "description": "Whether this should be the default signature",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "signature_name",
          "signature_content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "signature_id": {
            "description": "Unique identifier of the created signature",
            "type": "string",
            "examples": [
              "sig_123"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_signature"
      ]
    },
    {
      "name": "list_all_labels",
      "description": "Retrieve list of all available email labels",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "label_management",
      "action_category": "data_management",
      "pre_condition": "Mailbox is accessible",
      "post_condition": "List of labels is returned",
      "parameters": {
        "type": "object",
        "properties": {},
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "labels": {
            "description": "List of label objects with id and name",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "label_id": "label_client",
                  "name": "Client Communications"
                }
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "email_label"
      ]
    },
    {
      "name": "add_attendee_to_event",
      "description": "Add a new attendee to an existing calendar event",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Event exists and attendee email is valid",
      "post_condition": "Attendee is added to event",
      "parameters": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Identifier of the event",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          },
          "email_address": {
            "description": "Email address of the attendee to add",
            "type": "string",
            "examples": [
              "newperson@example.com"
            ]
          }
        },
        "required": [
          "event_id",
          "email_address"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the attendee was added successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "add_attachment_to_draft",
      "description": "Attach a file to an existing email draft",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "attachment_management",
      "action_category": "data_management",
      "pre_condition": "Draft exists and file is accessible",
      "post_condition": "File is attached to the draft",
      "parameters": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Identifier of the draft to attach file to",
            "type": "string",
            "examples": [
              "draft_789xyz"
            ]
          },
          "file_path": {
            "description": "Path to the file to attach",
            "type": "string",
            "examples": [
              "/documents/report.pdf"
            ]
          },
          "file_name": {
            "description": "Display name for the attachment",
            "type": "string",
            "examples": [
              "Q4_Report.pdf"
            ]
          }
        },
        "required": [
          "draft_id",
          "file_path"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "attachment_id": {
            "description": "Unique identifier of the attachment",
            "type": "string",
            "examples": [
              "attach_456"
            ]
          }
        }
      },
      "raises": "OSError",
      "tool_type": "READ",
      "related_databases": [
        "email_attachment",
        "email_draft",
        "email_folder",
        "email_message"
      ]
    },
    {
      "name": "compose_email_draft",
      "description": "Create a new email draft with subject, body, recipients, and optional attachments",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "User has valid email account configured",
      "post_condition": "Email draft is created and stored in drafts folder",
      "parameters": {
        "type": "object",
        "properties": {
          "subject": {
            "description": "Subject line of the email",
            "type": "string",
            "examples": [
              "Project Update - Q4 2024"
            ]
          },
          "body": {
            "description": "Main content of the email message",
            "type": "string",
            "examples": [
              "Dear team, I wanted to share the latest updates on our Q4 progress..."
            ]
          },
          "to_recipients": {
            "description": "List of primary recipient email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "john.doe@example.com",
                "jane.smith@example.com"
              ]
            ]
          },
          "cc_recipients": {
            "description": "List of CC recipient email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "manager@example.com"
              ]
            ]
          },
          "bcc_recipients": {
            "description": "List of BCC recipient email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "archive@example.com"
              ]
            ]
          },
          "priority": {
            "description": "Priority level of the email",
            "type": "string",
            "enum": [
              "low",
              "normal",
              "high"
            ],
            "examples": [
              "normal"
            ]
          }
        },
        "required": [
          "subject",
          "body",
          "to_recipients"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Unique identifier of the created draft",
            "type": "string",
            "examples": [
              "draft_789xyz"
            ]
          },
          "created_at": {
            "description": "Timestamp when draft was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_draft"
      ]
    },
    {
      "name": "delete_custom_label",
      "description": "Delete a custom label from the system",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "label_management",
      "action_category": "data_management",
      "pre_condition": "Label exists and is not a system label",
      "post_condition": "Label is deleted from all emails",
      "parameters": {
        "type": "object",
        "properties": {
          "label_id": {
            "description": "Identifier of the label to delete",
            "type": "string",
            "examples": [
              "label_client"
            ]
          }
        },
        "required": [
          "label_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the deletion succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_label",
        "message_label"
      ]
    },
    {
      "name": "remove_flag_from_email",
      "description": "Remove flag or star marker from an email",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email exists and is currently flagged",
      "post_condition": "Flag is removed from email",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the flag was removed successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "remove_attachment_from_draft",
      "description": "Remove an attachment from an email draft",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "attachment_management",
      "action_category": "data_management",
      "pre_condition": "Draft and attachment both exist",
      "post_condition": "Attachment is removed from draft",
      "parameters": {
        "type": "object",
        "properties": {
          "draft_id": {
            "description": "Identifier of the draft",
            "type": "string",
            "examples": [
              "draft_789xyz"
            ]
          },
          "attachment_id": {
            "description": "Identifier of the attachment to remove",
            "type": "string",
            "examples": [
              "attach_456"
            ]
          }
        },
        "required": [
          "draft_id",
          "attachment_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the removal succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_draft",
        "email_attachment"
      ]
    },
    {
      "name": "validate_email_address",
      "description": "Validate the format and syntax of an email address",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "validation",
      "pre_condition": "Email address string is provided",
      "post_condition": "Validation result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "email_address": {
            "description": "Email address to validate",
            "type": "string",
            "examples": [
              "user@example.com"
            ]
          }
        },
        "required": [
          "email_address"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the email address is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "error_message": {
            "description": "Error message if validation failed",
            "type": "string",
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "list_calendar_events_by_date_range",
      "description": "Get all calendar events within a specified date range",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Valid date range is provided",
      "post_condition": "List of events in range is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "start_date": {
            "description": "Start date of range in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-01 00:00:00"
            ]
          },
          "end_date": {
            "description": "End date of range in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-31 23:59:59"
            ]
          }
        },
        "required": [
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "events": {
            "description": "List of event objects in the date range",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "event_id": "event_123",
                  "title": "Team Meeting"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "rename_email_folder",
      "description": "Rename an existing email folder",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "folder_management",
      "action_category": "data_management",
      "pre_condition": "Folder exists and new name is valid",
      "post_condition": "Folder is renamed successfully",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "Identifier of the folder to rename",
            "type": "string",
            "examples": [
              "folder_proj2024"
            ]
          },
          "new_name": {
            "description": "New name for the folder",
            "type": "string",
            "examples": [
              "Archived Projects 2024"
            ]
          }
        },
        "required": [
          "folder_id",
          "new_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the rename operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_folder"
      ]
    },
    {
      "name": "retrieve_email_by_id",
      "description": "Fetch complete email details including headers, body, and metadata by message ID",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Message ID exists in the mailbox",
      "post_condition": "Email details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "subject": {
            "description": "Subject of the email",
            "type": "string",
            "examples": [
              "Project Update - Q4 2024"
            ]
          },
          "from_address": {
            "description": "Sender email address",
            "type": "string",
            "examples": [
              "sender@example.com"
            ]
          },
          "to_addresses": {
            "description": "List of recipient email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "john.doe@example.com"
              ]
            ]
          },
          "body": {
            "description": "Email body content",
            "type": "string",
            "examples": [
              "Dear team, I wanted to share..."
            ]
          },
          "received_at": {
            "description": "Timestamp when email was received in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 09:20:00"
            ]
          },
          "is_read": {
            "description": "Whether the email has been read",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "get_unread_email_count",
      "description": "Get the count of unread emails in a specific folder",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "data_management",
      "pre_condition": "Folder exists and is accessible",
      "post_condition": "Unread count is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "Identifier of the folder to check",
            "type": "string",
            "examples": [
              "inbox"
            ]
          }
        },
        "required": [
          "folder_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "unread_count": {
            "description": "Number of unread emails",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_folder"
      ]
    },
    {
      "name": "move_email_to_folder",
      "description": "Move an email from current folder to a specified destination folder",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "resource_management",
      "pre_condition": "Email and destination folder both exist",
      "post_condition": "Email is moved to the destination folder",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          },
          "folder_id": {
            "description": "Identifier of the destination folder",
            "type": "string",
            "examples": [
              "folder_projects"
            ]
          }
        },
        "required": [
          "message_id",
          "folder_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the move operation succeeded",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message",
        "email_folder"
      ]
    },
    {
      "name": "create_custom_label",
      "description": "Create a new custom label for email categorization",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "label_management",
      "action_category": "data_management",
      "pre_condition": "Label name is unique and valid",
      "post_condition": "New label is created",
      "parameters": {
        "type": "object",
        "properties": {
          "label_name": {
            "description": "Name of the new label",
            "type": "string",
            "examples": [
              "Client Communications"
            ]
          },
          "color": {
            "description": "Color code for the label display",
            "type": "string",
            "examples": [
              "#FF5733"
            ]
          }
        },
        "required": [
          "label_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "label_id": {
            "description": "Unique identifier of the created label",
            "type": "string",
            "examples": [
              "label_client"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_label"
      ]
    },
    {
      "name": "retrieve_calendar_event",
      "description": "Get complete details of a specific calendar event",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "calendar_management",
      "action_category": "data_management",
      "pre_condition": "Event exists in calendar",
      "post_condition": "Event details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Identifier of the event to retrieve",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          }
        },
        "required": [
          "event_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "event_id": {
            "description": "Unique identifier of the event",
            "type": "string",
            "examples": [
              "event_123abc"
            ]
          },
          "title": {
            "description": "Title of the event",
            "type": "string",
            "examples": [
              "Team Meeting"
            ]
          },
          "start_time": {
            "description": "Start time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 14:00:00"
            ]
          },
          "end_time": {
            "description": "End time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 15:00:00"
            ]
          },
          "attendees": {
            "description": "List of attendee email addresses",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "john@example.com"
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "calendar_event"
      ]
    },
    {
      "name": "create_email_folder",
      "description": "Create a new folder for organizing emails",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "folder_management",
      "action_category": "data_management",
      "pre_condition": "Folder name is unique and valid",
      "post_condition": "New folder is created in mailbox",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_name": {
            "description": "Name of the new folder",
            "type": "string",
            "examples": [
              "Projects 2024"
            ]
          },
          "parent_folder_id": {
            "description": "Identifier of parent folder for nested structure",
            "type": "string",
            "examples": [
              "inbox"
            ]
          }
        },
        "required": [
          "folder_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "Unique identifier of the created folder",
            "type": "string",
            "examples": [
              "folder_proj2024"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "email_folder"
      ]
    },
    {
      "name": "add_flag_to_email",
      "description": "Add a flag or star marker to an email for follow-up",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "state_management",
      "pre_condition": "Email exists in mailbox",
      "post_condition": "Email is flagged for follow-up",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the email message",
            "type": "string",
            "examples": [
              "msg_456abc"
            ]
          }
        },
        "required": [
          "message_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Whether the flag was added successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "email_message"
      ]
    },
    {
      "name": "calculate_email_size",
      "description": "Calculate the total size of an email including attachments",
      "group": "email_management.Integrated_Mail_and_Calendar_Client",
      "object_category": "email_management",
      "action_category": "computation",
      "pre_condition": "Email content and attachments are provided",
      "post_condition": "Total email size is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "body_length": {
            "description": "Length of email body in characters",
            "type": "integer",
            "examples": [
              5000
            ]
          },
          "attachment_sizes": {
            "description": "List of attachment sizes in bytes",
            "type": "array",
            "items": {
              "type": "integer"
            },
            "examples": [
              [
                1048576,
                2097152
              ]
            ]
          }
        },
        "required": [
          "body_length"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_size_bytes": {
            "description": "Total size of email in bytes",
            "type": "integer",
            "examples": [
              3150576
            ]
          },
          "total_size_mb": {
            "description": "Total size of email in megabytes",
            "type": "number",
            "examples": [
              3.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    }
  ],
  "schema_classification": {
    "EmailDraft": {
      "schema_name": "EmailDraft",
      "instance_key": "draft_id",
      "fields": [
        {
          "field_name": "draft_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "subject",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "主题为自由文本，不同措辞可能表达相同含义"
        },
        {
          "field_name": "body",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "正文为自然语言文本，不同措辞可能表达相同内容"
        },
        {
          "field_name": "to_recipients",
          "field_type": "List[str]",
          "comparison_type": "strict",
          "reason": "收件人邮箱地址必须完全匹配，任何不同都可能导致不同的收件人"
        },
        {
          "field_name": "cc_recipients",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "抄送邮箱地址必须完全匹配，任何不同都可能导致不同的收件人"
        },
        {
          "field_name": "bcc_recipients",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "密送邮箱地址必须完全匹配，任何不同都可能导致不同的收件人"
        },
        {
          "field_name": "priority",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "优先级为枚举或数值，业务上需要精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，需严格相等以确保状态一致"
        },
        {
          "field_name": "parent_message_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "关联原始消息的ID，作为外键引用，需严格匹配"
        },
        {
          "field_name": "is_reply",
          "field_type": "Optional[bool]",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否为回复，需严格相等"
        },
        {
          "field_name": "is_forward",
          "field_type": "Optional[bool]",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否为转发，需严格相等"
        }
      ]
    },
    "EmailMessage": {
      "schema_name": "EmailMessage",
      "instance_key": "message_id",
      "fields": [
        {
          "field_name": "message_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识邮件，每次生成不同"
        },
        {
          "field_name": "subject",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "邮件主题为自然语言文本，不同措辞可能表达相同含义"
        },
        {
          "field_name": "body",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "邮件正文为自由文本描述，不同措辞可以等价"
        },
        {
          "field_name": "from_address",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "发件人邮箱地址，必须精确匹配"
        },
        {
          "field_name": "to_recipients",
          "field_type": "List[str]",
          "comparison_type": "strict",
          "reason": "收件人邮箱地址列表，必须精确匹配"
        },
        {
          "field_name": "cc_recipients",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "抄送收件人邮箱地址列表，必须精确匹配"
        },
        {
          "field_name": "bcc_recipients",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "密送收件人邮箱地址列表，必须精确匹配"
        },
        {
          "field_name": "sent_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "发送时间戳，必须精确匹配"
        },
        {
          "field_name": "received_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "接收时间戳，必须精确匹配"
        },
        {
          "field_name": "is_read",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否已读为布尔值，必须精确匹配"
        },
        {
          "field_name": "is_flagged",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否标记为需跟进为布尔值，必须精确匹配"
        },
        {
          "field_name": "is_archived",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否归档为布尔值，必须精确匹配"
        },
        {
          "field_name": "is_spam",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否为垃圾邮件为布尔值，必须精确匹配"
        },
        {
          "field_name": "is_deleted",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否已删除为布尔值，必须精确匹配"
        },
        {
          "field_name": "folder_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "邮件所在文件夹ID，必须精确匹配"
        },
        {
          "field_name": "priority",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "优先级枚举值或标记，必须精确匹配"
        }
      ]
    },
    "EmailFolder": {
      "schema_name": "EmailFolder",
      "instance_key": "folder_id",
      "fields": [
        {
          "field_name": "folder_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "folder_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "文件夹名称属于自然语言文本，不同措辞可能表达相同意义"
        },
        {
          "field_name": "parent_folder_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，以确保文件夹层级结构一致"
        },
        {
          "field_name": "is_system_folder",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配以区分系统文件夹与普通文件夹"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配以确保创建时间一致"
        }
      ]
    },
    "EmailFilterRule": {
      "schema_name": "EmailFilterRule",
      "instance_key": "rule_id",
      "fields": [
        {
          "field_name": "rule_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识，每次生成都不同"
        },
        {
          "field_name": "rule_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "规则名称属于自由文本描述，不同的措辞可能表达相同内容"
        },
        {
          "field_name": "condition_field",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须严格匹配指定的email字段"
        },
        {
          "field_name": "condition_operator",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，比较运算符，必须严格相等"
        },
        {
          "field_name": "condition_value",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "条件值可能为自由文本，例如邮件主题、发件人等，可以语义相等"
        },
        {
          "field_name": "action_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，动作类型，必须严格相等"
        },
        {
          "field_name": "action_parameter",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "动作参数通常为自由文本（如文件夹名、标签名等），可语义相等"
        },
        {
          "field_name": "is_active",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须严格匹配是否启用"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须严格匹配创建时间"
        }
      ]
    },
    "EmailAttachment": {
      "schema_name": "EmailAttachment",
      "instance_key": "attachment_id",
      "fields": [
        {
          "field_name": "attachment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符，由工具随机生成，每次执行都不同"
        },
        {
          "field_name": "message_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，指向包含该附件的邮件，必须精确匹配"
        },
        {
          "field_name": "draft_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，指向包含该附件的草稿，必须精确匹配"
        },
        {
          "field_name": "file_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "文件显示名，属于自由文本描述，不同措辞可能表达相同含义"
        },
        {
          "field_name": "file_path",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "文件路径，需精确匹配，否则指向的文件可能不同"
        },
        {
          "field_name": "file_size",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值型字段，表示文件大小，必须精确匹配"
        },
        {
          "field_name": "mime_type",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "枚举值或字符串，表示文件类型，需精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，表示添加时间，必须精确匹配"
        }
      ]
    },
    "CalendarEvent": {
      "schema_name": "CalendarEvent",
      "instance_key": "event_id",
      "fields": [
        {
          "field_name": "event_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "事件标题为自由文本，措辞不同可能表达相同含义"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以等价"
        },
        {
          "field_name": "start_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "事件开始时间必须精确匹配"
        },
        {
          "field_name": "end_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "事件结束时间必须精确匹配"
        },
        {
          "field_name": "location",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "地址或地点为自由文本，不同措辞可能等价"
        },
        {
          "field_name": "attendees",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "与会者邮箱列表应完全匹配，参与者身份精确重要"
        },
        {
          "field_name": "is_recurring",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否为周期性事件的布尔值，需精确一致"
        },
        {
          "field_name": "series_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "周期性事件系列标识符，需精确一致"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "事件创建时间戳，需精确匹配"
        }
      ]
    },
    "RecurringEventSeries": {
      "schema_name": "RecurringEventSeries",
      "instance_key": "series_id",
      "fields": [
        {
          "field_name": "series_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "标题为自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "recurrence_pattern",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须严格匹配"
        },
        {
          "field_name": "recurrence_interval",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值类型，必须精准匹配"
        },
        {
          "field_name": "recurrence_end_date",
          "field_type": "Optional[date]",
          "comparison_type": "strict",
          "reason": "日期类型，必须严格匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须严格匹配"
        }
      ]
    },
    "EventReminder": {
      "schema_name": "EventReminder",
      "instance_key": "reminder_id",
      "fields": [
        {
          "field_name": "reminder_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "event_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "reminder_minutes",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值字段，必须精确匹配"
        },
        {
          "field_name": "reminder_method",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，必须精确匹配"
        }
      ]
    },
    "EmailLabel": {
      "schema_name": "EmailLabel",
      "instance_key": "label_id",
      "fields": [
        {
          "field_name": "label_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符，每次生成都不同"
        },
        {
          "field_name": "label_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "标签名称属于自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "color",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "颜色代码用于标签显示，需精确匹配，否则视觉效果不同"
        },
        {
          "field_name": "is_system_label",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，标识是否为系统标签，需严格相等"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，表示创建时间，需严格相等"
        }
      ]
    },
    "MessageLabel": {
      "schema_name": "MessageLabel",
      "instance_key": "message_label_id",
      "fields": [
        {
          "field_name": "message_label_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次插入时由系统生成，值随机，比较时应忽略"
        },
        {
          "field_name": "message_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格等价才能认为关系相同"
        },
        {
          "field_name": "label_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格等价才能认为关系相同"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，表示标签添加时间，业务上必须完全一致"
        }
      ]
    },
    "EmailSignature": {
      "schema_name": "EmailSignature",
      "instance_key": "signature_id",
      "fields": [
        {
          "field_name": "signature_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "signature_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人类可读的名称，可能存在不同表达但语义等价"
        },
        {
          "field_name": "signature_content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "HTML或纯文本内容，自由文本描述，不同措辞可以等价"
        },
        {
          "field_name": "is_default",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配"
        }
      ]
    },
    "ScheduledEmail": {
      "schema_name": "ScheduledEmail",
      "instance_key": "scheduled_id",
      "fields": [
        {
          "field_name": "scheduled_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "draft_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以保证引用相同的草稿"
        },
        {
          "field_name": "scheduled_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间类型，表示发送时间，必须严格相等"
        },
        {
          "field_name": "is_sent",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否已发送，必须严格相等"
        },
        {
          "field_name": "is_cancelled",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否已取消，必须严格相等"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间类型，表示创建时间，必须严格相等"
        }
      ]
    },
    "OutOfOfficeConfig": {
      "schema_name": "OutOfOfficeConfig",
      "instance_key": "config_id",
      "fields": [
        {
          "field_name": "config_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "message",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自动回复消息内容是自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "start_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "开始日期属于日期时间类型，必须严格匹配"
        },
        {
          "field_name": "end_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "结束日期属于日期时间类型，必须严格匹配"
        },
        {
          "field_name": "reply_to_internal_only",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否仅回复内部发件人为布尔值，需精确匹配"
        },
        {
          "field_name": "is_active",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否激活为布尔值，需精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间为时间戳，需严格匹配"
        }
      ]
    }
  }
}