{
  "domain": "knowledge_management",
  "databases": [
    {
      "table_name": "document",
      "description": "Stores document information including metadata, content, and status",
      "schema": {
        "columns": [
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the document",
            "optional": false
          },
          {
            "name": "title",
            "type": "VARCHAR(255)",
            "description": "Title of the document",
            "optional": false
          },
          {
            "name": "content",
            "type": "TEXT",
            "description": "Main content of the document",
            "optional": false
          },
          {
            "name": "author",
            "type": "VARCHAR(100)",
            "description": "Author name of the document",
            "optional": false
          },
          {
            "name": "category",
            "type": "VARCHAR(50)",
            "description": "Category of the document",
            "optional": true
          },
          {
            "name": "folder_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the folder containing the document",
            "optional": true,
            "references": "folder.folder_id"
          },
          {
            "name": "is_archived",
            "type": "BOOLEAN",
            "description": "Indicates whether the document is archived",
            "default": "false",
            "optional": false
          },
          {
            "name": "file_size",
            "type": "INTEGER",
            "description": "Size of the document in bytes",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the document was created",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the document was last updated",
            "optional": false
          },
          {
            "name": "archived_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the document was archived",
            "optional": true
          }
        ],
        "primary_key": "document_id"
      }
    },
    {
      "table_name": "document_tag",
      "description": "Stores tags associated with documents for categorization and search",
      "schema": {
        "columns": [
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "tag",
            "type": "VARCHAR(50)",
            "description": "Tag name for categorizing the document",
            "optional": false
          }
        ],
        "primary_key": "document_id"
      }
    },
    {
      "table_name": "document_version",
      "description": "Stores version history of documents",
      "schema": {
        "columns": [
          {
            "name": "version_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the version",
            "optional": false
          },
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the parent document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "version_number",
            "type": "VARCHAR(20)",
            "description": "Version number of the document",
            "optional": false
          },
          {
            "name": "content",
            "type": "TEXT",
            "description": "Content of this version",
            "optional": false
          },
          {
            "name": "version_note",
            "type": "TEXT",
            "description": "Note describing changes in this version",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the version was created",
            "optional": false
          }
        ],
        "primary_key": "version_id"
      }
    },
    {
      "table_name": "folder",
      "description": "Stores folder structure for organizing documents",
      "schema": {
        "columns": [
          {
            "name": "folder_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the folder",
            "optional": false
          },
          {
            "name": "folder_name",
            "type": "VARCHAR(255)",
            "description": "Name of the folder",
            "optional": false
          },
          {
            "name": "parent_folder_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the parent folder",
            "optional": true,
            "references": "folder.folder_id"
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Description of the folder purpose",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the folder was created",
            "optional": false
          }
        ],
        "primary_key": "folder_id"
      }
    },
    {
      "table_name": "document_permission",
      "description": "Stores access permissions for documents",
      "schema": {
        "columns": [
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user",
            "optional": false
          },
          {
            "name": "permission_level",
            "type": "VARCHAR(20)",
            "description": "Level of permission granted",
            "optional": false,
            "enum": [
              "read",
              "write",
              "admin"
            ]
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when permission was last updated",
            "optional": false
          }
        ],
        "primary_key": "document_id"
      }
    },
    {
      "table_name": "document_comment",
      "description": "Stores comments on documents",
      "schema": {
        "columns": [
          {
            "name": "comment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the comment",
            "optional": false
          },
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who added the comment",
            "optional": false
          },
          {
            "name": "comment_text",
            "type": "TEXT",
            "description": "Text content of the comment",
            "optional": false
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the comment was created",
            "optional": false
          }
        ],
        "primary_key": "comment_id"
      }
    },
    {
      "table_name": "document_template",
      "description": "Stores reusable document templates",
      "schema": {
        "columns": [
          {
            "name": "template_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the template",
            "optional": false
          },
          {
            "name": "template_name",
            "type": "VARCHAR(255)",
            "description": "Name of the template",
            "optional": false
          },
          {
            "name": "content_structure",
            "type": "TEXT",
            "description": "Structure or outline of the template content",
            "optional": false
          },
          {
            "name": "category",
            "type": "VARCHAR(50)",
            "description": "Category of the template",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the template was created",
            "optional": false
          }
        ],
        "primary_key": "template_id"
      }
    },
    {
      "table_name": "document_lock",
      "description": "Stores document lock information to prevent concurrent editing",
      "schema": {
        "columns": [
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the locked document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "user_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the user who locked the document",
            "optional": false
          },
          {
            "name": "locked_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the document was locked",
            "optional": false
          }
        ],
        "primary_key": "document_id"
      }
    },
    {
      "table_name": "document_link",
      "description": "Stores links between related documents",
      "schema": {
        "columns": [
          {
            "name": "link_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the link",
            "optional": false
          },
          {
            "name": "source_document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the source document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "target_document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the target document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "link_type",
            "type": "VARCHAR(20)",
            "description": "Type of relationship between documents",
            "optional": false,
            "enum": [
              "references",
              "related",
              "supersedes",
              "depends_on"
            ]
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the link was created",
            "optional": false
          }
        ],
        "primary_key": "link_id"
      }
    },
    {
      "table_name": "document_attachment",
      "description": "Stores attachments associated with documents",
      "schema": {
        "columns": [
          {
            "name": "attachment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the attachment",
            "optional": false
          },
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Identifier of the parent document",
            "optional": false,
            "references": "document.document_id"
          },
          {
            "name": "file_path",
            "type": "VARCHAR(500)",
            "description": "Path or URL to the attachment file",
            "optional": false
          },
          {
            "name": "file_name",
            "type": "VARCHAR(255)",
            "description": "Name of the attachment file",
            "optional": false
          },
          {
            "name": "file_type",
            "type": "VARCHAR(100)",
            "description": "MIME type of the attachment",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the attachment was added",
            "optional": false
          }
        ],
        "primary_key": "attachment_id"
      }
    }
  ],
  "tools": [
    {
      "name": "create_document",
      "description": "Create a new document with metadata including title, content, author, and tags",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_creation",
      "pre_condition": "User has permission to create documents",
      "post_condition": "Document is created and stored in the library",
      "parameters": {
        "type": "object",
        "properties": {
          "title": {
            "description": "The title of the document",
            "type": "string",
            "examples": [
              "Project Requirements Specification"
            ]
          },
          "content": {
            "description": "The main content of the document",
            "type": "string",
            "examples": [
              "This document outlines the requirements for the new system..."
            ]
          },
          "author": {
            "description": "The author name of the document",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "tags": {
            "description": "Tags for categorizing the document",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "project",
                "specification"
              ]
            ]
          },
          "category": {
            "description": "The category of the document",
            "type": "string",
            "examples": [
              "technical"
            ]
          }
        },
        "required": [
          "title",
          "content",
          "author"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the created document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "created_at": {
            "description": "The timestamp when the document 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": [
        "document",
        "document_tag"
      ]
    },
    {
      "name": "import_document",
      "description": "Import a document from an external file",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "import_export_management",
      "action_category": "data_creation",
      "pre_condition": "User has import permission",
      "post_condition": "Document is imported and created in the library",
      "parameters": {
        "type": "object",
        "properties": {
          "file_path": {
            "description": "The path or URL to the file to import",
            "type": "string",
            "examples": [
              "https://example.com/documents/file.docx"
            ]
          },
          "title": {
            "description": "The title for the imported document",
            "type": "string",
            "examples": [
              "Imported Requirements Document"
            ]
          },
          "author": {
            "description": "The author name for the imported document",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "format": {
            "description": "The format of the file being imported",
            "type": "string",
            "enum": [
              "pdf",
              "docx",
              "html",
              "markdown",
              "txt"
            ],
            "examples": [
              "docx"
            ]
          }
        },
        "required": [
          "file_path",
          "title",
          "author",
          "format"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the imported document",
            "type": "string",
            "examples": [
              "doc_12347"
            ]
          },
          "imported_at": {
            "description": "The timestamp when the document was imported in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 12:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "get_archived_documents",
      "description": "Retrieve all archived documents",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "None",
      "post_condition": "List of archived documents is returned",
      "parameters": {
        "type": "object",
        "properties": {},
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of archived documents",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12345",
                  "title": "Old Requirements",
                  "archived_at": "2024-01-18 10:00:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of archived documents",
            "type": "integer",
            "examples": [
              20
            ]
          }
        }
      },
      "raises": "Exception",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "create_document_template",
      "description": "Create a reusable document template",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "template_management",
      "action_category": "data_creation",
      "pre_condition": "User has permission to create templates",
      "post_condition": "Template is created and available for use",
      "parameters": {
        "type": "object",
        "properties": {
          "template_name": {
            "description": "The name of the template",
            "type": "string",
            "examples": [
              "Project Requirements Template"
            ]
          },
          "content_structure": {
            "description": "The structure/outline of the template content",
            "type": "string",
            "examples": [
              "1. Introduction\n2. Requirements\n3. Conclusion"
            ]
          },
          "category": {
            "description": "The category of the template",
            "type": "string",
            "examples": [
              "technical"
            ]
          }
        },
        "required": [
          "template_name",
          "content_structure"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "template_id": {
            "description": "The unique identifier of the created template",
            "type": "string",
            "examples": [
              "template_001"
            ]
          },
          "created_at": {
            "description": "The timestamp when the template was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 12:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "document_template"
      ]
    },
    {
      "name": "delete_folder",
      "description": "Delete a folder from the library",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_deletion",
      "pre_condition": "Folder exists and is empty or force delete is enabled",
      "post_condition": "Folder is removed from the library",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "The unique identifier of the folder",
            "type": "string",
            "examples": [
              "folder_002"
            ]
          },
          "force": {
            "description": "Whether to force delete non-empty folder",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "folder_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the deletion was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "deleted_at": {
            "description": "The timestamp when the folder was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 10:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "folder"
      ]
    },
    {
      "name": "export_document",
      "description": "Export a document to a specific format",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "import_export_management",
      "action_category": "data_transformation",
      "pre_condition": "Document exists",
      "post_condition": "Document is exported in the specified format",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "format": {
            "description": "The format to export the document to",
            "type": "string",
            "enum": [
              "pdf",
              "docx",
              "html",
              "markdown",
              "txt"
            ],
            "examples": [
              "pdf"
            ]
          }
        },
        "required": [
          "document_id",
          "format"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "export_url": {
            "description": "The URL or path to the exported file",
            "type": "string",
            "examples": [
              "https://storage.example.com/exports/doc_12345.pdf"
            ]
          },
          "exported_at": {
            "description": "The timestamp when the document was exported in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 11:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "calculate_document_reading_time",
      "description": "Estimate the reading time for a document based on word count",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "statistics_management",
      "action_category": "computation",
      "pre_condition": "None",
      "post_condition": "Reading time is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "word_count": {
            "description": "The total number of words in the document",
            "type": "integer",
            "examples": [
              1500
            ]
          },
          "reading_speed": {
            "description": "Average reading speed in words per minute",
            "type": "integer",
            "examples": [
              200
            ]
          }
        },
        "required": [
          "word_count"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reading_time_minutes": {
            "description": "Estimated reading time in minutes",
            "type": "number",
            "examples": [
              7.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_document_word_count",
      "description": "Calculate the total word count of a document's content",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "statistics_management",
      "action_category": "computation",
      "pre_condition": "None",
      "post_condition": "Word count is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "The text content to count words from",
            "type": "string",
            "examples": [
              "This is a sample document with multiple words in the content."
            ]
          }
        },
        "required": [
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "word_count": {
            "description": "The total number of words in the content",
            "type": "integer",
            "examples": [
              150
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "restore_archived_document",
      "description": "Restore an archived document to active status",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "state_management",
      "pre_condition": "Document is archived",
      "post_condition": "Document is restored to active status",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether restoration was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "restored_at": {
            "description": "The timestamp when the document was restored in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-19 11:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "delete_comment",
      "description": "Delete a comment from a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "comment_management",
      "action_category": "data_deletion",
      "pre_condition": "Comment exists and user is comment author or admin",
      "post_condition": "Comment is deleted",
      "parameters": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "The unique identifier of the comment",
            "type": "string",
            "examples": [
              "comment_001"
            ]
          }
        },
        "required": [
          "comment_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the deletion was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "deleted_at": {
            "description": "The timestamp when the comment was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 16:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_comment"
      ]
    },
    {
      "name": "move_document_to_folder",
      "description": "Move a document to a different folder",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "resource_transfer",
      "pre_condition": "Document and target folder exist",
      "post_condition": "Document is moved to the target folder",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "target_folder_id": {
            "description": "The identifier of the target folder",
            "type": "string",
            "examples": [
              "folder_002"
            ]
          }
        },
        "required": [
          "document_id",
          "target_folder_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the move was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "moved_at": {
            "description": "The timestamp when the document was moved in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 11:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "get_document_by_id",
      "description": "Retrieve a document by its unique identifier",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "Document exists in the library",
      "post_condition": "Document details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "title": {
            "description": "The title of the document",
            "type": "string",
            "examples": [
              "Project Requirements Specification"
            ]
          },
          "content": {
            "description": "The main content of the document",
            "type": "string",
            "examples": [
              "This document outlines the requirements..."
            ]
          },
          "author": {
            "description": "The author name of the document",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "tags": {
            "description": "Tags associated with the document",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "project"
              ]
            ]
          },
          "created_at": {
            "description": "The creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "updated_at": {
            "description": "The last update timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:20:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document",
        "document_tag"
      ]
    },
    {
      "name": "get_document_attachments",
      "description": "Retrieve all attachments for a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "Document exists",
      "post_condition": "List of attachments is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "attachments": {
            "description": "List of attachments for the document",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "attachment_id": "attach_001",
                  "file_name": "diagram.png",
                  "file_type": "image/png"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of attachments",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_attachment"
      ]
    },
    {
      "name": "get_folder_contents",
      "description": "Retrieve all documents and subfolders in a folder",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "Folder exists",
      "post_condition": "Folder contents are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "The unique identifier of the folder",
            "type": "string",
            "examples": [
              "folder_002"
            ]
          }
        },
        "required": [
          "folder_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of documents in the folder",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12345",
                  "title": "Requirements"
                }
              ]
            ]
          },
          "subfolders": {
            "description": "List of subfolders in the folder",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "folder_id": "folder_003",
                  "folder_name": "Archived"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "folder",
        "document"
      ]
    },
    {
      "name": "archive_document",
      "description": "Archive a document to move it out of active view",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "state_management",
      "pre_condition": "Document exists and user has archive permission",
      "post_condition": "Document is archived",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether archiving was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "archived_at": {
            "description": "The timestamp when the document was archived in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-18 10:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "remove_document_attachment",
      "description": "Remove an attachment from a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_deletion",
      "pre_condition": "Attachment exists and user has edit permission",
      "post_condition": "Attachment is removed from the document",
      "parameters": {
        "type": "object",
        "properties": {
          "attachment_id": {
            "description": "The unique identifier of the attachment",
            "type": "string",
            "examples": [
              "attach_001"
            ]
          }
        },
        "required": [
          "attachment_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the removal was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "removed_at": {
            "description": "The timestamp when the attachment was removed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-18 17:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_attachment"
      ]
    },
    {
      "name": "get_document_comments",
      "description": "Retrieve all comments for a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "comment_management",
      "action_category": "data_retrieval",
      "pre_condition": "Document exists",
      "post_condition": "List of comments is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "comments": {
            "description": "List of comments on the document",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "comment_id": "comment_001",
                  "user_id": "user_789",
                  "comment_text": "Needs clarification",
                  "created_at": "2024-01-16 15:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of comments",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_comment"
      ]
    },
    {
      "name": "add_tags_to_document",
      "description": "Add new tags to an existing document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "tag_management",
      "action_category": "data_modification",
      "pre_condition": "Document exists",
      "post_condition": "Tags are added to the document",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "tags": {
            "description": "List of tags to add",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "important",
                "reviewed"
              ]
            ]
          }
        },
        "required": [
          "document_id",
          "tags"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether tags were added successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "tags": {
            "description": "Complete list of tags after addition",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "project",
                "important",
                "reviewed"
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_tag"
      ]
    },
    {
      "name": "check_document_lock_status",
      "description": "Check if a document is currently locked",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "lock_management",
      "action_category": "validation",
      "pre_condition": "Document exists",
      "post_condition": "Lock status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_locked": {
            "description": "Indicates whether the document is locked",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "locked_by": {
            "description": "The identifier of the user who locked the document",
            "type": "string",
            "examples": [
              "user_789"
            ]
          },
          "locked_at": {
            "description": "The timestamp when the document was locked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_lock"
      ]
    },
    {
      "name": "duplicate_document",
      "description": "Create a duplicate copy of an existing document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_creation",
      "pre_condition": "Document exists and user has read permission",
      "post_condition": "Duplicate document is created",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document to duplicate",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "title": {
            "description": "The title for the duplicated document",
            "type": "string",
            "examples": [
              "Copy of Project Requirements Specification"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the duplicated document",
            "type": "string",
            "examples": [
              "doc_12348"
            ]
          },
          "created_at": {
            "description": "The timestamp when the duplicate was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 13:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document",
        "document_tag"
      ]
    },
    {
      "name": "create_folder",
      "description": "Create a new folder in the document library",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_creation",
      "pre_condition": "User has permission to create folders",
      "post_condition": "Folder is created in the library",
      "parameters": {
        "type": "object",
        "properties": {
          "folder_name": {
            "description": "The name of the folder",
            "type": "string",
            "examples": [
              "Project Documents"
            ]
          },
          "parent_folder_id": {
            "description": "The identifier of the parent folder, null for root level",
            "type": "string",
            "examples": [
              "folder_001"
            ]
          },
          "description": {
            "description": "Description of the folder purpose",
            "type": "string",
            "examples": [
              "Contains all project-related documents"
            ]
          }
        },
        "required": [
          "folder_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "folder_id": {
            "description": "The unique identifier of the created folder",
            "type": "string",
            "examples": [
              "folder_002"
            ]
          },
          "created_at": {
            "description": "The timestamp when the folder was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "folder"
      ]
    },
    {
      "name": "add_comment_to_document",
      "description": "Add a comment to a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "comment_management",
      "action_category": "data_creation",
      "pre_condition": "Document exists and user has read permission",
      "post_condition": "Comment is added to the document",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_id": {
            "description": "The identifier of the user adding the comment",
            "type": "string",
            "examples": [
              "user_789"
            ]
          },
          "comment_text": {
            "description": "The text content of the comment",
            "type": "string",
            "examples": [
              "This section needs clarification"
            ]
          }
        },
        "required": [
          "document_id",
          "user_id",
          "comment_text"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "comment_id": {
            "description": "The unique identifier of the created comment",
            "type": "string",
            "examples": [
              "comment_001"
            ]
          },
          "created_at": {
            "description": "The timestamp when the comment was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 15:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_comment"
      ]
    },
    {
      "name": "search_documents_by_keyword",
      "description": "Search documents by keyword in title or content",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "Search index is available",
      "post_condition": "List of matching documents is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "keyword": {
            "description": "The keyword to search for",
            "type": "string",
            "examples": [
              "requirements"
            ]
          },
          "search_field": {
            "description": "The field to search in",
            "type": "string",
            "enum": [
              "title",
              "content",
              "both"
            ],
            "examples": [
              "both"
            ]
          }
        },
        "required": [
          "keyword"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of documents matching the search criteria",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12345",
                  "title": "Project Requirements"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of matching documents",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "convert_document_format",
      "description": "Convert document content from one format to another",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "conversion_management",
      "action_category": "data_transformation",
      "pre_condition": "None",
      "post_condition": "Content is converted to target format",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "The content to convert",
            "type": "string",
            "examples": [
              "# Title\n## Section\nContent..."
            ]
          },
          "format": {
            "description": "The current format of the content",
            "type": "string",
            "enum": [
              "markdown",
              "html",
              "plain_text"
            ],
            "examples": [
              "markdown",
              "html"
            ]
          }
        },
        "required": [
          "content",
          "format"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "converted_content": {
            "description": "The content in the target format",
            "type": "string",
            "examples": [
              "<h1>Title</h1><h2>Section</h2><p>Content...</p>"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "unlock_document",
      "description": "Unlock a document to allow editing by others",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "lock_management",
      "action_category": "state_management",
      "pre_condition": "Document is locked by the user",
      "post_condition": "Document is unlocked",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_id": {
            "description": "The identifier of the user unlocking the document",
            "type": "string",
            "examples": [
              "user_789"
            ]
          }
        },
        "required": [
          "document_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the unlock was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "unlocked_at": {
            "description": "The timestamp when the document was unlocked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 15:00:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "document_lock"
      ]
    },
    {
      "name": "compare_document_versions",
      "description": "Compare two versions of a document and identify differences",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "comparison_management",
      "action_category": "data_analysis",
      "pre_condition": "None",
      "post_condition": "Comparison result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "The content of the original version",
            "type": "string",
            "examples": [
              "Original document content...",
              "Modified document content with changes..."
            ]
          }
        },
        "required": [
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "differences": {
            "description": "List of differences between the versions",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "type": "addition",
                  "text": "new paragraph"
                }
              ]
            ]
          },
          "similarity_score": {
            "description": "Similarity percentage between versions",
            "type": "number",
            "examples": [
              85.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "document",
        "document_version",
        "folder"
      ]
    },
    {
      "name": "add_document_attachment",
      "description": "Add an attachment file to a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_creation",
      "pre_condition": "Document exists and user has edit permission",
      "post_condition": "Attachment is added to the document",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "file_path": {
            "description": "The path or URL to the attachment file",
            "type": "string",
            "examples": [
              "https://storage.example.com/files/diagram.png"
            ]
          },
          "file_name": {
            "description": "The name of the attachment file",
            "type": "string",
            "examples": [
              "architecture_diagram.png"
            ]
          },
          "file_type": {
            "description": "The MIME type of the attachment",
            "type": "string",
            "examples": [
              "image/png"
            ]
          }
        },
        "required": [
          "document_id",
          "file_path",
          "file_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "attachment_id": {
            "description": "The unique identifier of the attachment",
            "type": "string",
            "examples": [
              "attach_001"
            ]
          },
          "created_at": {
            "description": "The timestamp when the attachment was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 16:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_attachment"
      ]
    },
    {
      "name": "get_recently_modified_documents",
      "description": "Retrieve documents that were recently modified",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "None",
      "post_condition": "List of recently modified documents is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "limit": {
            "description": "Maximum number of documents to return",
            "type": "integer",
            "examples": [
              10
            ]
          },
          "days": {
            "description": "Number of days to look back for modifications",
            "type": "integer",
            "examples": [
              7
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of recently modified documents",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12345",
                  "title": "Requirements",
                  "updated_at": "2024-01-16 14:20:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of documents found",
            "type": "integer",
            "examples": [
              25
            ]
          }
        }
      },
      "raises": "Exception",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "get_documents_by_author",
      "description": "Retrieve all documents created by a specific author",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "None",
      "post_condition": "List of documents by the author is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "author": {
            "description": "The author name to filter by",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          }
        },
        "required": [
          "author"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of documents by the specified author",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12345",
                  "title": "Project Requirements"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of documents by the author",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "Exception",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "restore_document_version",
      "description": "Restore a document to a specific version",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "version_management",
      "action_category": "data_modification",
      "pre_condition": "Document and version exist",
      "post_condition": "Document is restored to the specified version",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "version_id": {
            "description": "The unique identifier of the version to restore",
            "type": "string",
            "examples": [
              "ver_67890"
            ]
          }
        },
        "required": [
          "document_id",
          "version_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the restoration was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "restored_at": {
            "description": "The timestamp when the document was restored in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-19 09:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document",
        "document_version"
      ]
    },
    {
      "name": "revoke_document_access",
      "description": "Revoke a user's access to a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "permission_management",
      "action_category": "authorization",
      "pre_condition": "Document exists and user has admin permission",
      "post_condition": "User access is revoked",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_id": {
            "description": "The identifier of the user whose access to revoke",
            "type": "string",
            "examples": [
              "user_789"
            ]
          }
        },
        "required": [
          "document_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether access was revoked successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "revoked_at": {
            "description": "The timestamp when access was revoked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 14:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_permission"
      ]
    },
    {
      "name": "delete_document",
      "description": "Delete a document from the library",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_deletion",
      "pre_condition": "Document exists and user has delete permission",
      "post_condition": "Document is removed from the library",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document to delete",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the deletion was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "deleted_at": {
            "description": "The timestamp when the document was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 09:15:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "remove_document_link",
      "description": "Remove a link between two documents",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "link_management",
      "action_category": "data_deletion",
      "pre_condition": "Link exists between the documents",
      "post_condition": "Link is removed",
      "parameters": {
        "type": "object",
        "properties": {
          "link_id": {
            "description": "The unique identifier of the link",
            "type": "string",
            "examples": [
              "link_001"
            ]
          }
        },
        "required": [
          "link_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the link was removed successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "removed_at": {
            "description": "The timestamp when the link was removed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-18 15:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_link"
      ]
    },
    {
      "name": "update_document_title",
      "description": "Update the title of an existing document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_modification",
      "pre_condition": "Document exists and user has edit permission",
      "post_condition": "Document title is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "title": {
            "description": "The new title for the document",
            "type": "string",
            "examples": [
              "Updated Project Requirements Specification"
            ]
          }
        },
        "required": [
          "document_id",
          "title"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "The timestamp when the title was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 09:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "share_document_with_users",
      "description": "Share a document with multiple users",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "sharing_management",
      "action_category": "authorization",
      "pre_condition": "Document exists and user has share permission",
      "post_condition": "Document is shared with specified users",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_ids": {
            "description": "List of user identifiers to share with",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "user_789",
                "user_790"
              ]
            ]
          },
          "permission_level": {
            "description": "The permission level to grant",
            "type": "string",
            "enum": [
              "read",
              "write"
            ],
            "examples": [
              "read"
            ]
          },
          "message": {
            "description": "Optional message to include with the share",
            "type": "string",
            "examples": [
              "Please review this document"
            ]
          }
        },
        "required": [
          "document_id",
          "user_ids",
          "permission_level"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether sharing was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "shared_with_count": {
            "description": "Number of users the document was shared with",
            "type": "integer",
            "examples": [
              2
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_permission"
      ]
    },
    {
      "name": "get_document_version_history",
      "description": "Retrieve the version history of a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "version_management",
      "action_category": "data_retrieval",
      "pre_condition": "Document exists",
      "post_condition": "Version history is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "versions": {
            "description": "List of all versions of the document",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "version_id": "ver_67890",
                  "version_number": "2.0",
                  "created_at": "2024-01-18 11:00:00"
                }
              ]
            ]
          },
          "total_versions": {
            "description": "Total number of versions",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_version"
      ]
    },
    {
      "name": "get_linked_documents",
      "description": "Retrieve all documents linked to a specific document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "link_management",
      "action_category": "data_retrieval",
      "pre_condition": "Document exists",
      "post_condition": "List of linked documents is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "link_type": {
            "description": "Optional filter for specific link type",
            "type": "string",
            "enum": [
              "references",
              "related",
              "supersedes",
              "depends_on"
            ],
            "examples": [
              "references"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "linked_documents": {
            "description": "List of documents linked to the specified document",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12346",
                  "title": "Related Document",
                  "link_type": "references"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of linked documents",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_link"
      ]
    },
    {
      "name": "lock_document",
      "description": "Lock a document to prevent concurrent editing",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "lock_management",
      "action_category": "state_management",
      "pre_condition": "Document exists and is not already locked",
      "post_condition": "Document is locked for editing by the user",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_id": {
            "description": "The identifier of the user locking the document",
            "type": "string",
            "examples": [
              "user_789"
            ]
          }
        },
        "required": [
          "document_id",
          "user_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the lock was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "locked_at": {
            "description": "The timestamp when the document was locked in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:00:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "document_lock"
      ]
    },
    {
      "name": "validate_document_format",
      "description": "Validate if document content follows a specific format or structure",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "validation_management",
      "action_category": "validation",
      "pre_condition": "None",
      "post_condition": "Validation result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "content": {
            "description": "The document content to validate",
            "type": "string",
            "examples": [
              "# Title\n## Section 1\nContent here..."
            ]
          },
          "format": {
            "description": "The expected format type",
            "type": "string",
            "enum": [
              "markdown",
              "html",
              "plain_text"
            ],
            "examples": [
              "markdown"
            ]
          }
        },
        "required": [
          "content",
          "format"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Indicates whether the content is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "validation_errors": {
            "description": "List of validation errors if any",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Missing required heading"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_document_metadata",
      "description": "Retrieve metadata information of a document without content",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "Document exists",
      "post_condition": "Document metadata is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          }
        },
        "required": [
          "document_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "title": {
            "description": "The title of the document",
            "type": "string",
            "examples": [
              "Project Requirements Specification"
            ]
          },
          "author": {
            "description": "The author name of the document",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "tags": {
            "description": "Tags associated with the document",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "project"
              ]
            ]
          },
          "created_at": {
            "description": "The creation timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "updated_at": {
            "description": "The last update timestamp in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:20:00"
            ]
          },
          "file_size": {
            "description": "The size of the document in bytes",
            "type": "integer",
            "examples": [
              15360
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document",
        "document_tag"
      ]
    },
    {
      "name": "search_documents_by_tags",
      "description": "Search documents by one or more tags",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_retrieval",
      "pre_condition": "None",
      "post_condition": "List of matching documents is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "tags": {
            "description": "List of tags to search for",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "project"
              ]
            ]
          },
          "match_mode": {
            "description": "Whether to match all tags or any tag",
            "type": "string",
            "enum": [
              "all",
              "any"
            ],
            "examples": [
              "all"
            ]
          }
        },
        "required": [
          "tags"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of documents matching the tag criteria",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "doc_12345",
                  "title": "Project Requirements"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of matching documents",
            "type": "integer",
            "examples": [
              8
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "document",
        "document_tag"
      ]
    },
    {
      "name": "set_document_permission",
      "description": "Set access permissions for a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "permission_management",
      "action_category": "authorization",
      "pre_condition": "Document exists and user has admin permission",
      "post_condition": "Document permissions are updated",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_id": {
            "description": "The identifier of the user to grant permission",
            "type": "string",
            "examples": [
              "user_789"
            ]
          },
          "permission_level": {
            "description": "The level of permission to grant",
            "type": "string",
            "enum": [
              "read",
              "write",
              "admin"
            ],
            "examples": [
              "read"
            ]
          }
        },
        "required": [
          "document_id",
          "user_id",
          "permission_level"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether permission was set successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "The timestamp when permission was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 13:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_permission"
      ]
    },
    {
      "name": "update_document_content",
      "description": "Update the content of an existing document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_modification",
      "pre_condition": "Document exists and user has edit permission",
      "post_condition": "Document content is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "content": {
            "description": "The new content to replace the existing content",
            "type": "string",
            "examples": [
              "Updated requirements for the project..."
            ]
          }
        },
        "required": [
          "document_id",
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "The timestamp when the document was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:20:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document"
      ]
    },
    {
      "name": "create_document_version",
      "description": "Create a new version of an existing document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "version_management",
      "action_category": "data_creation",
      "pre_condition": "Document exists",
      "post_condition": "New version is created and linked to the document",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "content": {
            "description": "The content of the new version",
            "type": "string",
            "examples": [
              "Version 2.0 of the requirements document..."
            ]
          },
          "version_note": {
            "description": "Note describing the changes in this version",
            "type": "string",
            "examples": [
              "Updated section 3 with new requirements"
            ]
          }
        },
        "required": [
          "document_id",
          "content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "version_id": {
            "description": "The unique identifier of the created version",
            "type": "string",
            "examples": [
              "ver_67890"
            ]
          },
          "version_number": {
            "description": "The version number",
            "type": "string",
            "examples": [
              "2.0"
            ]
          },
          "created_at": {
            "description": "The timestamp when the version was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-18 11:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_version"
      ]
    },
    {
      "name": "create_document_from_template",
      "description": "Create a new document based on a template",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "document_management",
      "action_category": "data_creation",
      "pre_condition": "Template exists",
      "post_condition": "Document is created from template",
      "parameters": {
        "type": "object",
        "properties": {
          "template_id": {
            "description": "The unique identifier of the template",
            "type": "string",
            "examples": [
              "template_001"
            ]
          },
          "title": {
            "description": "The title of the new document",
            "type": "string",
            "examples": [
              "New Project Requirements"
            ]
          },
          "author": {
            "description": "The author name of the document",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          }
        },
        "required": [
          "template_id",
          "title",
          "author"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the created document",
            "type": "string",
            "examples": [
              "doc_12346"
            ]
          },
          "created_at": {
            "description": "The timestamp when the document was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_template",
        "document"
      ]
    },
    {
      "name": "get_all_templates",
      "description": "Retrieve all available document templates",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "template_management",
      "action_category": "data_retrieval",
      "pre_condition": "None",
      "post_condition": "List of templates is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "category": {
            "description": "Optional category filter for templates",
            "type": "string",
            "examples": [
              "technical"
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "templates": {
            "description": "List of available templates",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "template_id": "template_001",
                  "template_name": "Project Requirements Template"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of templates",
            "type": "integer",
            "examples": [
              10
            ]
          }
        }
      },
      "raises": "Exception",
      "tool_type": "READ",
      "related_databases": [
        "document_template"
      ]
    },
    {
      "name": "create_document_link",
      "description": "Create a link between two related documents",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "link_management",
      "action_category": "data_creation",
      "pre_condition": "Both documents exist",
      "post_condition": "Link is created between the documents",
      "parameters": {
        "type": "object",
        "properties": {
          "source_document_id": {
            "description": "The identifier of the source document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "target_document_id": {
            "description": "The identifier of the target document",
            "type": "string",
            "examples": [
              "doc_12346"
            ]
          },
          "link_type": {
            "description": "The type of relationship between documents",
            "type": "string",
            "enum": [
              "references",
              "related",
              "supersedes",
              "depends_on"
            ],
            "examples": [
              "references"
            ]
          }
        },
        "required": [
          "source_document_id",
          "target_document_id",
          "link_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "link_id": {
            "description": "The unique identifier of the created link",
            "type": "string",
            "examples": [
              "link_001"
            ]
          },
          "created_at": {
            "description": "The timestamp when the link was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-17 14:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_link"
      ]
    },
    {
      "name": "remove_tags_from_document",
      "description": "Remove specific tags from a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "tag_management",
      "action_category": "data_modification",
      "pre_condition": "Document exists and has the specified tags",
      "post_condition": "Specified tags are removed from the document",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "tags": {
            "description": "List of tags to remove",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "draft"
              ]
            ]
          }
        },
        "required": [
          "document_id",
          "tags"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether tags were removed successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "tags": {
            "description": "Complete list of tags after removal",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "requirements",
                "project"
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_tag"
      ]
    },
    {
      "name": "check_document_permission",
      "description": "Check if a user has specific permission for a document",
      "group": "knowledge_management.Document_Library_System",
      "object_category": "permission_management",
      "action_category": "validation",
      "pre_condition": "Document and user exist",
      "post_condition": "Permission status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "The unique identifier of the document",
            "type": "string",
            "examples": [
              "doc_12345"
            ]
          },
          "user_id": {
            "description": "The identifier of the user",
            "type": "string",
            "examples": [
              "user_789"
            ]
          },
          "permission_level": {
            "description": "The permission level to check",
            "type": "string",
            "enum": [
              "read",
              "write",
              "admin"
            ],
            "examples": [
              "read"
            ]
          }
        },
        "required": [
          "document_id",
          "user_id",
          "permission_level"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "has_permission": {
            "description": "Indicates whether the user has the specified permission",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "document_permission"
      ]
    }
  ],
  "schema_classification": {
    "Document": {
      "schema_name": "Document",
      "instance_key": "document_id",
      "fields": [
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具随机生成，每次执行都不同"
        },
        {
          "field_name": "title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "文档标题为自由文本，不同措辞可能等价"
        },
        {
          "field_name": "content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "文档正文为自由文本描述，不同措辞可能表达相同含义"
        },
        {
          "field_name": "author",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "作者名为人名，不同写法或格式可能语义相同"
        },
        {
          "field_name": "category",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "分类为自然语言短语，不同措辞可能表达相同类别"
        },
        {
          "field_name": "folder_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用相同文件夹"
        },
        {
          "field_name": "is_archived",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，归档状态必须完全一致"
        },
        {
          "field_name": "file_size",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型字段，文档大小需要严格匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，创建时间必须严格一致"
        },
        {
          "field_name": "updated_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，更新时间必须严格一致"
        },
        {
          "field_name": "archived_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，归档时间必须严格一致"
        }
      ]
    },
    "DocumentTag": {
      "schema_name": "DocumentTag",
      "instance_key": "document_id",
      "fields": [
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "tag",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "标签名属于枚举或分类字段，需要精确匹配"
        }
      ]
    },
    "DocumentVersion": {
      "schema_name": "DocumentVersion",
      "instance_key": "version_id",
      "fields": [
        {
          "field_name": "version_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每个版本，由工具随机生成，每次执行都不同"
        },
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "必须精确匹配的外键ID，引用父文档"
        },
        {
          "field_name": "version_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "必须精确匹配的版本号，版本号的微小差异很重要"
        },
        {
          "field_name": "content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本内容，不同措辞可以表达相同含义"
        },
        {
          "field_name": "version_note",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "备注和描述性文本，不同措辞可以表达等价意思"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "必须精确匹配的时间戳，记录版本创建时间"
        }
      ]
    },
    "Folder": {
      "schema_name": "Folder",
      "instance_key": "folder_id",
      "fields": [
        {
          "field_name": "folder_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "folder_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "文件夹名称，可能存在同义或细微措辞差异但业务上等价"
        },
        {
          "field_name": "parent_folder_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格对应父文件夹"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，必须精确匹配"
        }
      ]
    },
    "DocumentPermission": {
      "schema_name": "DocumentPermission",
      "instance_key": "document_id",
      "fields": [
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，对用户的唯一标识，必须精确匹配"
        },
        {
          "field_name": "permission_level",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示权限级别，必须精确匹配"
        },
        {
          "field_name": "updated_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，必须精确匹配"
        }
      ]
    },
    "DocumentComment": {
      "schema_name": "DocumentComment",
      "instance_key": "comment_id",
      "fields": [
        {
          "field_name": "comment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次生成唯一标识，工具随机生成，比较时应忽略"
        },
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向具体文档，必须精确匹配"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向用户，必须精确匹配"
        },
        {
          "field_name": "comment_text",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，代表评论创建时间，必须精确匹配"
        }
      ]
    },
    "DocumentTemplate": {
      "schema_name": "DocumentTemplate",
      "instance_key": "template_id",
      "fields": [
        {
          "field_name": "template_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键。每个模板的唯一标识符，通常由系统随机生成，比较时应忽略。"
        },
        {
          "field_name": "template_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "模板名称属于自由文本（如人名、公司名），不同措辞可能表达相同含义，应进行语义比较。"
        },
        {
          "field_name": "content_structure",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "模板内容结构为自由文本描述，不同表达可能等价，应进行语义比较。"
        },
        {
          "field_name": "category",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "模板分类为自由文本（如业务类型、类别），可能存在不同但等价的表述，应进行语义比较。"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，需精确匹配以保证数据状态一致性。"
        }
      ]
    },
    "DocumentLock": {
      "schema_name": "DocumentLock",
      "instance_key": "document_id",
      "fields": [
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "user_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "locked_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，必须严格匹配"
        }
      ]
    },
    "DocumentLink": {
      "schema_name": "DocumentLink",
      "instance_key": "link_id",
      "fields": [
        {
          "field_name": "link_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条记录，随机生成，每次执行都不同"
        },
        {
          "field_name": "source_document_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的文档一致"
        },
        {
          "field_name": "target_document_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的文档一致"
        },
        {
          "field_name": "link_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示文档之间的关系类型，需严格匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，创建时间需精确匹配"
        }
      ]
    },
    "DocumentAttachment": {
      "schema_name": "DocumentAttachment",
      "instance_key": "attachment_id",
      "fields": [
        {
          "field_name": "attachment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键；由系统随机生成，每次执行可能不同"
        },
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以保证关联正确"
        },
        {
          "field_name": "file_path",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "文件路径或URL，任何差异都代表不同的文件位置"
        },
        {
          "field_name": "file_name",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "文件名，必须精确匹配否则指向不同文件"
        },
        {
          "field_name": "file_type",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "MIME类型，定义文件格式，任何差异都影响文件解析"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，表示添加时间，需精确匹配"
        }
      ]
    }
  }
}