{
  "domain": "job_seeking",
  "databases": [
    {
      "table_name": "job_application",
      "description": "Core table storing all job application records with applicant information, job details, and application status",
      "schema": {
        "columns": [
          {
            "name": "application_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the job application",
            "optional": false
          },
          {
            "name": "applicant_name",
            "type": "VARCHAR(100)",
            "description": "Full name of the job applicant",
            "optional": false
          },
          {
            "name": "email",
            "type": "VARCHAR(100)",
            "description": "Email address of the applicant",
            "optional": false
          },
          {
            "name": "phone",
            "type": "VARCHAR(20)",
            "description": "Phone number of the applicant",
            "optional": true
          },
          {
            "name": "job_title",
            "type": "VARCHAR(200)",
            "description": "Title of the job position being applied for",
            "optional": false
          },
          {
            "name": "company_name",
            "type": "VARCHAR(200)",
            "description": "Name of the company",
            "optional": false
          },
          {
            "name": "application_date",
            "type": "DATETIME",
            "description": "Date and time when the application was submitted",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(50)",
            "description": "Current status of the application (e.g., submitted, under_review, rejected, accepted, withdrawn, archived)",
            "enum": [
              "submitted",
              "under_review",
              "rejected",
              "accepted",
              "withdrawn",
              "archived"
            ],
            "default": "submitted",
            "optional": false
          },
          {
            "name": "resume_content",
            "type": "TEXT",
            "description": "Text content of the resume",
            "optional": true
          },
          {
            "name": "resume_format",
            "type": "VARCHAR(10)",
            "description": "Format of the resume document (e.g., pdf, docx)",
            "enum": [
              "pdf",
              "docx",
              "doc",
              "txt"
            ],
            "optional": true
          },
          {
            "name": "resume_uploaded_at",
            "type": "DATETIME",
            "description": "Timestamp when the resume was uploaded",
            "optional": true
          },
          {
            "name": "cover_letter_content",
            "type": "TEXT",
            "description": "Text content of the cover letter",
            "optional": true
          },
          {
            "name": "cover_letter_uploaded_at",
            "type": "DATETIME",
            "description": "Timestamp when the cover letter was uploaded",
            "optional": true
          },
          {
            "name": "deadline_date",
            "type": "DATETIME",
            "description": "Follow-up or response deadline for the application",
            "optional": true
          },
          {
            "name": "deadline_type",
            "type": "VARCHAR(50)",
            "description": "Type of deadline (e.g., follow_up, response)",
            "enum": [
              "follow_up",
              "response",
              "application_deadline"
            ],
            "optional": true
          },
          {
            "name": "referral_source",
            "type": "VARCHAR(100)",
            "description": "Source of the job referral (e.g., LinkedIn, Indeed, employee referral)",
            "optional": true
          },
          {
            "name": "referral_person",
            "type": "VARCHAR(100)",
            "description": "Name of person who referred the applicant",
            "optional": true
          },
          {
            "name": "priority_level",
            "type": "INTEGER",
            "description": "Priority level of the application (1-5, where 5 is highest)",
            "optional": true
          },
          {
            "name": "priority_reason",
            "type": "TEXT",
            "description": "Reason for the assigned priority level",
            "optional": true
          },
          {
            "name": "expected_salary_min",
            "type": "DECIMAL(12,2)",
            "description": "Minimum expected salary",
            "optional": true
          },
          {
            "name": "expected_salary_max",
            "type": "DECIMAL(12,2)",
            "description": "Maximum expected salary",
            "optional": true
          },
          {
            "name": "salary_currency",
            "type": "VARCHAR(10)",
            "description": "Currency for salary expectations (e.g., USD, EUR)",
            "enum": [
              "USD",
              "EUR",
              "GBP",
              "JPY",
              "CNY",
              "AUD",
              "CAD"
            ],
            "default": "USD",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the record was created",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "DATETIME",
            "description": "Timestamp when the record was last updated",
            "optional": true
          }
        ],
        "primary_key": "application_id"
      }
    },
    {
      "table_name": "application_note",
      "description": "Table storing notes and comments associated with job applications for tracking purposes",
      "schema": {
        "columns": [
          {
            "name": "note_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the note",
            "optional": false
          },
          {
            "name": "application_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the associated job application",
            "optional": false,
            "references": "job_application.application_id"
          },
          {
            "name": "note_content",
            "type": "TEXT",
            "description": "Content of the note or comment",
            "optional": false
          },
          {
            "name": "note_type",
            "type": "VARCHAR(50)",
            "description": "Type or category of the note (e.g., follow_up, reminder, general)",
            "enum": [
              "follow_up",
              "reminder",
              "general",
              "feedback",
              "action_item"
            ],
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the note was created",
            "optional": false
          }
        ],
        "primary_key": "note_id"
      }
    },
    {
      "table_name": "application_stage",
      "description": "Table tracking the progression stages of job applications through the hiring process",
      "schema": {
        "columns": [
          {
            "name": "stage_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the stage record",
            "optional": false
          },
          {
            "name": "application_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the associated job application",
            "optional": false,
            "references": "job_application.application_id"
          },
          {
            "name": "stage_name",
            "type": "VARCHAR(100)",
            "description": "Name of the application stage (e.g., phone_screening, technical_interview, final_interview)",
            "optional": false
          },
          {
            "name": "stage_date",
            "type": "DATETIME",
            "description": "Date and time when the stage was reached",
            "optional": false
          },
          {
            "name": "stage_notes",
            "type": "TEXT",
            "description": "Additional notes about the stage",
            "optional": true
          }
        ],
        "primary_key": "stage_id"
      }
    },
    {
      "table_name": "interview_schedule",
      "description": "Table storing interview schedules and details for job applications",
      "schema": {
        "columns": [
          {
            "name": "interview_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the interview schedule",
            "optional": false
          },
          {
            "name": "application_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the associated job application",
            "optional": false,
            "references": "job_application.application_id"
          },
          {
            "name": "interview_type",
            "type": "VARCHAR(50)",
            "description": "Type of interview (e.g., phone_screening, technical_interview, behavioral_interview)",
            "enum": [
              "phone_screening",
              "technical_interview",
              "behavioral_interview",
              "system_design",
              "final_round"
            ],
            "optional": false
          },
          {
            "name": "interview_date",
            "type": "DATETIME",
            "description": "Scheduled date and time of the interview",
            "optional": false
          },
          {
            "name": "interviewer_name",
            "type": "VARCHAR(100)",
            "description": "Name of the interviewer",
            "optional": true
          },
          {
            "name": "interview_location",
            "type": "VARCHAR(200)",
            "description": "Location or platform for the interview (e.g., Zoom, office address)",
            "optional": true
          },
          {
            "name": "interview_duration_minutes",
            "type": "INTEGER",
            "description": "Expected duration of the interview in minutes",
            "optional": true
          }
        ],
        "primary_key": "interview_id"
      }
    },
    {
      "table_name": "interview_feedback",
      "description": "Table storing feedback and notes after interviews",
      "schema": {
        "columns": [
          {
            "name": "feedback_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the interview feedback",
            "optional": false
          },
          {
            "name": "interview_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the associated interview",
            "optional": false,
            "references": "interview_schedule.interview_id"
          },
          {
            "name": "feedback_content",
            "type": "TEXT",
            "description": "Content of the feedback or notes",
            "optional": false
          },
          {
            "name": "performance_rating",
            "type": "INTEGER",
            "description": "Self-assessment rating of interview performance (e.g., 1-5 scale)",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "DATETIME",
            "description": "Timestamp when the feedback was created",
            "optional": false
          }
        ],
        "primary_key": "feedback_id"
      }
    }
  ],
  "tools": [
    {
      "name": "format_application_for_display",
      "description": "Format application data for user-friendly display",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_transformation",
      "pre_condition": "Application data must be provided",
      "post_condition": "Formatted display data is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "application_data": {
            "description": "Raw application data",
            "type": "object",
            "properties": {
              "application_id": {
                "type": "string"
              },
              "job_title": {
                "type": "string"
              },
              "company_name": {
                "type": "string"
              },
              "status": {
                "type": "string"
              },
              "application_date": {
                "type": "string"
              }
            },
            "examples": [
              {
                "application_id": "APP-2024-001",
                "job_title": "Software Engineer",
                "company_name": "Tech Corp",
                "status": "under_review",
                "application_date": "2024-01-15 10:30:00"
              }
            ]
          },
          "display_format": {
            "description": "Format type for display",
            "type": "string",
            "examples": [
              "summary"
            ]
          }
        },
        "required": [
          "application_data"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "formatted_text": {
            "description": "Formatted text for display",
            "type": "string",
            "examples": [
              "Software Engineer at Tech Corp - Status: Under Review (Applied: 2024-01-15)"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_application_summary",
      "description": "Generate a summary of key information for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "content_generation",
      "pre_condition": "Application details must be provided",
      "post_condition": "Summary is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "job_title": {
            "description": "Title of the job position",
            "type": "string",
            "examples": [
              "Software Engineer"
            ]
          },
          "company_name": {
            "description": "Name of the company",
            "type": "string",
            "examples": [
              "Tech Corp Inc"
            ]
          },
          "application_date": {
            "description": "Date of application in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "status": {
            "description": "Current status of the application",
            "type": "string",
            "enum": [
              "submitted",
              "under_review",
              "rejected",
              "accepted",
              "withdrawn",
              "archived"
            ],
            "examples": [
              "under_review"
            ]
          },
          "job_requirements": {
            "description": "Key job requirements",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "Python",
                "AWS",
                "5 years experience"
              ]
            ]
          }
        },
        "required": [
          "job_title",
          "company_name",
          "application_date",
          "status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "summary_text": {
            "description": "Generated summary text",
            "type": "string",
            "examples": [
              "Applied for Software Engineer position at Tech Corp Inc on 2024-01-15. Current status: under_review."
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "add_salary_expectation",
      "description": "Add salary expectation information to an application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Salary expectation is recorded",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "expected_salary_min": {
            "description": "Minimum expected salary",
            "type": "number",
            "examples": [
              100000
            ]
          },
          "expected_salary_max": {
            "description": "Maximum expected salary",
            "type": "number",
            "examples": [
              130000
            ]
          },
          "salary_currency": {
            "description": "Currency for salary",
            "type": "string",
            "enum": [
              "USD",
              "EUR",
              "GBP",
              "JPY",
              "CNY",
              "AUD",
              "CAD"
            ],
            "examples": [
              "USD"
            ]
          }
        },
        "required": [
          "application_id",
          "expected_salary_min"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "salary_expectation_added": {
            "description": "Whether salary expectation was successfully added",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "detect_duplicate_applications",
      "description": "Detect potential duplicate applications based on job and company",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "validation",
      "pre_condition": "Application details must be provided",
      "post_condition": "Duplicate detection result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "job_title": {
            "description": "Job title to check",
            "type": "string",
            "examples": [
              "Software Engineer"
            ]
          },
          "company_name": {
            "description": "Company name to check",
            "type": "string",
            "examples": [
              "Tech Corp Inc"
            ]
          },
          "existing_applications": {
            "description": "List of existing applications to check against",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp Inc"
                }
              ]
            ]
          }
        },
        "required": [
          "job_title",
          "company_name",
          "existing_applications"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_duplicate": {
            "description": "Whether a duplicate application exists",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "duplicate_application_ids": {
            "description": "IDs of potential duplicate applications",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "APP-2024-001"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "list_applications_by_date_range",
      "description": "Retrieve job applications submitted within a specific date range",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_retrieval",
      "pre_condition": "Valid start and end dates must be provided",
      "post_condition": "List of applications within the date range is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "start_date": {
            "description": "Start date of the range in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date of the range in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-31"
            ]
          }
        },
        "required": [
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of applications within the date range",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "applicant_name": {
                  "type": "string"
                },
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                },
                "application_date": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "applicant_name": "John Smith",
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp",
                  "application_date": "2024-01-15 10:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of applications in the date range",
            "type": "integer",
            "examples": [
              25
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "calculate_average_response_time",
      "description": "Calculate average response time across multiple applications",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Application dates and response dates must be provided",
      "post_condition": "Average response time is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "application_response_pairs": {
            "description": "List of application and response date pairs",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_date": {
                  "type": "string"
                },
                "response_date": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_date": "2024-01-15 10:30:00",
                  "response_date": "2024-01-20 14:00:00"
                }
              ]
            ]
          }
        },
        "required": [
          "application_response_pairs"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "average_days": {
            "description": "Average response time in days",
            "type": "number",
            "examples": [
              5.5
            ]
          },
          "median_days": {
            "description": "Median response time in days",
            "type": "number",
            "examples": [
              5.0
            ]
          },
          "fastest_response_days": {
            "description": "Fastest response time in days",
            "type": "number",
            "examples": [
              3.0
            ]
          },
          "slowest_response_days": {
            "description": "Slowest response time in days",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "create_job_application",
      "description": "Create a new job application with applicant information, job details, and application materials",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_creation",
      "pre_condition": "Valid applicant information and job details must be provided",
      "post_condition": "A new job application record is created in the system",
      "parameters": {
        "type": "object",
        "properties": {
          "applicant_name": {
            "description": "Full name of the job applicant",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "email": {
            "description": "Email address of the applicant",
            "type": "string",
            "examples": [
              "john.smith@email.com"
            ]
          },
          "phone": {
            "description": "Phone number of the applicant",
            "type": "string",
            "examples": [
              "+1-555-0123"
            ]
          },
          "job_title": {
            "description": "Title of the job position being applied for",
            "type": "string",
            "examples": [
              "Software Engineer"
            ]
          },
          "company_name": {
            "description": "Name of the company",
            "type": "string",
            "examples": [
              "Tech Corp Inc"
            ]
          },
          "application_date": {
            "description": "Date when the application is submitted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "resume_content": {
            "description": "Text content of the resume",
            "type": "string",
            "examples": [
              "Experienced software engineer with 5 years..."
            ]
          },
          "cover_letter_content": {
            "description": "Text content of the cover letter",
            "type": "string",
            "examples": [
              "Dear Hiring Manager, I am writing to express..."
            ]
          }
        },
        "required": [
          "applicant_name",
          "email",
          "job_title",
          "company_name",
          "application_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier for the created application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "status": {
            "description": "Status of the application creation",
            "type": "string",
            "examples": [
              "created"
            ]
          },
          "created_at": {
            "description": "Timestamp when the application 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": [
        "job_application"
      ]
    },
    {
      "name": "get_high_priority_applications",
      "description": "Retrieve all high priority applications",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_retrieval",
      "pre_condition": "Minimum priority threshold must be provided",
      "post_condition": "List of high priority applications is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "min_priority_level": {
            "description": "Minimum priority level to filter by",
            "type": "integer",
            "examples": [
              4
            ]
          }
        },
        "required": [
          "min_priority_level"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of high priority applications",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                },
                "priority_level": {
                  "type": "integer"
                },
                "status": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp",
                  "priority_level": 5,
                  "status": "under_review"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "list_applications_by_status",
      "description": "Retrieve all job applications with a specific status",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_retrieval",
      "pre_condition": "Valid status must be provided",
      "post_condition": "List of applications with the specified status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "status": {
            "description": "Status to filter applications by",
            "type": "string",
            "examples": [
              "under_review"
            ],
            "enum": [
              "submitted",
              "under_review",
              "rejected",
              "accepted",
              "withdrawn",
              "archived"
            ]
          }
        },
        "required": [
          "status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of applications with the specified status",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "applicant_name": {
                  "type": "string"
                },
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                },
                "application_date": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "applicant_name": "John Smith",
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp",
                  "application_date": "2024-01-15 10:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of applications with this status",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "calculate_stage_duration",
      "description": "Calculate the duration spent in a specific application stage",
      "group": "job_seeking.Job_Application",
      "object_category": "stage_management",
      "action_category": "computation",
      "pre_condition": "Stage start and end dates must be provided",
      "post_condition": "Stage duration is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "stage_start_date": {
            "description": "Start date of the stage in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-18 14:00:00"
            ]
          },
          "stage_end_date": {
            "description": "End date of the stage in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-22 16:00:00"
            ]
          }
        },
        "required": [
          "stage_start_date",
          "stage_end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "duration_days": {
            "description": "Duration in days",
            "type": "integer",
            "examples": [
              4
            ]
          },
          "duration_hours": {
            "description": "Duration in hours",
            "type": "integer",
            "examples": [
              98
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_application_statistics",
      "description": "Generate statistical summary of all applications",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Application data must be provided",
      "post_condition": "Statistics are generated",
      "parameters": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of applications to analyze",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "status": {
                  "type": "string"
                },
                "application_date": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "status": "under_review",
                  "application_date": "2024-01-15 10:30:00"
                }
              ]
            ]
          }
        },
        "required": [
          "applications"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_applications": {
            "description": "Total number of applications",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "status_breakdown": {
            "description": "Count of applications by status",
            "type": "object",
            "examples": [
              {
                "submitted": 10,
                "under_review": 15,
                "rejected": 20,
                "accepted": 5
              }
            ]
          },
          "applications_this_month": {
            "description": "Number of applications submitted this month",
            "type": "integer",
            "examples": [
              8
            ]
          },
          "applications_this_week": {
            "description": "Number of applications submitted this week",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "generate_application_timeline",
      "description": "Generate a timeline visualization of application progress",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "content_generation",
      "pre_condition": "Application stages must be provided",
      "post_condition": "Timeline is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "application_stages": {
            "description": "List of application stages with dates",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "stage_name": {
                  "type": "string"
                },
                "stage_date": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "stage_name": "submitted",
                  "stage_date": "2024-01-15 10:30:00"
                }
              ]
            ]
          }
        },
        "required": [
          "application_stages"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "timeline_data": {
            "description": "Structured timeline data",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "stage": {
                  "type": "string"
                },
                "date": {
                  "type": "string"
                },
                "days_since_start": {
                  "type": "integer"
                }
              }
            },
            "examples": [
              [
                {
                  "stage": "submitted",
                  "date": "2024-01-15 10:30:00",
                  "days_since_start": 0
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "restore_archived_application",
      "description": "Restore an archived application to active status",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist and be archived",
      "post_condition": "Application is restored to active status",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the archived application",
            "type": "string",
            "examples": [
              "APP-2023-001"
            ]
          },
          "restored_status": {
            "description": "Status to set after restoration",
            "type": "string",
            "examples": [
              "submitted"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the restored application",
            "type": "string",
            "examples": [
              "APP-2023-001"
            ]
          },
          "restore_status": {
            "description": "Status of the restore operation",
            "type": "string",
            "examples": [
              "restored"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "compare_application_requirements",
      "description": "Compare applicant qualifications against job requirements",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Job requirements and applicant qualifications must be provided",
      "post_condition": "Comparison result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "job_requirements": {
            "description": "List of job requirements",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "Python",
                "AWS",
                "5 years experience"
              ]
            ]
          },
          "applicant_qualifications": {
            "description": "List of applicant qualifications",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "Python",
                "AWS",
                "Docker",
                "6 years experience"
              ]
            ]
          }
        },
        "required": [
          "job_requirements",
          "applicant_qualifications"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "matched_requirements": {
            "description": "Requirements that match applicant qualifications",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Python",
                "AWS",
                "5 years experience"
              ]
            ]
          },
          "missing_requirements": {
            "description": "Requirements not met by applicant",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [],
            "match_percentage": {
              "description": "Percentage of requirements matched",
              "type": "number",
              "examples": [
                100.0
              ]
            }
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_application_stage_history",
      "description": "Retrieve the complete stage progression history of an application",
      "group": "job_seeking.Job_Application",
      "object_category": "stage_management",
      "action_category": "data_retrieval",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Stage history is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "stages": {
            "description": "List of stages in chronological order",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "stage_id": {
                  "type": "string"
                },
                "stage_name": {
                  "type": "string"
                },
                "stage_date": {
                  "type": "string"
                },
                "stage_notes": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "stage_id": "STAGE-2024-001",
                  "stage_name": "phone_screening",
                  "stage_date": "2024-01-18 14:00:00",
                  "stage_notes": "Scheduled for phone call"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "application_stage"
      ]
    },
    {
      "name": "get_application_details",
      "description": "Retrieve complete details of a specific job application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_retrieval",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Application details are retrieved",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "applicant_name": {
            "description": "Full name of the applicant",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "applicant_email": {
            "description": "Email address of the applicant",
            "type": "string",
            "examples": [
              "john.smith@email.com"
            ]
          },
          "job_title": {
            "description": "Title of the job position",
            "type": "string",
            "examples": [
              "Software Engineer"
            ]
          },
          "company_name": {
            "description": "Name of the company",
            "type": "string",
            "examples": [
              "Tech Corp Inc"
            ]
          },
          "status": {
            "description": "Current status of the application",
            "type": "string",
            "examples": [
              "under_review"
            ]
          },
          "application_date": {
            "description": "Date of application submission in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "track_application_stage",
      "description": "Record the current stage of the application process",
      "group": "job_seeking.Job_Application",
      "object_category": "stage_management",
      "action_category": "data_creation",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Application stage is recorded",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "stage_name": {
            "description": "Name of the application stage",
            "type": "string",
            "examples": [
              "phone_screening"
            ]
          },
          "stage_date": {
            "description": "Date when the stage was reached in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-18 14:00:00"
            ]
          },
          "stage_notes": {
            "description": "Additional notes about the stage",
            "type": "string",
            "examples": [
              "Scheduled for 30-minute phone call with recruiter"
            ]
          }
        },
        "required": [
          "application_id",
          "stage_name",
          "stage_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "stage_id": {
            "description": "Unique identifier of the recorded stage",
            "type": "string",
            "examples": [
              "STAGE-2024-001"
            ]
          },
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "application_stage",
        "job_application"
      ]
    },
    {
      "name": "validate_contact_information",
      "description": "Validate the format of contact information",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "validation",
      "pre_condition": "Contact information must be provided",
      "post_condition": "Validation result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "email": {
            "description": "Email address to validate",
            "type": "string",
            "examples": [
              "john.smith@email.com"
            ]
          },
          "phone": {
            "description": "Phone number to validate",
            "type": "string",
            "examples": [
              "+1-555-0123"
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "email_valid": {
            "description": "Whether email format is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "phone_valid": {
            "description": "Whether phone format is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "validation_errors": {
            "description": "List of validation errors",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "set_application_priority",
      "description": "Set priority level for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Priority is set for the application",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "priority_level": {
            "description": "Priority level (1-5, where 5 is highest)",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "priority_reason": {
            "description": "Reason for the priority level",
            "type": "string",
            "examples": [
              "Dream company with perfect role match"
            ]
          }
        },
        "required": [
          "application_id",
          "priority_level"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "priority_set": {
            "description": "Whether priority was successfully set",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "list_applications_by_applicant",
      "description": "Retrieve all job applications submitted by a specific applicant",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_retrieval",
      "pre_condition": "Applicant email must be provided",
      "post_condition": "List of applications is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "email": {
            "description": "Email address of the applicant",
            "type": "string",
            "examples": [
              "john.smith@email.com"
            ]
          }
        },
        "required": [
          "email"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of applications submitted by the applicant",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                },
                "status": {
                  "type": "string"
                },
                "application_date": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp",
                  "status": "under_review",
                  "application_date": "2024-01-15 10:30:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of applications",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "merge_duplicate_applications",
      "description": "Merge information from duplicate applications into a single record",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_transformation",
      "pre_condition": "Both applications must exist in the system",
      "post_condition": "Applications are merged into one record",
      "parameters": {
        "type": "object",
        "properties": {
          "primary_application_id": {
            "description": "ID of the application to keep",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "secondary_application_id": {
            "description": "ID of the application to merge and remove",
            "type": "string",
            "examples": [
              "APP-2024-002"
            ]
          }
        },
        "required": [
          "primary_application_id",
          "secondary_application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "merged_application_id": {
            "description": "ID of the resulting merged application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "merge_status": {
            "description": "Status of the merge operation",
            "type": "string",
            "examples": [
              "merged"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "calculate_application_roi",
      "description": "Calculate return on investment metrics for job applications",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "computation",
      "pre_condition": "Application effort and outcome data must be provided",
      "post_condition": "ROI metrics are calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_applications": {
            "description": "Total number of applications submitted",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "total_interviews": {
            "description": "Total number of interviews received",
            "type": "integer",
            "examples": [
              10
            ]
          },
          "total_offers": {
            "description": "Total number of offers received",
            "type": "integer",
            "examples": [
              2
            ]
          },
          "average_time_per_application_hours": {
            "description": "Average time spent per application in hours",
            "type": "number",
            "examples": [
              2.5
            ]
          }
        },
        "required": [
          "total_applications",
          "total_interviews",
          "total_offers"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "interview_conversion_rate": {
            "description": "Percentage of applications leading to interviews",
            "type": "number",
            "examples": [
              20.0
            ]
          },
          "offer_conversion_rate": {
            "description": "Percentage of applications leading to offers",
            "type": "number",
            "examples": [
              4.0
            ]
          },
          "interview_to_offer_rate": {
            "description": "Percentage of interviews leading to offers",
            "type": "number",
            "examples": [
              20.0
            ]
          },
          "total_time_invested_hours": {
            "description": "Total time invested in applications",
            "type": "number",
            "examples": [
              125.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "archive_old_applications",
      "description": "Archive applications older than a specified date",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Cutoff date must be provided",
      "post_condition": "Old applications are archived",
      "parameters": {
        "type": "object",
        "properties": {
          "cutoff_date": {
            "description": "Date before which applications should be archived in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2023-12-31"
            ]
          },
          "archive_status": {
            "description": "Status to set for archived applications",
            "type": "string",
            "examples": [
              "archived"
            ]
          }
        },
        "required": [
          "cutoff_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "archived_count": {
            "description": "Number of applications archived",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "archived_application_ids": {
            "description": "List of archived application IDs",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "APP-2023-001",
                "APP-2023-002"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "search_applications_by_keyword",
      "description": "Search applications using keywords in job title or company name",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_retrieval",
      "pre_condition": "Search keyword must be provided",
      "post_condition": "Matching applications are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "keyword": {
            "description": "Keyword to search for",
            "type": "string",
            "examples": [
              "engineer"
            ]
          },
          "search_fields": {
            "description": "Fields to search in",
            "type": "array",
            "items": {
              "type": "string",
              "enum": [
                "job_title",
                "company_name",
                "applicant_name",
                "referral_source",
                "referral_person",
                "priority_reason",
                "resume_content",
                "cover_letter_content"
              ]
            },
            "examples": [
              [
                "job_title",
                "company_name"
              ]
            ]
          }
        },
        "required": [
          "keyword"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "matching_applications": {
            "description": "List of applications matching the search",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp"
                }
              ]
            ]
          },
          "total_matches": {
            "description": "Total number of matching applications",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "calculate_interview_preparation_time",
      "description": "Calculate the time available for interview preparation",
      "group": "job_seeking.Job_Application",
      "object_category": "interview_management",
      "action_category": "computation",
      "pre_condition": "Current date and interview date must be provided",
      "post_condition": "Preparation time is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "current_date": {
            "description": "Current date and time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 10:00:00"
            ]
          },
          "interview_date": {
            "description": "Scheduled interview date and time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-25 10:00:00"
            ]
          }
        },
        "required": [
          "current_date",
          "interview_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "days_until_interview": {
            "description": "Number of days until the interview",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "hours_until_interview": {
            "description": "Total hours until the interview",
            "type": "integer",
            "examples": [
              120
            ]
          },
          "is_urgent": {
            "description": "Whether the interview is within 48 hours",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "batch_update_application_status",
      "description": "Update status for multiple applications at once",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "All applications must exist in the system",
      "post_condition": "All specified applications are updated",
      "parameters": {
        "type": "object",
        "properties": {
          "application_ids": {
            "description": "List of application identifiers to update",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "APP-2024-001",
                "APP-2024-002"
              ]
            ]
          },
          "new_status": {
            "description": "New status to apply to all applications",
            "type": "string",
            "enum": [
              "submitted",
              "under_review",
              "rejected",
              "accepted",
              "withdrawn",
              "archived"
            ],
            "examples": [
              "withdrawn"
            ]
          },
          "updated_at": {
            "description": "Timestamp of the batch update in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 16:00:00"
            ]
          }
        },
        "required": [
          "application_ids",
          "new_status",
          "updated_at"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "updated_count": {
            "description": "Number of applications successfully updated",
            "type": "integer",
            "examples": [
              2
            ]
          },
          "failed_updates": {
            "description": "List of application IDs that failed to update",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "validate_application_completeness",
      "description": "Check if a job application has all required fields and documents",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "validation",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Validation result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_complete": {
            "description": "Whether the application is complete",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "missing_fields": {
            "description": "List of missing required fields",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "resume",
                "cover_letter"
              ]
            ]
          },
          "validation_message": {
            "description": "Detailed validation message",
            "type": "string",
            "examples": [
              "Application is complete and ready for submission"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "get_application_interviews",
      "description": "Retrieve all interview schedules for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "interview_management",
      "action_category": "data_retrieval",
      "pre_condition": "Application must exist in the system",
      "post_condition": "List of interviews is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "interviews": {
            "description": "List of scheduled interviews",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "interview_id": {
                  "type": "string"
                },
                "interview_type": {
                  "type": "string"
                },
                "interview_date": {
                  "type": "string"
                },
                "interviewer_name": {
                  "type": "string"
                },
                "interview_location": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "interview_id": "INT-2024-001",
                  "interview_type": "technical_interview",
                  "interview_date": "2024-01-25 10:00:00",
                  "interviewer_name": "Jane Doe",
                  "interview_location": "Zoom"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "interview_schedule",
        "job_application"
      ]
    },
    {
      "name": "add_interview_feedback",
      "description": "Add feedback or notes after an interview",
      "group": "job_seeking.Job_Application",
      "object_category": "interview_management",
      "action_category": "data_creation",
      "pre_condition": "Interview must exist in the system",
      "post_condition": "Feedback is added to the interview",
      "parameters": {
        "type": "object",
        "properties": {
          "interview_id": {
            "description": "Unique identifier of the interview",
            "type": "string",
            "examples": [
              "INT-2024-001"
            ]
          },
          "feedback_content": {
            "description": "Content of the feedback",
            "type": "string",
            "examples": [
              "Interview went well, discussed technical challenges and solutions"
            ]
          },
          "performance_rating": {
            "description": "Self-assessment rating of interview performance",
            "type": "integer",
            "examples": [
              4
            ]
          },
          "created_at": {
            "description": "Timestamp when feedback was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-25 11:30:00"
            ]
          }
        },
        "required": [
          "interview_id",
          "feedback_content",
          "created_at"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "feedback_id": {
            "description": "Unique identifier of the feedback",
            "type": "string",
            "examples": [
              "FEEDBACK-2024-001"
            ]
          },
          "interview_id": {
            "description": "Unique identifier of the interview",
            "type": "string",
            "examples": [
              "INT-2024-001"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "interview_feedback",
        "interview_schedule",
        "job_application"
      ]
    },
    {
      "name": "check_application_deadline",
      "description": "Check if an application deadline has passed or is approaching",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "validation",
      "pre_condition": "Deadline date must be provided",
      "post_condition": "Deadline status is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "deadline_date": {
            "description": "Deadline date in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-02-01 17:00:00"
            ]
          },
          "current_date": {
            "description": "Current date for comparison in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 10:30:00"
            ]
          },
          "warning_days": {
            "description": "Number of days before deadline to trigger warning",
            "type": "integer",
            "examples": [
              3
            ]
          }
        },
        "required": [
          "deadline_date",
          "current_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_overdue": {
            "description": "Whether the deadline has passed",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "is_approaching": {
            "description": "Whether the deadline is approaching within warning period",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "days_remaining": {
            "description": "Number of days until deadline",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "track_referral_source",
      "description": "Track the source or referral for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Referral source is recorded",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "referral_source": {
            "description": "Source of the job referral",
            "type": "string",
            "examples": [
              "LinkedIn"
            ]
          },
          "referral_person": {
            "description": "Name of person who referred (if applicable)",
            "type": "string",
            "examples": [
              "Jane Doe"
            ]
          }
        },
        "required": [
          "application_id",
          "referral_source"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "referral_tracked": {
            "description": "Whether referral was successfully tracked",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "attach_cover_letter_to_application",
      "description": "Attach or update cover letter content for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "document_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Cover letter is attached to the application",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "cover_letter_content": {
            "description": "Text content of the cover letter",
            "type": "string",
            "examples": [
              "Dear Hiring Manager, I am writing to express my interest..."
            ]
          },
          "uploaded_at": {
            "description": "Timestamp when the cover letter was uploaded in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 11:05:00"
            ]
          }
        },
        "required": [
          "application_id",
          "cover_letter_content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "cover_letter_attached": {
            "description": "Whether cover letter was successfully attached",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "match_resume_to_job_description",
      "description": "Calculate match score between resume and job description",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Resume content and job description must be provided",
      "post_condition": "Match score is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "resume_content": {
            "description": "Text content of the resume",
            "type": "string",
            "examples": [
              "Experienced software engineer with Python and AWS..."
            ]
          },
          "job_description": {
            "description": "Text content of the job description",
            "type": "string",
            "examples": [
              "Looking for software engineer with Python, AWS, and 5 years experience..."
            ]
          }
        },
        "required": [
          "resume_content",
          "job_description"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "match_score": {
            "description": "Overall match score (0-100)",
            "type": "number",
            "examples": [
              85.5
            ]
          },
          "matched_keywords": {
            "description": "Keywords that match between resume and job",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Python",
                "AWS",
                "software engineer"
              ]
            ]
          },
          "missing_keywords": {
            "description": "Keywords in job description not found in resume",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Kubernetes"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "set_application_deadline",
      "description": "Set a follow-up or response deadline for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Deadline is set for the application",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "deadline_date": {
            "description": "Deadline date in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-02-01 17:00:00"
            ]
          },
          "deadline_type": {
            "description": "Type of deadline",
            "type": "string",
            "enum": [
              "follow_up",
              "response",
              "application_deadline"
            ],
            "examples": [
              "follow_up"
            ]
          }
        },
        "required": [
          "application_id",
          "deadline_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "deadline_set": {
            "description": "Whether deadline was successfully set",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "export_application_data",
      "description": "Export application data in a specified format",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_transformation",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Application data is exported",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "export_format": {
            "description": "Format for export",
            "type": "string",
            "examples": [
              "json"
            ]
          }
        },
        "required": [
          "application_id",
          "export_format"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "exported_data": {
            "description": "Exported application data in specified format",
            "type": "string",
            "examples": [
              "{\"application_id\": \"APP-2024-001\", \"job_title\": \"Software Engineer\"}"
            ]
          },
          "export_timestamp": {
            "description": "Timestamp when data was exported in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 15:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "calculate_application_diversity_score",
      "description": "Calculate diversity score based on variety of companies and roles applied to",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "List of applications must be provided",
      "post_condition": "Diversity score is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of applications with job and company info",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "job_title": {
                  "type": "string"
                },
                "company_name": {
                  "type": "string"
                },
                "industry": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "job_title": "Software Engineer",
                  "company_name": "Tech Corp",
                  "industry": "Technology"
                }
              ]
            ]
          }
        },
        "required": [
          "applications"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "unique_companies": {
            "description": "Number of unique companies",
            "type": "integer",
            "examples": [
              10
            ]
          },
          "unique_job_titles": {
            "description": "Number of unique job titles",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "unique_industries": {
            "description": "Number of unique industries",
            "type": "integer",
            "examples": [
              3
            ]
          },
          "diversity_score": {
            "description": "Overall diversity score (0-100)",
            "type": "number",
            "examples": [
              75.5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_application_response_time",
      "description": "Calculate the time elapsed since application submission",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "computation",
      "pre_condition": "Application date must be provided",
      "post_condition": "Response time is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "application_date": {
            "description": "Date when the application was submitted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "current_date": {
            "description": "Current date for calculation in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 10:30:00"
            ]
          }
        },
        "required": [
          "application_date",
          "current_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "days_elapsed": {
            "description": "Number of days since application submission",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "hours_elapsed": {
            "description": "Total hours since application submission",
            "type": "integer",
            "examples": [
              120
            ]
          },
          "business_days_elapsed": {
            "description": "Number of business days since application submission",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_application_status",
      "description": "Update the status of an existing job application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Application status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "new_status": {
            "description": "New status to be set for the application",
            "type": "string",
            "enum": [
              "submitted",
              "under_review",
              "rejected",
              "accepted",
              "withdrawn",
              "archived"
            ],
            "examples": [
              "under_review"
            ]
          },
          "updated_at": {
            "description": "Timestamp of the status update in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:20:00"
            ]
          }
        },
        "required": [
          "application_id",
          "new_status",
          "updated_at"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the updated application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "previous_status": {
            "description": "Previous status before update",
            "type": "string",
            "examples": [
              "submitted"
            ]
          },
          "status": {
            "description": "Current status after update",
            "type": "string",
            "examples": [
              "under_review"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "extract_keywords_from_resume",
      "description": "Extract key skills and keywords from resume content",
      "group": "job_seeking.Job_Application",
      "object_category": "document_management",
      "action_category": "content_processing",
      "pre_condition": "Resume content must be provided",
      "post_condition": "Keywords are extracted",
      "parameters": {
        "type": "object",
        "properties": {
          "resume_content": {
            "description": "Text content of the resume",
            "type": "string",
            "examples": [
              "Experienced software engineer with Python, AWS, and Docker expertise..."
            ]
          }
        },
        "required": [
          "resume_content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "technical_skills": {
            "description": "Extracted technical skills",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Python",
                "AWS",
                "Docker"
              ]
            ]
          },
          "soft_skills": {
            "description": "Extracted soft skills",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "leadership",
                "communication"
              ]
            ]
          },
          "keywords": {
            "description": "All extracted keywords",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "software",
                "engineer",
                "Python",
                "AWS"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "add_interview_schedule",
      "description": "Add an interview schedule to a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "interview_management",
      "action_category": "data_creation",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Interview schedule is added",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "interview_type": {
            "description": "Type of interview",
            "type": "string",
            "enum": [
              "phone_screening",
              "technical_interview",
              "behavioral_interview",
              "system_design",
              "final_round"
            ],
            "examples": [
              "technical_interview"
            ]
          },
          "interview_date": {
            "description": "Scheduled date and time of the interview in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-25 10:00:00"
            ]
          },
          "interviewer_name": {
            "description": "Name of the interviewer",
            "type": "string",
            "examples": [
              "Jane Doe"
            ]
          },
          "interview_location": {
            "description": "Location or platform for the interview",
            "type": "string",
            "examples": [
              "Zoom Meeting Room"
            ]
          },
          "interview_duration_minutes": {
            "description": "Expected duration of the interview in minutes",
            "type": "integer",
            "examples": [
              60
            ]
          }
        },
        "required": [
          "application_id",
          "interview_type",
          "interview_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "interview_id": {
            "description": "Unique identifier of the scheduled interview",
            "type": "string",
            "examples": [
              "INT-2024-001"
            ]
          },
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "interview_schedule",
        "job_application"
      ]
    },
    {
      "name": "generate_follow_up_reminder",
      "description": "Generate a follow-up reminder message for an application",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "content_generation",
      "pre_condition": "Application details and follow-up date must be provided",
      "post_condition": "Reminder message is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "job_title": {
            "description": "Job title",
            "type": "string",
            "examples": [
              "Software Engineer"
            ]
          },
          "company_name": {
            "description": "Company name",
            "type": "string",
            "examples": [
              "Tech Corp Inc"
            ]
          },
          "application_date": {
            "description": "Date of application in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 10:30:00"
            ]
          },
          "follow_up_date": {
            "description": "Date to follow up in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-22 10:00:00"
            ]
          }
        },
        "required": [
          "job_title",
          "company_name",
          "application_date",
          "follow_up_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reminder_message": {
            "description": "Generated reminder message",
            "type": "string",
            "examples": [
              "Follow up on your Software Engineer application at Tech Corp Inc (applied on 2024-01-15)"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "add_application_note",
      "description": "Add a note or comment to a job application for tracking purposes",
      "group": "job_seeking.Job_Application",
      "object_category": "note_management",
      "action_category": "data_creation",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Note is added to the application",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "note_content": {
            "description": "Content of the note",
            "type": "string",
            "examples": [
              "Followed up with recruiter on 2024-01-16"
            ]
          },
          "note_type": {
            "description": "Type or category of the note",
            "type": "string",
            "enum": [
              "follow_up",
              "reminder",
              "general",
              "feedback",
              "action_item"
            ],
            "examples": [
              "follow_up"
            ]
          },
          "created_at": {
            "description": "Timestamp when the note was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 15:30:00"
            ]
          }
        },
        "required": [
          "application_id",
          "note_content",
          "created_at"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "note_id": {
            "description": "Unique identifier of the created note",
            "type": "string",
            "examples": [
              "NOTE-2024-001"
            ]
          },
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "application_note",
        "job_application"
      ]
    },
    {
      "name": "attach_resume_to_application",
      "description": "Attach or update resume content for a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "document_management",
      "action_category": "data_modification",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Resume is attached to the application",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "resume_content": {
            "description": "Text content of the resume",
            "type": "string",
            "examples": [
              "Experienced software engineer with 5 years in backend development..."
            ]
          },
          "resume_format": {
            "description": "Format of the resume document",
            "type": "string",
            "examples": [
              "pdf"
            ]
          },
          "uploaded_at": {
            "description": "Timestamp when the resume was uploaded in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 11:00:00"
            ]
          }
        },
        "required": [
          "application_id",
          "resume_content"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "resume_attached": {
            "description": "Whether resume was successfully attached",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "compare_applications",
      "description": "Compare two applications side by side",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Two application datasets must be provided",
      "post_condition": "Comparison result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "application_1": {
            "description": "First application data",
            "type": "object",
            "properties": {
              "job_title": {
                "type": "string"
              },
              "company_name": {
                "type": "string"
              },
              "status": {
                "type": "string"
              },
              "match_score": {
                "type": "number"
              }
            },
            "examples": [
              {
                "job_title": "Software Engineer",
                "company_name": "Tech Corp",
                "status": "under_review",
                "match_score": 85.0
              }
            ]
          },
          "application_2": {
            "description": "Second application data",
            "type": "object",
            "properties": {
              "job_title": {
                "type": "string"
              },
              "company_name": {
                "type": "string"
              },
              "status": {
                "type": "string"
              },
              "match_score": {
                "type": "number"
              }
            },
            "examples": [
              {
                "job_title": "Senior Developer",
                "company_name": "Startup Inc",
                "status": "submitted",
                "match_score": 78.0
              }
            ]
          }
        },
        "required": [
          "application_1",
          "application_2"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "comparison_summary": {
            "description": "Summary of key differences",
            "type": "string",
            "examples": [
              "Application 1 has higher match score but Application 2 is at an earlier stage"
            ]
          },
          "recommendation": {
            "description": "Recommendation on which to prioritize",
            "type": "string",
            "examples": [
              "Prioritize Application 1 due to higher match score and active review status"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "prioritize_applications",
      "description": "Prioritize applications based on multiple criteria",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Application list with criteria must be provided",
      "post_condition": "Prioritized list is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "applications": {
            "description": "List of applications with priority factors",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "deadline_urgency": {
                  "type": "integer"
                },
                "match_score": {
                  "type": "number"
                },
                "company_preference": {
                  "type": "integer"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "deadline_urgency": 5,
                  "match_score": 85.0,
                  "company_preference": 4
                }
              ]
            ]
          }
        },
        "required": [
          "applications"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "prioritized_applications": {
            "description": "Applications sorted by priority",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "application_id": {
                  "type": "string"
                },
                "priority_score": {
                  "type": "number"
                }
              }
            },
            "examples": [
              [
                {
                  "application_id": "APP-2024-001",
                  "priority_score": 94.0
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_interview_schedule",
      "description": "Update an existing interview schedule",
      "group": "job_seeking.Job_Application",
      "object_category": "interview_management",
      "action_category": "data_modification",
      "pre_condition": "Interview schedule must exist in the system",
      "post_condition": "Interview schedule is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "interview_id": {
            "description": "Unique identifier of the interview",
            "type": "string",
            "examples": [
              "INT-2024-001"
            ]
          },
          "new_interview_date": {
            "description": "New scheduled date and time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-26 14:00:00"
            ]
          },
          "new_location": {
            "description": "New location or platform for the interview",
            "type": "string",
            "examples": [
              "Google Meet"
            ]
          }
        },
        "required": [
          "interview_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "interview_id": {
            "description": "Unique identifier of the updated interview",
            "type": "string",
            "examples": [
              "INT-2024-001"
            ]
          },
          "update_status": {
            "description": "Status of the update operation",
            "type": "string",
            "examples": [
              "updated"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "interview_schedule"
      ]
    },
    {
      "name": "get_application_notes",
      "description": "Retrieve all notes associated with a job application",
      "group": "job_seeking.Job_Application",
      "object_category": "note_management",
      "action_category": "data_retrieval",
      "pre_condition": "Application must exist in the system",
      "post_condition": "List of notes is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "notes": {
            "description": "List of notes for the application",
            "type": "array",
            "items": {
              "type": "object",
              "properties": {
                "note_id": {
                  "type": "string"
                },
                "note_content": {
                  "type": "string"
                },
                "note_type": {
                  "type": "string"
                },
                "created_at": {
                  "type": "string"
                }
              }
            },
            "examples": [
              [
                {
                  "note_id": "NOTE-2024-001",
                  "note_content": "Followed up with recruiter",
                  "note_type": "follow_up",
                  "created_at": "2024-01-16 15:30:00"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "application_note"
      ]
    },
    {
      "name": "delete_job_application",
      "description": "Delete a job application from the system",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_deletion",
      "pre_condition": "Application must exist in the system",
      "post_condition": "Application is removed from the system",
      "parameters": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the application to delete",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          }
        },
        "required": [
          "application_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "application_id": {
            "description": "Unique identifier of the deleted application",
            "type": "string",
            "examples": [
              "APP-2024-001"
            ]
          },
          "deletion_status": {
            "description": "Status of the deletion operation",
            "type": "string",
            "examples": [
              "deleted"
            ]
          },
          "deleted_at": {
            "description": "Timestamp when the application was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 09:15:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "job_application"
      ]
    },
    {
      "name": "calculate_application_success_rate",
      "description": "Calculate the success rate of applications by status",
      "group": "job_seeking.Job_Application",
      "object_category": "application_management",
      "action_category": "data_analysis",
      "pre_condition": "Application status counts must be provided",
      "post_condition": "Success rate is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_applications": {
            "description": "Total number of applications submitted",
            "type": "integer",
            "examples": [
              50
            ]
          },
          "successful_applications": {
            "description": "Number of applications that resulted in offers",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "rejected_applications": {
            "description": "Number of rejected applications",
            "type": "integer",
            "examples": [
              20
            ]
          }
        },
        "required": [
          "total_applications",
          "successful_applications"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success_rate": {
            "description": "Percentage of successful applications",
            "type": "number",
            "examples": [
              10.0
            ]
          },
          "rejection_rate": {
            "description": "Percentage of rejected applications",
            "type": "number",
            "examples": [
              40.0
            ]
          },
          "pending_rate": {
            "description": "Percentage of pending applications",
            "type": "number",
            "examples": [
              50.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    }
  ],
  "schema_classification": {
    "JobApplication": {
      "schema_name": "JobApplication",
      "instance_key": "application_id",
      "fields": [
        {
          "field_name": "application_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条申请记录，工具每次生成均不同"
        },
        {
          "field_name": "applicant_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名字段，不同书写方式（如全名、昵称、顺序变化）可能表达相同含义"
        },
        {
          "field_name": "email",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电子邮件地址必须精确匹配，不同字符即表示不同用户"
        },
        {
          "field_name": "phone",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "电话号码必须精确匹配，业务上即使微小差异也视为不同号码"
        },
        {
          "field_name": "job_title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "职位名称属于自由文本，不同措辞可能表达相同职位"
        },
        {
          "field_name": "company_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "公司名称可能有缩写、全称、别名等，需语义比较"
        },
        {
          "field_name": "application_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "提交时间必须严格匹配，时间差异即表示不同状态"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举型字段，需精确匹配业务流程状态"
        },
        {
          "field_name": "resume_content",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "简历内容为自由文本，不同表达可能语义相同"
        },
        {
          "field_name": "resume_format",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "简历格式需精确匹配，pdf与docx不可等价"
        },
        {
          "field_name": "resume_uploaded_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "上传时间需严格匹配，时间不同即为不同记录"
        },
        {
          "field_name": "cover_letter_content",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "求职信内容为自然语言文本，不同表述可能含义一致"
        },
        {
          "field_name": "cover_letter_uploaded_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "上传时间需严格匹配，时间不同即为不同记录"
        },
        {
          "field_name": "deadline_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "截止日期需严格匹配，业务上即使微小时间差异也很重要"
        },
        {
          "field_name": "deadline_type",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "截止类型为枚举，需精确匹配"
        },
        {
          "field_name": "referral_source",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "推荐来源为自由文本，不同平台或表述可能语义相同"
        },
        {
          "field_name": "referral_person",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "推荐人姓名属于自然语言文本，可能有昵称、正式姓名等变化"
        },
        {
          "field_name": "priority_level",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "优先级为数值，需精确匹配"
        },
        {
          "field_name": "priority_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "优先级原因为自由文本，不同措辞可能表达相同理由"
        },
        {
          "field_name": "expected_salary_min",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值型字段，必须精确匹配"
        },
        {
          "field_name": "expected_salary_max",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值型字段，必须精确匹配"
        },
        {
          "field_name": "salary_currency",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "货币单位为枚举型，需精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间需严格匹配，表示记录生成时间节点"
        },
        {
          "field_name": "updated_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "更新时间需严格匹配，业务上时间差异即为不同状态"
        }
      ]
    },
    "ApplicationNote": {
      "schema_name": "ApplicationNote",
      "instance_key": "note_id",
      "fields": [
        {
          "field_name": "note_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具随机生成，每次执行都不同"
        },
        {
          "field_name": "application_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精准对应关联的申请记录"
        },
        {
          "field_name": "note_content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "note_type",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "枚举值，类型或类别应严格一致"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配"
        }
      ]
    },
    "ApplicationStage": {
      "schema_name": "ApplicationStage",
      "instance_key": "stage_id",
      "fields": [
        {
          "field_name": "stage_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每个记录，由系统或工具随机生成"
        },
        {
          "field_name": "application_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联的申请一致"
        },
        {
          "field_name": "stage_name",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，表示具体的流程阶段，微小差异即表明不同业务含义"
        },
        {
          "field_name": "stage_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间字段，必须严格一致以反映准确的业务进程"
        },
        {
          "field_name": "stage_notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本备注，不同措辞可以表达相同业务含义"
        }
      ]
    },
    "InterviewSchedule": {
      "schema_name": "InterviewSchedule",
      "instance_key": "interview_id",
      "fields": [
        {
          "field_name": "interview_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识，用于唯一性，不参与等价性比较"
        },
        {
          "field_name": "application_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联的申请一致"
        },
        {
          "field_name": "interview_type",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，表示面试类型，需精确匹配"
        },
        {
          "field_name": "interview_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，必须严格相等"
        },
        {
          "field_name": "interviewer_name",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "姓名字段，不同表述可能等价（如缩写、全称等）"
        },
        {
          "field_name": "interview_location",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "地址或平台信息，可以有不同但等价的自然语言表达"
        },
        {
          "field_name": "interview_duration_minutes",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值字段，表示面试持续时间，必须精确匹配"
        }
      ]
    },
    "InterviewFeedback": {
      "schema_name": "InterviewFeedback",
      "instance_key": "feedback_id",
      "fields": [
        {
          "field_name": "feedback_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成的唯一标识符，每次执行都不同"
        },
        {
          "field_name": "interview_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联的面试记录一致"
        },
        {
          "field_name": "feedback_content",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可能表达相同含义"
        },
        {
          "field_name": "performance_rating",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值评分，必须精确匹配，任何微小差异都很重要"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须严格相等以确保数据状态一致"
        }
      ]
    }
  }
}