{
  "domain": "social_media_messaging",
  "databases": [
    {
      "table_name": "post",
      "description": "Stores community board posts with content, metadata, and engagement metrics",
      "schema": {
        "columns": [
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the post",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who created the post",
            "optional": false
          },
          {
            "name": "title",
            "type": "VARCHAR(200)",
            "description": "Title of the post",
            "optional": false
          },
          {
            "name": "content",
            "type": "TEXT",
            "description": "Main text content of the post",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the post was created",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "DATETIME",
            "description": "Timestamp when the post was last updated",
            "optional": true
          },
          {
            "name": "view_count",
            "type": "INTEGER",
            "description": "Number of times the post has been viewed",
            "default": "0",
            "optional": false
          },
          {
            "name": "like_count",
            "type": "INTEGER",
            "description": "Number of likes the post has received",
            "default": "0",
            "optional": false
          },
          {
            "name": "comment_count",
            "type": "INTEGER",
            "description": "Number of comments on the post",
            "default": "0",
            "optional": false
          },
          {
            "name": "is_pinned",
            "type": "BOOLEAN",
            "description": "Whether the post is pinned to the top",
            "default": "false",
            "optional": false
          },
          {
            "name": "pinned_at",
            "type": "DATETIME",
            "description": "Timestamp when the post was pinned",
            "optional": true
          },
          {
            "name": "is_locked",
            "type": "BOOLEAN",
            "description": "Whether the post is locked from further interactions",
            "default": "false",
            "optional": false
          },
          {
            "name": "locked_at",
            "type": "DATETIME",
            "description": "Timestamp when the post was locked",
            "optional": true
          },
          {
            "name": "lock_reason",
            "type": "TEXT",
            "description": "Reason for locking the post",
            "optional": true
          },
          {
            "name": "is_archived",
            "type": "BOOLEAN",
            "description": "Whether the post is archived",
            "default": "false",
            "optional": false
          },
          {
            "name": "archived_at",
            "type": "DATETIME",
            "description": "Timestamp when the post was archived",
            "optional": true
          },
          {
            "name": "is_deleted",
            "type": "BOOLEAN",
            "description": "Whether the post is deleted",
            "default": "false",
            "optional": false
          },
          {
            "name": "deleted_at",
            "type": "DATETIME",
            "description": "Timestamp when the post was deleted",
            "optional": true
          }
        ],
        "primary_key": "post_id"
      }
    },
    {
      "table_name": "post_tag",
      "description": "Stores tags associated with posts for categorization",
      "schema": {
        "columns": [
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the post",
            "optional": false,
            "references": "post.post_id"
          },
          {
            "name": "tag",
            "type": "VARCHAR(50)",
            "description": "Tag name",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the tag was added",
            "optional": false
          }
        ],
        "primary_key": "post_id"
      }
    },
    {
      "table_name": "comment",
      "description": "Stores comments made on posts",
      "schema": {
        "columns": [
          {
            "name": "comment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the comment",
            "optional": false
          },
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the post the comment belongs to",
            "optional": false,
            "references": "post.post_id"
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who created the comment",
            "optional": false
          },
          {
            "name": "content",
            "type": "TEXT",
            "description": "Text content of the comment",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the comment was created",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "DATETIME",
            "description": "Timestamp when the comment was last updated",
            "optional": true
          },
          {
            "name": "is_deleted",
            "type": "BOOLEAN",
            "description": "Whether the comment is deleted",
            "default": "false",
            "optional": false
          },
          {
            "name": "deleted_at",
            "type": "DATETIME",
            "description": "Timestamp when the comment was deleted",
            "optional": true
          }
        ],
        "primary_key": "comment_id"
      }
    },
    {
      "table_name": "post_like",
      "description": "Stores like relationships between users and posts",
      "schema": {
        "columns": [
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the liked post",
            "optional": false,
            "references": "post.post_id"
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who liked the post",
            "optional": false
          },
          {
            "name": "liked_at",
            "type": "DATETIME",
            "description": "Timestamp when the like was added",
            "optional": false
          }
        ],
        "primary_key": "post_id"
      }
    },
    {
      "table_name": "bookmark",
      "description": "Stores bookmark relationships between users and posts",
      "schema": {
        "columns": [
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the bookmarked post",
            "optional": false,
            "references": "post.post_id"
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who bookmarked the post",
            "optional": false
          },
          {
            "name": "bookmarked_at",
            "type": "DATETIME",
            "description": "Timestamp when the bookmark was added",
            "optional": false
          }
        ],
        "primary_key": "post_id"
      }
    },
    {
      "table_name": "user_follow",
      "description": "Stores follow relationships between users",
      "schema": {
        "columns": [
          {
            "name": "follower_user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who is following",
            "optional": false
          },
          {
            "name": "followed_user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user being followed",
            "optional": false
          },
          {
            "name": "followed_at",
            "type": "DATETIME",
            "description": "Timestamp when the follow relationship was created",
            "optional": false
          }
        ],
        "primary_key": "follower_user_id"
      }
    },
    {
      "table_name": "mention",
      "description": "Stores user mentions in posts and comments",
      "schema": {
        "columns": [
          {
            "name": "mention_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the mention",
            "optional": false
          },
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the post containing the mention",
            "optional": true,
            "references": "post.post_id"
          },
          {
            "name": "comment_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the comment containing the mention",
            "optional": true,
            "references": "comment.comment_id"
          },
          {
            "name": "mentioned_user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user being mentioned",
            "optional": false
          },
          {
            "name": "mentioned_at",
            "type": "DATETIME",
            "description": "Timestamp when the mention was created",
            "optional": false
          }
        ],
        "primary_key": "mention_id"
      }
    },
    {
      "table_name": "notification",
      "description": "Stores notifications for users about various activities",
      "schema": {
        "columns": [
          {
            "name": "notification_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the notification",
            "optional": false
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user receiving the notification",
            "optional": false
          },
          {
            "name": "type",
            "type": "VARCHAR(20)",
            "description": "Type of notification",
            "optional": false,
            "enum": [
              "mention",
              "like",
              "comment",
              "follow"
            ]
          },
          {
            "name": "content",
            "type": "TEXT",
            "description": "Notification message content",
            "optional": false
          },
          {
            "name": "related_post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of related post if applicable",
            "optional": true,
            "references": "post.post_id"
          },
          {
            "name": "related_comment_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of related comment if applicable",
            "optional": true,
            "references": "comment.comment_id"
          },
          {
            "name": "related_user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of related user if applicable",
            "optional": true
          },
          {
            "name": "is_read",
            "type": "BOOLEAN",
            "description": "Whether the notification has been read",
            "default": "false",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the notification was created",
            "optional": false
          },
          {
            "name": "read_at",
            "type": "DATETIME",
            "description": "Timestamp when the notification was read",
            "optional": true
          }
        ],
        "primary_key": "notification_id"
      }
    },
    {
      "table_name": "report",
      "description": "Stores reports submitted by users for posts or comments violating guidelines",
      "schema": {
        "columns": [
          {
            "name": "report_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the report",
            "optional": false
          },
          {
            "name": "reporter_user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user submitting the report",
            "optional": false
          },
          {
            "name": "post_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the reported post",
            "optional": true,
            "references": "post.post_id"
          },
          {
            "name": "comment_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the reported comment",
            "optional": true,
            "references": "comment.comment_id"
          },
          {
            "name": "reason",
            "type": "VARCHAR(50)",
            "description": "Reason for the report",
            "optional": false,
            "enum": [
              "spam",
              "harassment",
              "inappropriate_content",
              "misinformation",
              "other"
            ]
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Additional details about the report",
            "optional": true
          },
          {
            "name": "reported_at",
            "type": "DATETIME",
            "description": "Timestamp when the report was submitted",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current status of the report",
            "default": "pending",
            "optional": false
          }
        ],
        "primary_key": "report_id"
      }
    }
  ],
  "tools": [
    {
      "name": "mention_user_in_post",
      "description": "Mention one or more users in a post to notify them",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "notification_management",
      "action_category": "data_creation",
      "pre_condition": "Post must exist and mentioned users must be valid",
      "post_condition": "Mentions are recorded and notifications are sent to mentioned users",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post containing mentions",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "mentioned_user_ids": {
            "description": "List of user identifiers being mentioned",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "user_33333",
                "user_44444"
              ]
            ]
          }
        },
        "required": [
          "post_id",
          "mentioned_user_ids"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "mention_count": {
            "description": "Number of users successfully mentioned",
            "type": "integer",
            "examples": [
              2
            ]
          },
          "mentioned_at": {
            "description": "Timestamp when mentions were recorded in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 05:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "mention",
        "notification"
      ]
    },
    {
      "name": "get_user_following",
      "description": "Retrieve a list of users that a specific user is following",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "user_management",
      "action_category": "data_retrieval",
      "pre_condition": "User must exist in the system",
      "post_condition": "List of followed users is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Identifier of the user whose following list to retrieve",
            "type": "string",
            "examples": [
              "user_11111"
            ]
          },
          "limit": {
            "description": "Maximum number of followed users to retrieve",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "offset": {
            "description": "Number of followed users to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "following": {
            "description": "List of followed user objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "user_id": "user_22222",
                  "followed_at": "2024-01-16 03:00:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of users being followed",
            "type": "integer",
            "examples": [
              35
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "user_follow"
      ]
    },
    {
      "name": "extract_mentions_from_text",
      "description": "Extract all user mentions from text content",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "content_management",
      "action_category": "data_transformation",
      "pre_condition": "Text content must be provided",
      "post_condition": "List of extracted mentions is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "Text content to extract mentions from",
            "type": "string",
            "examples": [
              "Thanks @john and @mary for your feedback!"
            ]
          }
        },
        "required": [
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "mentions": {
            "description": "List of extracted usernames without the @ symbol",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "john",
                "mary"
              ]
            ]
          },
          "mention_count": {
            "description": "Total number of mentions found",
            "type": "integer",
            "examples": [
              2
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_user_bookmarks",
      "description": "Retrieve all posts that a user has bookmarked",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "bookmark_management",
      "action_category": "data_retrieval",
      "pre_condition": "User must exist in the system",
      "post_condition": "List of bookmarked posts is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Identifier of the user whose bookmarks to retrieve",
            "type": "string",
            "examples": [
              "user_55555"
            ]
          },
          "limit": {
            "description": "Maximum number of bookmarks to retrieve",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of bookmarks to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "bookmarks": {
            "description": "List of bookmarked post objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "bookmarked_at": "2024-01-16 01:00:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of bookmarked posts",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "bookmark",
        "post"
      ]
    },
    {
      "name": "lock_post",
      "description": "Lock a post to prevent further comments and interactions",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "state_management",
      "pre_condition": "Post must exist and user must have moderator permissions",
      "post_condition": "Post is locked and no new comments can be added",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to lock",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the moderator locking the post",
            "type": "string",
            "examples": [
              "moderator_11111"
            ]
          },
          "reason": {
            "description": "Optional reason for locking the post",
            "type": "string",
            "examples": [
              "Discussion has ended"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "locked_at": {
            "description": "Timestamp when the post was locked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 21:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "extract_hashtags_from_text",
      "description": "Extract all hashtags from text content",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "content_management",
      "action_category": "data_transformation",
      "pre_condition": "Text content must be provided",
      "post_condition": "List of extracted hashtags is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "Text content to extract hashtags from",
            "type": "string",
            "examples": [
              "Welcome to our #community! Let's #connect and #share ideas."
            ]
          }
        },
        "required": [
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "hashtags": {
            "description": "List of extracted hashtags without the # symbol",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "community",
                "connect",
                "share"
              ]
            ]
          },
          "hashtag_count": {
            "description": "Total number of hashtags found",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "sanitize_text_content",
      "description": "Remove or escape potentially harmful HTML/script tags from text content",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "content_management",
      "action_category": "data_transformation",
      "pre_condition": "Text content must be provided",
      "post_condition": "Sanitized text content is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "Text content to sanitize",
            "type": "string",
            "examples": [
              "Hello <script>alert('xss')</script> world!"
            ]
          },
          "allow_html": {
            "description": "Whether to allow safe HTML tags",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "sanitized_content": {
            "description": "Cleaned and safe text content",
            "type": "string",
            "examples": [
              "Hello  world!"
            ]
          },
          "removed_elements": {
            "description": "List of removed or escaped elements",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "script"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "remove_bookmark",
      "description": "Remove a post from a user's bookmarks",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "bookmark_management",
      "action_category": "data_deletion",
      "pre_condition": "Post must be currently bookmarked by the user",
      "post_condition": "Post is removed from user's bookmark list",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to unbookmark",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user removing the bookmark",
            "type": "string",
            "examples": [
              "user_55555"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "removed_at": {
            "description": "Timestamp when the bookmark was removed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 02:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "bookmark"
      ]
    },
    {
      "name": "get_post_details",
      "description": "Retrieve complete details of a specific post including title, content, author, timestamps, and engagement metrics",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_retrieval",
      "pre_condition": "Post must exist in the system",
      "post_condition": "Post details are returned to the requester",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to retrieve",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          }
        },
        "required": [
          "post_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the post author",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "title": {
            "description": "Title of the post",
            "type": "string",
            "examples": [
              "Welcome to our community!"
            ]
          },
          "content": {
            "description": "Text content of the post",
            "type": "string",
            "examples": [
              "This is a great place to share ideas."
            ]
          },
          "tags": {
            "description": "Tags associated with the post",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "announcement",
                "welcome"
              ]
            ]
          },
          "created_at": {
            "description": "Creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "updated_at": {
            "description": "Last update timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 11:00:00"
            ]
          },
          "view_count": {
            "description": "Number of times the post has been viewed",
            "type": "integer",
            "examples": [
              150
            ]
          },
          "like_count": {
            "description": "Number of likes the post has received",
            "type": "integer",
            "examples": [
              25
            ]
          },
          "comment_count": {
            "description": "Number of comments on the post",
            "type": "integer",
            "examples": [
              8
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "get_user_posts",
      "description": "Retrieve all posts created by a specific user",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_retrieval",
      "pre_condition": "User must exist in the system",
      "post_condition": "List of user's posts is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "limit": {
            "description": "Maximum number of posts to retrieve",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of posts to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of post objects created by the user",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "created_at": "2024-01-15 10:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of posts by the user",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "validate_post_content_length",
      "description": "Validate that post title and content meet length requirements",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "content_management",
      "action_category": "validation",
      "pre_condition": "Title and content must be provided",
      "post_condition": "Validation result indicating whether content meets requirements",
      "parameters": {
        "type": "object",
        "properties": {
          "title": {
            "description": "Post title to validate",
            "type": "string",
            "examples": [
              "Welcome to our community!"
            ]
          },
          "content": {
            "description": "Post content to validate",
            "type": "string",
            "examples": [
              "This is a great place to share ideas."
            ]
          },
          "min_title_length": {
            "description": "Minimum required title length",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "max_title_length": {
            "description": "Maximum allowed title length",
            "type": "integer",
            "examples": [
              200
            ]
          },
          "min_content_length": {
            "description": "Minimum required content length",
            "type": "integer",
            "examples": [
              10
            ]
          },
          "max_content_length": {
            "description": "Maximum allowed content length",
            "type": "integer",
            "examples": [
              10000
            ]
          }
        },
        "required": [
          "title",
          "content",
          "min_title_length",
          "max_title_length",
          "min_content_length",
          "max_content_length"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Boolean indicating whether content meets length requirements",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "validation_errors": {
            "description": "List of validation error messages if any",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "check_user_liked_post",
      "description": "Check whether a specific user has liked a particular post",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "engagement_management",
      "action_category": "data_retrieval",
      "pre_condition": "Post and user must exist",
      "post_condition": "Like status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user to check",
            "type": "string",
            "examples": [
              "user_99999"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_liked": {
            "description": "Boolean indicating whether the user has liked the post",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "liked_at": {
            "description": "Timestamp when the user liked the post in yyyy-mm-dd HH:MM:SS format, null if not liked",
            "type": "string",
            "examples": [
              "2024-01-15 17:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post_like"
      ]
    },
    {
      "name": "mark_all_notifications_as_read",
      "description": "Mark all notifications for a user as read",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "notification_management",
      "action_category": "state_management",
      "pre_condition": "User must exist in the system",
      "post_condition": "All user notifications are marked as read",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Identifier of the user whose notifications to mark as read",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "marked_count": {
            "description": "Number of notifications marked as read",
            "type": "integer",
            "examples": [
              3
            ]
          },
          "marked_at": {
            "description": "Timestamp when notifications were marked as read in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 08:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "notification"
      ]
    },
    {
      "name": "unlike_post",
      "description": "Remove a like from a post for a specific user",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "engagement_management",
      "action_category": "data_deletion",
      "pre_condition": "User must have previously liked the post",
      "post_condition": "Like is removed and post like count is decremented",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to unlike",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user unliking the post",
            "type": "string",
            "examples": [
              "user_99999"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "unliked_at": {
            "description": "Timestamp when the like was removed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 18:00:00"
            ]
          },
          "like_count": {
            "description": "Updated total like count for the post",
            "type": "integer",
            "examples": [
              25
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post_like",
        "post"
      ]
    },
    {
      "name": "get_recent_posts",
      "description": "Retrieve the most recently created posts on the community board",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_retrieval",
      "pre_condition": "Posts must exist in the system",
      "post_condition": "List of recent posts is returned in descending chronological order",
      "parameters": {
        "type": "object",
        "properties": {
          "limit": {
            "description": "Maximum number of posts to retrieve",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of posts to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of recent post objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "created_at": "2024-01-15 10:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of posts available",
            "type": "integer",
            "examples": [
              150
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "get_trending_posts",
      "description": "Retrieve posts that are currently trending based on engagement metrics",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_retrieval",
      "pre_condition": "System must have engagement data to calculate trends",
      "post_condition": "List of trending posts is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "time_window": {
            "description": "Time period to consider for trending calculation",
            "type": "string",
            "enum": [
              "1_hour",
              "6_hours",
              "24_hours",
              "7_days"
            ],
            "examples": [
              "24_hours"
            ]
          },
          "limit": {
            "description": "Maximum number of trending posts to return",
            "type": "integer",
            "examples": [
              10
            ]
          }
        },
        "required": [
          "time_window"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of trending post objects with engagement scores",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "trending_score": 87.5
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "get_user_notifications",
      "description": "Retrieve all notifications for a specific user including mentions, likes, and comments",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "notification_management",
      "action_category": "data_retrieval",
      "pre_condition": "User must exist in the system",
      "post_condition": "List of notifications is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Identifier of the user whose notifications to retrieve",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "notification_type": {
            "description": "Optional filter for specific notification types",
            "type": "string",
            "enum": [
              "all",
              "mention",
              "like",
              "comment",
              "follow"
            ],
            "examples": [
              "all"
            ]
          },
          "unread_only": {
            "description": "Whether to retrieve only unread notifications",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "limit": {
            "description": "Maximum number of notifications to retrieve",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of notifications to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "notifications": {
            "description": "List of notification objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "notification_id": "notif_11111",
                  "type": "mention",
                  "content": "You were mentioned in a post",
                  "created_at": "2024-01-16 05:00:00",
                  "is_read": false
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of notifications",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "unread_count": {
            "description": "Number of unread notifications",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "notification"
      ]
    },
    {
      "name": "mention_user_in_comment",
      "description": "Mention one or more users in a comment to notify them",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "notification_management",
      "action_category": "data_creation",
      "pre_condition": "Comment must exist and mentioned users must be valid",
      "post_condition": "Mentions are recorded and notifications are sent to mentioned users",
      "parameters": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "Unique identifier of the comment containing mentions",
            "type": "string",
            "examples": [
              "comment_11111"
            ]
          },
          "mentioned_user_ids": {
            "description": "List of user identifiers being mentioned",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "user_33333"
              ]
            ]
          }
        },
        "required": [
          "comment_id",
          "mentioned_user_ids"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "mention_count": {
            "description": "Number of users successfully mentioned",
            "type": "integer",
            "examples": [
              1
            ]
          },
          "mentioned_at": {
            "description": "Timestamp when mentions were recorded in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 06:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "mention",
        "notification"
      ]
    },
    {
      "name": "search_posts_by_tags",
      "description": "Find posts that have specific tags assigned to them",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "search_management",
      "action_category": "data_retrieval",
      "pre_condition": "At least one tag must be provided",
      "post_condition": "List of posts with matching tags is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "tags": {
            "description": "List of tags to search for",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "announcement",
                "welcome"
              ]
            ]
          },
          "match_all": {
            "description": "Whether to match all tags (true) or any tag (false)",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "limit": {
            "description": "Maximum number of results to return",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of results to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "tags"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of post objects with matching tags",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "tags": [
                    "announcement",
                    "welcome"
                  ]
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of matching posts",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post",
        "post_tag"
      ]
    },
    {
      "name": "search_posts_by_keyword",
      "description": "Search for posts containing specific keywords in title or content",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "search_management",
      "action_category": "data_retrieval",
      "pre_condition": "Search keyword must be provided",
      "post_condition": "List of matching posts is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "keyword": {
            "description": "Keyword or phrase to search for in posts",
            "type": "string",
            "examples": [
              "community"
            ]
          },
          "limit": {
            "description": "Maximum number of results to return",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of results to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "keyword"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of post objects matching the search",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "relevance_score": 0.95
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of matching posts",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "sort_posts_by_criteria",
      "description": "Sort a list of posts based on specified criteria and order",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_transformation",
      "pre_condition": "List of posts and valid sort criteria must be provided",
      "post_condition": "Sorted list of posts is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of post objects to sort",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_1",
                  "created_at": "2024-01-15 10:30:00",
                  "like_count": 25
                }
              ]
            ]
          },
          "sort_by": {
            "description": "Field to sort by",
            "type": "string",
            "enum": [
              "created_at",
              "updated_at",
              "like_count",
              "comment_count",
              "view_count"
            ],
            "examples": [
              "like_count"
            ]
          },
          "sort_order": {
            "description": "Sort order direction",
            "type": "string",
            "enum": [
              "ascending",
              "descending"
            ],
            "examples": [
              "descending"
            ]
          }
        },
        "required": [
          "posts",
          "sort_by",
          "sort_order"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of posts sorted according to criteria",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_1",
                  "created_at": "2024-01-15 10:30:00",
                  "like_count": 25
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_post_comments",
      "description": "Retrieve all comments associated with a specific post",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "comment_management",
      "action_category": "data_retrieval",
      "pre_condition": "Post must exist in the system",
      "post_condition": "List of comments is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "limit": {
            "description": "Maximum number of comments to retrieve",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "offset": {
            "description": "Number of comments to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "post_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "comments": {
            "description": "List of comment objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "comment_id": "comment_11111",
                  "user_id": "user_54321",
                  "content": "Great post!",
                  "created_at": "2024-01-15 14:00:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of comments on the post",
            "type": "integer",
            "examples": [
              8
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "comment"
      ]
    },
    {
      "name": "bookmark_post",
      "description": "Add a post to a user's bookmarks for easy access later",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "bookmark_management",
      "action_category": "data_creation",
      "pre_condition": "Post must exist and user must not have already bookmarked it",
      "post_condition": "Post is added to user's bookmark list",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to bookmark",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user bookmarking the post",
            "type": "string",
            "examples": [
              "user_55555"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "bookmarked_at": {
            "description": "Timestamp when the post was bookmarked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 01:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "bookmark"
      ]
    },
    {
      "name": "add_comment_to_post",
      "description": "Add a text comment to an existing post on the community board",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "comment_management",
      "action_category": "data_creation",
      "pre_condition": "Post must exist and user must have commenting permissions",
      "post_condition": "Comment is added to the post and visible to users",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to comment on",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user adding the comment",
            "type": "string",
            "examples": [
              "user_54321"
            ]
          },
          "content": {
            "description": "Text content of the comment",
            "type": "string",
            "examples": [
              "Great post! Thanks for sharing."
            ]
          }
        },
        "required": [
          "post_id",
          "user_id",
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "Unique identifier of the created comment",
            "type": "string",
            "examples": [
              "comment_11111"
            ]
          },
          "created_at": {
            "description": "Timestamp when the comment was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 14:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "comment",
        "post"
      ]
    },
    {
      "name": "pin_post",
      "description": "Pin a post to the top of the community board for increased visibility",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "state_management",
      "pre_condition": "Post must exist and user must have moderator permissions",
      "post_condition": "Post is marked as pinned and displayed at the top",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to pin",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the moderator pinning the post",
            "type": "string",
            "examples": [
              "moderator_11111"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "pinned_at": {
            "description": "Timestamp when the post was pinned in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 19:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "mark_notification_as_read",
      "description": "Mark a specific notification as read by the user",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "notification_management",
      "action_category": "state_management",
      "pre_condition": "Notification must exist and belong to the user",
      "post_condition": "Notification is marked as read",
      "parameters": {
        "type": "object",
        "properties": {
          "notification_id": {
            "description": "Unique identifier of the notification to mark as read",
            "type": "string",
            "examples": [
              "notif_11111"
            ]
          },
          "user_id": {
            "description": "Identifier of the user marking the notification",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "notification_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "read_at": {
            "description": "Timestamp when the notification was marked as read in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 07:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "notification"
      ]
    },
    {
      "name": "unpin_post",
      "description": "Remove the pinned status from a post",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "state_management",
      "pre_condition": "Post must be currently pinned and user must have moderator permissions",
      "post_condition": "Post is no longer pinned and returns to normal display order",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to unpin",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the moderator unpinning the post",
            "type": "string",
            "examples": [
              "moderator_11111"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "unpinned_at": {
            "description": "Timestamp when the post was unpinned in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 20:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "increment_post_view_count",
      "description": "Increment the view count of a post when it is accessed by a user",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "engagement_management",
      "action_category": "data_modification",
      "pre_condition": "Post must exist",
      "post_condition": "Post view count is incremented by one",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post being viewed",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Optional identifier of the user viewing the post",
            "type": "string",
            "examples": [
              "user_77777"
            ]
          }
        },
        "required": [
          "post_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "view_count": {
            "description": "Updated total view count for the post",
            "type": "integer",
            "examples": [
              151
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "calculate_user_activity_score",
      "description": "Calculate an activity score for a user based on their posts, comments, and engagement",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "user_management",
      "action_category": "computation",
      "pre_condition": "User activity data must be available",
      "post_condition": "Activity score is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "post_count": {
            "description": "Number of posts created by the user",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "comment_count": {
            "description": "Number of comments made by the user",
            "type": "integer",
            "examples": [
              42
            ]
          },
          "like_given_count": {
            "description": "Number of likes given by the user",
            "type": "integer",
            "examples": [
              120
            ]
          },
          "like_received_count": {
            "description": "Number of likes received on user's posts",
            "type": "integer",
            "examples": [
              85
            ]
          },
          "time_period_days": {
            "description": "Time period in days over which to calculate the score",
            "type": "integer",
            "examples": [
              30
            ]
          }
        },
        "required": [
          "post_count",
          "comment_count",
          "like_given_count",
          "like_received_count",
          "time_period_days"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "activity_score": {
            "description": "Calculated activity score for the user",
            "type": "number",
            "examples": [
              87.5
            ]
          },
          "activity_level": {
            "description": "Categorization of activity level",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "very_high"
            ],
            "examples": [
              "high"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "delete_post",
      "description": "Remove a post from the community board permanently",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_deletion",
      "pre_condition": "Post must exist and user must be the author or have deletion permissions",
      "post_condition": "Post is removed from the board and marked as deleted",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to delete",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user requesting deletion",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "deleted_at": {
            "description": "Timestamp when the post was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 13:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "get_post_engagement_summary",
      "description": "Calculate and retrieve aggregated engagement statistics for a post",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "engagement_management",
      "action_category": "data_analysis",
      "pre_condition": "Post must exist in the system",
      "post_condition": "Engagement summary with metrics is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          }
        },
        "required": [
          "post_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "view_count": {
            "description": "Total number of views",
            "type": "integer",
            "examples": [
              150
            ]
          },
          "like_count": {
            "description": "Total number of likes",
            "type": "integer",
            "examples": [
              25
            ]
          },
          "comment_count": {
            "description": "Total number of comments",
            "type": "integer",
            "examples": [
              8
            ]
          },
          "bookmark_count": {
            "description": "Total number of bookmarks",
            "type": "integer",
            "examples": [
              12
            ]
          },
          "engagement_rate": {
            "description": "Calculated engagement rate as a percentage",
            "type": "number",
            "examples": [
              30.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post",
        "post_like",
        "comment",
        "bookmark"
      ]
    },
    {
      "name": "get_all_tags",
      "description": "Retrieve a list of all unique tags used across the community board",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "tag_management",
      "action_category": "data_retrieval",
      "pre_condition": "System must have posts with tags",
      "post_condition": "List of all unique tags with usage counts is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "min_usage_count": {
            "description": "Minimum number of times a tag must be used to be included",
            "type": "integer",
            "examples": [
              1
            ]
          },
          "limit": {
            "description": "Maximum number of tags to return",
            "type": "integer",
            "examples": [
              100
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "tags": {
            "description": "List of tag objects with usage statistics",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "tag": "announcement",
                  "usage_count": 25
                },
                {
                  "tag": "welcome",
                  "usage_count": 18
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post_tag"
      ]
    },
    {
      "name": "report_comment",
      "description": "Submit a report flagging a comment for violating community guidelines",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "moderation_management",
      "action_category": "data_creation",
      "pre_condition": "Comment must exist and user must be authenticated",
      "post_condition": "Report is recorded and queued for moderator review",
      "parameters": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "Unique identifier of the comment being reported",
            "type": "string",
            "examples": [
              "comment_11111"
            ]
          },
          "reporter_user_id": {
            "description": "Identifier of the user submitting the report",
            "type": "string",
            "examples": [
              "user_88888"
            ]
          },
          "reason": {
            "description": "Reason for reporting the comment",
            "type": "string",
            "enum": [
              "spam",
              "harassment",
              "inappropriate_content",
              "misinformation",
              "other"
            ],
            "examples": [
              "harassment"
            ]
          },
          "description": {
            "description": "Additional details about the report",
            "type": "string",
            "examples": [
              "This comment contains offensive language"
            ]
          }
        },
        "required": [
          "comment_id",
          "reporter_user_id",
          "reason"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "report_id": {
            "description": "Unique identifier of the created report",
            "type": "string",
            "examples": [
              "report_33333"
            ]
          },
          "reported_at": {
            "description": "Timestamp when the report was submitted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 00:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "report"
      ]
    },
    {
      "name": "get_user_followers",
      "description": "Retrieve a list of users who follow a specific user",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "user_management",
      "action_category": "data_retrieval",
      "pre_condition": "User must exist in the system",
      "post_condition": "List of follower users is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Identifier of the user whose followers to retrieve",
            "type": "string",
            "examples": [
              "user_22222"
            ]
          },
          "limit": {
            "description": "Maximum number of followers to retrieve",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "offset": {
            "description": "Number of followers to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "followers": {
            "description": "List of follower user objects",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "user_id": "user_11111",
                  "followed_at": "2024-01-16 03:00:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of followers",
            "type": "integer",
            "examples": [
              120
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "user_follow"
      ]
    },
    {
      "name": "create_board_post",
      "description": "Create a new text post on the community board with title, content, and optional tags",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_creation",
      "pre_condition": "User must be authenticated and have posting permissions",
      "post_condition": "A new post is created and visible on the community board",
      "parameters": {
        "type": "object",
        "properties": {
          "user_id": {
            "description": "Unique identifier of the user creating the post",
            "type": "string",
            "examples": [
              "user_12345"
            ]
          },
          "title": {
            "description": "Title of the community board post",
            "type": "string",
            "examples": [
              "Welcome to our community!"
            ]
          },
          "content": {
            "description": "Main text content of the post",
            "type": "string",
            "examples": [
              "This is a great place to share ideas and connect with others."
            ]
          },
          "tags": {
            "description": "Optional tags for categorizing the post",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "announcement",
                "welcome"
              ]
            ]
          }
        },
        "required": [
          "user_id",
          "title",
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the created post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "created_at": {
            "description": "Timestamp when the post 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": [
        "post"
      ]
    },
    {
      "name": "restore_archived_post",
      "description": "Restore an archived post back to active status",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "state_management",
      "pre_condition": "Post must be in archived status and user must have restoration permissions",
      "post_condition": "Post is restored to active status",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the archived post to restore",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user restoring the post",
            "type": "string",
            "examples": [
              "moderator_11111"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "restored_at": {
            "description": "Timestamp when the post was restored in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "like_post",
      "description": "Add a like to a post from a specific user",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "engagement_management",
      "action_category": "data_creation",
      "pre_condition": "Post must exist and user must not have already liked the post",
      "post_condition": "Like is recorded and post like count is incremented",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to like",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the user liking the post",
            "type": "string",
            "examples": [
              "user_99999"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "liked_at": {
            "description": "Timestamp when the like was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 17:00:00"
            ]
          },
          "like_count": {
            "description": "Updated total like count for the post",
            "type": "integer",
            "examples": [
              26
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post_like",
        "post"
      ]
    },
    {
      "name": "unfollow_user",
      "description": "Unfollow a user to stop receiving updates about their posts",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "user_management",
      "action_category": "data_deletion",
      "pre_condition": "Follow relationship must currently exist",
      "post_condition": "Follow relationship is removed",
      "parameters": {
        "type": "object",
        "properties": {
          "follower_user_id": {
            "description": "Identifier of the user who wants to unfollow",
            "type": "string",
            "examples": [
              "user_11111"
            ]
          },
          "followed_user_id": {
            "description": "Identifier of the user to be unfollowed",
            "type": "string",
            "examples": [
              "user_22222"
            ]
          }
        },
        "required": [
          "follower_user_id",
          "followed_user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "unfollowed_at": {
            "description": "Timestamp when the follow relationship was removed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 04:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "user_follow"
      ]
    },
    {
      "name": "filter_posts_by_date_range",
      "description": "Retrieve posts created within a specific date range",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_retrieval",
      "pre_condition": "Valid date range must be provided",
      "post_condition": "List of posts within the date range is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "start_date": {
            "description": "Start date of the range in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date of the range in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-31"
            ]
          },
          "limit": {
            "description": "Maximum number of posts to retrieve",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "offset": {
            "description": "Number of posts to skip for pagination",
            "type": "integer",
            "examples": [
              0
            ]
          }
        },
        "required": [
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "posts": {
            "description": "List of post objects within the date range",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "post_id": "post_67890",
                  "title": "Welcome to our community!",
                  "created_at": "2024-01-15 10:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of posts in the date range",
            "type": "integer",
            "examples": [
              45
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "follow_user",
      "description": "Follow another user to receive updates about their posts",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "user_management",
      "action_category": "data_creation",
      "pre_condition": "Both users must exist and follower must not already be following the target",
      "post_condition": "Follow relationship is established",
      "parameters": {
        "type": "object",
        "properties": {
          "follower_user_id": {
            "description": "Identifier of the user who wants to follow",
            "type": "string",
            "examples": [
              "user_11111"
            ]
          },
          "followed_user_id": {
            "description": "Identifier of the user to be followed",
            "type": "string",
            "examples": [
              "user_22222"
            ]
          }
        },
        "required": [
          "follower_user_id",
          "followed_user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "followed_at": {
            "description": "Timestamp when the follow relationship was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 03:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "user_follow"
      ]
    },
    {
      "name": "archive_old_posts",
      "description": "Move posts older than a specified date to archived status",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "state_management",
      "pre_condition": "Archive date threshold must be provided and user must have archival permissions",
      "post_condition": "Matching posts are marked as archived",
      "parameters": {
        "type": "object",
        "properties": {
          "archive_before_date": {
            "description": "Archive posts created before this date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2023-12-31"
            ]
          },
          "user_id": {
            "description": "Identifier of the user performing the archival",
            "type": "string",
            "examples": [
              "moderator_11111"
            ]
          }
        },
        "required": [
          "archive_before_date",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "archived_count": {
            "description": "Number of posts archived",
            "type": "integer",
            "examples": [
              45
            ]
          },
          "archived_at": {
            "description": "Timestamp when archival was performed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 09:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "report_post",
      "description": "Submit a report flagging a post for violating community guidelines",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "moderation_management",
      "action_category": "data_creation",
      "pre_condition": "Post must exist and user must be authenticated",
      "post_condition": "Report is recorded and queued for moderator review",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post being reported",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "reporter_user_id": {
            "description": "Identifier of the user submitting the report",
            "type": "string",
            "examples": [
              "user_88888"
            ]
          },
          "reason": {
            "description": "Reason for reporting the post",
            "type": "string",
            "enum": [
              "spam",
              "harassment",
              "inappropriate_content",
              "misinformation",
              "other"
            ],
            "examples": [
              "spam"
            ]
          },
          "description": {
            "description": "Additional details about the report",
            "type": "string",
            "examples": [
              "This post contains advertising links"
            ]
          }
        },
        "required": [
          "post_id",
          "reporter_user_id",
          "reason"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "report_id": {
            "description": "Unique identifier of the created report",
            "type": "string",
            "examples": [
              "report_22222"
            ]
          },
          "reported_at": {
            "description": "Timestamp when the report was submitted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 23:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "report"
      ]
    },
    {
      "name": "unlock_post",
      "description": "Unlock a previously locked post to allow comments and interactions again",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "state_management",
      "pre_condition": "Post must be currently locked and user must have moderator permissions",
      "post_condition": "Post is unlocked and comments are enabled",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to unlock",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "user_id": {
            "description": "Identifier of the moderator unlocking the post",
            "type": "string",
            "examples": [
              "moderator_11111"
            ]
          }
        },
        "required": [
          "post_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "unlocked_at": {
            "description": "Timestamp when the post was unlocked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 22:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "add_tags_to_post",
      "description": "Add one or more tags to an existing post for better categorization",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "tag_management",
      "action_category": "data_modification",
      "pre_condition": "Post must exist and user must have permission to edit tags",
      "post_condition": "New tags are added to the post's tag list",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "tags": {
            "description": "List of tags to add to the post",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "tutorial",
                "beginner"
              ]
            ]
          }
        },
        "required": [
          "post_id",
          "tags"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "tags": {
            "description": "Complete list of tags after addition",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "announcement",
                "welcome",
                "tutorial",
                "beginner"
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post_tag"
      ]
    },
    {
      "name": "update_post_content",
      "description": "Modify the title and/or content of an existing post",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "post_management",
      "action_category": "data_modification",
      "pre_condition": "Post must exist and user must be the author or have edit permissions",
      "post_condition": "Post content is updated with new values",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post to update",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "title": {
            "description": "New title for the post",
            "type": "string",
            "examples": [
              "Updated: Welcome to our community!"
            ]
          },
          "content": {
            "description": "New content for the post",
            "type": "string",
            "examples": [
              "This is an updated message for our community."
            ]
          }
        },
        "required": [
          "post_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "updated_at": {
            "description": "Timestamp of the update in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 12:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post"
      ]
    },
    {
      "name": "delete_comment",
      "description": "Remove a comment from a post permanently",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "comment_management",
      "action_category": "data_deletion",
      "pre_condition": "Comment must exist and user must be the author or have deletion permissions",
      "post_condition": "Comment is removed from the post",
      "parameters": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "Unique identifier of the comment to delete",
            "type": "string",
            "examples": [
              "comment_11111"
            ]
          },
          "user_id": {
            "description": "Identifier of the user requesting deletion",
            "type": "string",
            "examples": [
              "user_54321"
            ]
          }
        },
        "required": [
          "comment_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "deleted_at": {
            "description": "Timestamp when the comment was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 16:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "comment"
      ]
    },
    {
      "name": "remove_tags_from_post",
      "description": "Remove one or more tags from a post",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "tag_management",
      "action_category": "data_modification",
      "pre_condition": "Post must exist and specified tags must be present on the post",
      "post_condition": "Specified tags are removed from the post",
      "parameters": {
        "type": "object",
        "properties": {
          "post_id": {
            "description": "Unique identifier of the post",
            "type": "string",
            "examples": [
              "post_67890"
            ]
          },
          "tags": {
            "description": "List of tags to remove from the post",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "welcome"
              ]
            ]
          }
        },
        "required": [
          "post_id",
          "tags"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "tags": {
            "description": "Complete list of tags after removal",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "announcement"
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "post_tag"
      ]
    },
    {
      "name": "update_comment",
      "description": "Modify the content of an existing comment",
      "group": "social_media_messaging.TextBased_Community_Board",
      "object_category": "comment_management",
      "action_category": "data_modification",
      "pre_condition": "Comment must exist and user must be the author or have edit permissions",
      "post_condition": "Comment content is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "Unique identifier of the comment to update",
            "type": "string",
            "examples": [
              "comment_11111"
            ]
          },
          "content": {
            "description": "New content for the comment",
            "type": "string",
            "examples": [
              "Updated: Great post! Thanks for sharing."
            ]
          }
        },
        "required": [
          "comment_id",
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "updated_at": {
            "description": "Timestamp of the update in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 15:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "comment"
      ]
    }
  ],
  "schema_classification": {
    "Post": {
      "schema_name": "Post",
      "instance_key": "post_id",
      "fields": [
        {
          "field_name": "post_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条帖子记录，通常由工具自动生成，每次执行都不同"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向用户实体，必须严格匹配"
        },
        {
          "field_name": "title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "帖子标题，自由文本，不同措辞可以表达相同含义"
        },
        {
          "field_name": "content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "帖子内容，自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间，时间戳字段，必须严格匹配"
        },
        {
          "field_name": "updated_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "更新时间，时间戳字段，必须严格匹配"
        },
        {
          "field_name": "view_count",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "浏览次数，数值字段，必须精确匹配"
        },
        {
          "field_name": "like_count",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "点赞数，数值字段，必须精确匹配"
        },
        {
          "field_name": "comment_count",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "评论数，数值字段，必须精确匹配"
        },
        {
          "field_name": "is_pinned",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否置顶，必须精确匹配"
        },
        {
          "field_name": "pinned_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "置顶时间，时间戳字段，必须精确匹配"
        },
        {
          "field_name": "is_locked",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否锁定，必须精确匹配"
        },
        {
          "field_name": "locked_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "锁定时间，时间戳字段，必须精确匹配"
        },
        {
          "field_name": "lock_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "锁定原因，自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "is_archived",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否归档，必须精确匹配"
        },
        {
          "field_name": "archived_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "归档时间，时间戳字段，必须精确匹配"
        },
        {
          "field_name": "is_deleted",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否删除，必须精确匹配"
        },
        {
          "field_name": "deleted_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "删除时间，时间戳字段，必须精确匹配"
        }
      ]
    },
    "PostTag": {
      "schema_name": "PostTag",
      "instance_key": "post_id",
      "fields": [
        {
          "field_name": "post_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "tag",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "标签名称，通常需要精确匹配，属于枚举或固定文本类型"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "必须精确匹配的日期时间字段"
        }
      ]
    },
    "Comment": {
      "schema_name": "Comment",
      "instance_key": "comment_id",
      "fields": [
        {
          "field_name": "comment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条评论，由系统随机生成，每次执行都不同"
        },
        {
          "field_name": "post_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配以确保评论属于同一个帖子"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配以确保评论者身份一致"
        },
        {
          "field_name": "content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本内容，不同措辞可能表达相同含义，需语义比较"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配评论创建时间"
        },
        {
          "field_name": "updated_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配最后更新时间"
        },
        {
          "field_name": "is_deleted",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，标记评论是否被删除，必须严格相等"
        },
        {
          "field_name": "deleted_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配删除时间"
        }
      ]
    },
    "PostLike": {
      "schema_name": "PostLike",
      "instance_key": "post_id",
      "fields": [
        {
          "field_name": "post_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "必须精确匹配的外键ID"
        },
        {
          "field_name": "liked_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "必须精确匹配的日期时间"
        }
      ]
    },
    "Bookmark": {
      "schema_name": "Bookmark",
      "instance_key": "post_id",
      "fields": [
        {
          "field_name": "post_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "用户ID为外键，必须严格匹配"
        },
        {
          "field_name": "bookmarked_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须严格匹配以确保操作时点一致"
        }
      ]
    },
    "UserFollow": {
      "schema_name": "UserFollow",
      "instance_key": "follower_user_id",
      "fields": [
        {
          "field_name": "follower_user_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "followed_user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "必须精确匹配的外键ID，代表被关注用户"
        },
        {
          "field_name": "followed_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "必须精确匹配的时间戳"
        }
      ]
    },
    "Mention": {
      "schema_name": "Mention",
      "instance_key": "mention_id",
      "fields": [
        {
          "field_name": "mention_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "post_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "必须精确匹配的外键ID，指向帖子"
        },
        {
          "field_name": "comment_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "必须精确匹配的外键ID，指向评论"
        },
        {
          "field_name": "mentioned_user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "必须精确匹配的外键ID，指向被提及的用户"
        },
        {
          "field_name": "mentioned_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "必须精确匹配的时间戳，代表提及创建的具体时间"
        }
      ]
    },
    "Notification": {
      "schema_name": "Notification",
      "instance_key": "notification_id",
      "fields": [
        {
          "field_name": "notification_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次生成都不同"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，通知类型必须严格相同"
        },
        {
          "field_name": "content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本内容，不同措辞可以表达同一通知"
        },
        {
          "field_name": "related_post_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "related_comment_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "related_user_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "is_read",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，是否已读必须完全一致"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        },
        {
          "field_name": "read_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        }
      ]
    },
    "Report": {
      "schema_name": "Report",
      "instance_key": "report_id",
      "fields": [
        {
          "field_name": "report_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识报告，由系统自动生成，每次不同"
        },
        {
          "field_name": "reporter_user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，指向报告人用户"
        },
        {
          "field_name": "post_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，可选，指向被举报的帖子，数值必须精确匹配"
        },
        {
          "field_name": "comment_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，可选，指向被举报的评论，数值必须精确匹配"
        },
        {
          "field_name": "reason",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，举报原因，必须严格相等"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本，补充说明，不同措辞可以表达相同含义"
        },
        {
          "field_name": "reported_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须严格相等"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "状态字符串，业务状态需精确匹配"
        }
      ]
    }
  }
}