{
  "domain": "healthcare_telemedicine",
  "databases": [
    {
      "table_name": "patient",
      "description": "Stores patient account information and personal details",
      "schema": {
        "columns": [
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the patient account",
            "optional": false
          },
          {
            "name": "first_name",
            "type": "VARCHAR(100)",
            "description": "Patient's first name",
            "optional": false
          },
          {
            "name": "last_name",
            "type": "VARCHAR(100)",
            "description": "Patient's last name",
            "optional": false
          },
          {
            "name": "email",
            "type": "VARCHAR(255)",
            "description": "Patient's email address for account login",
            "optional": false
          },
          {
            "name": "phone_number",
            "type": "VARCHAR(20)",
            "description": "Patient's primary contact phone number",
            "optional": false
          },
          {
            "name": "date_of_birth",
            "type": "DATE",
            "description": "Patient's date of birth",
            "optional": false
          },
          {
            "name": "password_hash",
            "type": "VARCHAR(255)",
            "description": "Hashed account password",
            "optional": false
          },
          {
            "name": "address",
            "type": "TEXT",
            "description": "Patient's residential address",
            "optional": true
          },
          {
            "name": "emergency_contact_name",
            "type": "VARCHAR(200)",
            "description": "Name of emergency contact person",
            "optional": true
          },
          {
            "name": "emergency_contact_phone",
            "type": "VARCHAR(20)",
            "description": "Phone number of emergency contact",
            "optional": true
          },
          {
            "name": "preferred_language",
            "type": "VARCHAR(50)",
            "description": "Patient's preferred language for communication",
            "optional": true,
            "enum": [
              "English",
              "Spanish",
              "French",
              "Chinese",
              "German"
            ]
          },
          {
            "name": "account_status",
            "type": "VARCHAR(50)",
            "description": "Current status of the patient account",
            "optional": false,
            "default": "pending_verification"
          },
          {
            "name": "email_verified",
            "type": "BOOLEAN",
            "description": "Whether email has been verified",
            "optional": false,
            "default": "false"
          },
          {
            "name": "two_factor_enabled",
            "type": "BOOLEAN",
            "description": "Whether two-factor authentication is enabled",
            "optional": false,
            "default": "false"
          },
          {
            "name": "two_factor_method",
            "type": "VARCHAR(50)",
            "description": "Method for two-factor authentication",
            "optional": true,
            "enum": [
              "sms",
              "email",
              "authenticator_app"
            ]
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when the account was created",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when profile was last updated",
            "optional": true
          },
          {
            "name": "verified_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when email was verified",
            "optional": true
          }
        ],
        "primary_key": "patient_id"
      }
    },
    {
      "table_name": "healthcare_provider",
      "description": "Stores healthcare provider information including credentials and specialties",
      "schema": {
        "columns": [
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the healthcare provider",
            "optional": false
          },
          {
            "name": "full_name",
            "type": "VARCHAR(200)",
            "description": "Provider's full name with title",
            "optional": false
          },
          {
            "name": "credentials",
            "type": "VARCHAR(255)",
            "description": "Professional credentials and certifications",
            "optional": true
          },
          {
            "name": "years_experience",
            "type": "INTEGER",
            "description": "Number of years in practice",
            "optional": true
          },
          {
            "name": "average_rating",
            "type": "DECIMAL(3,2)",
            "description": "Average patient rating out of 5",
            "optional": true
          },
          {
            "name": "average_consultation_minutes",
            "type": "INTEGER",
            "description": "Average consultation duration in minutes",
            "optional": true,
            "default": "30"
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when provider was added to system",
            "optional": false
          }
        ],
        "primary_key": "provider_id"
      }
    },
    {
      "table_name": "provider_specialty",
      "description": "Stores specialties associated with healthcare providers",
      "schema": {
        "columns": [
          {
            "name": "specialty_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the specialty record",
            "optional": false
          },
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Reference to healthcare provider",
            "optional": false,
            "references": "healthcare_provider.provider_id"
          },
          {
            "name": "specialty",
            "type": "VARCHAR(100)",
            "description": "Medical specialty",
            "optional": false,
            "enum": [
              "General Practice",
              "Cardiology",
              "Dermatology",
              "Pediatrics",
              "Psychiatry",
              "Orthopedics",
              "Neurology",
              "Endocrinology"
            ]
          }
        ],
        "primary_key": "specialty_id"
      }
    },
    {
      "table_name": "provider_language",
      "description": "Stores languages spoken by healthcare providers",
      "schema": {
        "columns": [
          {
            "name": "language_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the language record",
            "optional": false
          },
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Reference to healthcare provider",
            "optional": false,
            "references": "healthcare_provider.provider_id"
          },
          {
            "name": "language",
            "type": "VARCHAR(50)",
            "description": "Language spoken by provider",
            "optional": false
          }
        ],
        "primary_key": "language_id"
      }
    },
    {
      "table_name": "appointment",
      "description": "Stores telehealth appointment information",
      "schema": {
        "columns": [
          {
            "name": "appointment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the appointment",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Reference to healthcare provider",
            "optional": false,
            "references": "healthcare_provider.provider_id"
          },
          {
            "name": "appointment_datetime",
            "type": "TIMESTAMP",
            "description": "Scheduled date and time of appointment",
            "optional": false
          },
          {
            "name": "appointment_type",
            "type": "VARCHAR(50)",
            "description": "Type of appointment",
            "optional": false,
            "enum": [
              "video_consultation",
              "phone_consultation",
              "in_person"
            ]
          },
          {
            "name": "reason_for_visit",
            "type": "TEXT",
            "description": "Brief description of the reason for the appointment",
            "optional": false
          },
          {
            "name": "duration_minutes",
            "type": "INTEGER",
            "description": "Expected duration of appointment in minutes",
            "optional": true,
            "default": "30"
          },
          {
            "name": "status",
            "type": "VARCHAR(50)",
            "description": "Current status of the appointment",
            "optional": false,
            "default": "scheduled",
            "enum": [
              "scheduled",
              "completed",
              "cancelled",
              "no_show"
            ]
          },
          {
            "name": "confirmation_number",
            "type": "VARCHAR(50)",
            "description": "Appointment confirmation number",
            "optional": true
          },
          {
            "name": "cancellation_reason",
            "type": "TEXT",
            "description": "Reason for cancelling the appointment",
            "optional": true
          },
          {
            "name": "cancelled_by",
            "type": "VARCHAR(20)",
            "description": "Who initiated the cancellation",
            "optional": true,
            "enum": [
              "patient",
              "provider",
              "system"
            ]
          },
          {
            "name": "reschedule_reason",
            "type": "TEXT",
            "description": "Reason for rescheduling",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when appointment was created",
            "optional": false
          },
          {
            "name": "cancelled_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when appointment was cancelled",
            "optional": true
          },
          {
            "name": "rescheduled_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when appointment was rescheduled",
            "optional": true
          }
        ],
        "primary_key": "appointment_id"
      }
    },
    {
      "table_name": "medical_document",
      "description": "Stores medical documents and files uploaded to patient health records",
      "schema": {
        "columns": [
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the document",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "document_type",
            "type": "VARCHAR(50)",
            "description": "Type of medical document",
            "optional": false,
            "enum": [
              "lab_result",
              "prescription",
              "imaging_report",
              "insurance_card",
              "medical_history",
              "vaccination_record"
            ]
          },
          {
            "name": "file_name",
            "type": "VARCHAR(255)",
            "description": "Name of the file",
            "optional": false
          },
          {
            "name": "file_size_bytes",
            "type": "INTEGER",
            "description": "Size of the file in bytes",
            "optional": false
          },
          {
            "name": "file_format",
            "type": "VARCHAR(10)",
            "description": "Format of the file",
            "optional": false,
            "enum": [
              "pdf",
              "jpg",
              "png",
              "docx"
            ]
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Brief description of the document",
            "optional": true
          },
          {
            "name": "file_path",
            "type": "VARCHAR(500)",
            "description": "Storage path of the document",
            "optional": false
          },
          {
            "name": "upload_status",
            "type": "VARCHAR(50)",
            "description": "Status of the upload operation",
            "optional": false,
            "default": "success"
          },
          {
            "name": "uploaded_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when document was uploaded",
            "optional": false
          },
          {
            "name": "deleted_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when document was deleted",
            "optional": true
          },
          {
            "name": "deletion_reason",
            "type": "TEXT",
            "description": "Reason for deleting the document",
            "optional": true
          }
        ],
        "primary_key": "document_id"
      }
    },
    {
      "table_name": "medication",
      "description": "Stores patient's current and historical medication information",
      "schema": {
        "columns": [
          {
            "name": "medication_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the medication entry",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "medication_name",
            "type": "VARCHAR(255)",
            "description": "Name of the medication",
            "optional": false
          },
          {
            "name": "dosage",
            "type": "VARCHAR(100)",
            "description": "Dosage amount and unit",
            "optional": false
          },
          {
            "name": "frequency",
            "type": "VARCHAR(100)",
            "description": "How often the medication should be taken",
            "optional": false
          },
          {
            "name": "start_date",
            "type": "DATE",
            "description": "Date when medication was started",
            "optional": false
          },
          {
            "name": "prescribing_provider",
            "type": "VARCHAR(200)",
            "description": "Name of the provider who prescribed the medication",
            "optional": true
          },
          {
            "name": "instructions",
            "type": "TEXT",
            "description": "Special instructions for taking the medication",
            "optional": true
          },
          {
            "name": "is_active",
            "type": "BOOLEAN",
            "description": "Whether medication is currently active",
            "optional": false,
            "default": "true"
          },
          {
            "name": "discontinuation_date",
            "type": "DATE",
            "description": "Date when medication was discontinued",
            "optional": true
          },
          {
            "name": "discontinuation_reason",
            "type": "TEXT",
            "description": "Reason for discontinuing the medication",
            "optional": true
          },
          {
            "name": "added_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when medication was added",
            "optional": false
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when medication was updated",
            "optional": true
          },
          {
            "name": "removed_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when medication was removed",
            "optional": true
          }
        ],
        "primary_key": "medication_id"
      }
    },
    {
      "table_name": "medication_reminder",
      "description": "Stores medication reminder configurations for patients",
      "schema": {
        "columns": [
          {
            "name": "reminder_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the medication reminder",
            "optional": false
          },
          {
            "name": "medication_id",
            "type": "VARCHAR(10)",
            "description": "Reference to medication",
            "optional": false,
            "references": "medication.medication_id"
          },
          {
            "name": "notification_method",
            "type": "VARCHAR(50)",
            "description": "Method for sending reminders",
            "optional": false,
            "enum": [
              "push_notification",
              "sms",
              "email",
              "all"
            ]
          },
          {
            "name": "reminder_enabled",
            "type": "BOOLEAN",
            "description": "Whether the reminder is enabled",
            "optional": false,
            "default": "true"
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when reminder was created",
            "optional": false
          }
        ],
        "primary_key": "reminder_id"
      }
    },
    {
      "table_name": "reminder_time",
      "description": "Stores specific times for medication reminders",
      "schema": {
        "columns": [
          {
            "name": "reminder_time_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the reminder time",
            "optional": false
          },
          {
            "name": "reminder_id",
            "type": "VARCHAR(10)",
            "description": "Reference to medication reminder",
            "optional": false,
            "references": "medication_reminder.reminder_id"
          },
          {
            "name": "reminder_time",
            "type": "TIME",
            "description": "Time to send reminder in HH:MM format",
            "optional": false
          }
        ],
        "primary_key": "reminder_time_id"
      }
    },
    {
      "table_name": "prescription",
      "description": "Stores prescription information for patients",
      "schema": {
        "columns": [
          {
            "name": "prescription_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the prescription",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Reference to prescribing provider",
            "optional": false,
            "references": "healthcare_provider.provider_id"
          },
          {
            "name": "medication_name",
            "type": "VARCHAR(255)",
            "description": "Name of prescribed medication",
            "optional": false
          },
          {
            "name": "prescribed_date",
            "type": "DATE",
            "description": "Date when prescription was written",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(50)",
            "description": "Current status of the prescription",
            "optional": false,
            "enum": [
              "active",
              "completed",
              "cancelled"
            ]
          },
          {
            "name": "refills_remaining",
            "type": "INTEGER",
            "description": "Number of refills remaining",
            "optional": true
          },
          {
            "name": "created_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when prescription was created",
            "optional": false
          }
        ],
        "primary_key": "prescription_id"
      }
    },
    {
      "table_name": "prescription_refill_request",
      "description": "Stores prescription refill requests from patients",
      "schema": {
        "columns": [
          {
            "name": "refill_request_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the refill request",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "prescription_id",
            "type": "VARCHAR(10)",
            "description": "Reference to prescription",
            "optional": false,
            "references": "prescription.prescription_id"
          },
          {
            "name": "pharmacy_id",
            "type": "VARCHAR(10)",
            "description": "Reference to preferred pharmacy",
            "optional": false,
            "references": "pharmacy.pharmacy_id"
          },
          {
            "name": "urgency_level",
            "type": "VARCHAR(20)",
            "description": "Urgency level of the refill request",
            "optional": true,
            "default": "routine",
            "enum": [
              "routine",
              "urgent",
              "emergency"
            ]
          },
          {
            "name": "additional_notes",
            "type": "TEXT",
            "description": "Additional notes or comments for the refill request",
            "optional": true
          },
          {
            "name": "request_status",
            "type": "VARCHAR(50)",
            "description": "Status of the refill request",
            "optional": false,
            "default": "pending_approval"
          },
          {
            "name": "submitted_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when request was submitted",
            "optional": false
          }
        ],
        "primary_key": "refill_request_id"
      }
    },
    {
      "table_name": "pharmacy",
      "description": "Stores patient's preferred pharmacy information",
      "schema": {
        "columns": [
          {
            "name": "pharmacy_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the pharmacy entry",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "pharmacy_name",
            "type": "VARCHAR(255)",
            "description": "Name of the pharmacy",
            "optional": false
          },
          {
            "name": "pharmacy_address",
            "type": "TEXT",
            "description": "Full address of the pharmacy",
            "optional": false
          },
          {
            "name": "pharmacy_phone",
            "type": "VARCHAR(20)",
            "description": "Phone number of the pharmacy",
            "optional": false
          },
          {
            "name": "is_primary",
            "type": "BOOLEAN",
            "description": "Whether this is the primary pharmacy",
            "optional": false,
            "default": "false"
          },
          {
            "name": "added_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when pharmacy was added",
            "optional": false
          }
        ],
        "primary_key": "pharmacy_id"
      }
    },
    {
      "table_name": "secure_message",
      "description": "Stores secure messages between patients and providers",
      "schema": {
        "columns": [
          {
            "name": "message_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the message",
            "optional": false
          },
          {
            "name": "thread_id",
            "type": "VARCHAR(10)",
            "description": "Identifier for the message thread",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Reference to provider",
            "optional": false,
            "references": "healthcare_provider.provider_id"
          },
          {
            "name": "sender_type",
            "type": "VARCHAR(20)",
            "description": "Type of sender",
            "optional": false,
            "enum": [
              "patient",
              "provider"
            ]
          },
          {
            "name": "subject",
            "type": "VARCHAR(255)",
            "description": "Subject line of the message",
            "optional": false
          },
          {
            "name": "message_body",
            "type": "TEXT",
            "description": "Content of the message",
            "optional": false
          },
          {
            "name": "priority",
            "type": "VARCHAR(20)",
            "description": "Priority level of the message",
            "optional": true,
            "default": "normal",
            "enum": [
              "low",
              "normal",
              "high",
              "urgent"
            ]
          },
          {
            "name": "is_read",
            "type": "BOOLEAN",
            "description": "Whether message has been read",
            "optional": false,
            "default": "false"
          },
          {
            "name": "delivery_status",
            "type": "VARCHAR(50)",
            "description": "Status of message delivery",
            "optional": false,
            "default": "delivered"
          },
          {
            "name": "sent_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when message was sent",
            "optional": false
          },
          {
            "name": "read_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when message was marked as read",
            "optional": true
          }
        ],
        "primary_key": "message_id"
      }
    },
    {
      "table_name": "message_attachment",
      "description": "Stores attachments associated with secure messages",
      "schema": {
        "columns": [
          {
            "name": "attachment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the attachment",
            "optional": false
          },
          {
            "name": "message_id",
            "type": "VARCHAR(10)",
            "description": "Reference to message",
            "optional": false,
            "references": "secure_message.message_id"
          },
          {
            "name": "document_id",
            "type": "VARCHAR(10)",
            "description": "Reference to document",
            "optional": false,
            "references": "medical_document.document_id"
          }
        ],
        "primary_key": "attachment_id"
      }
    },
    {
      "table_name": "insurance",
      "description": "Stores patient insurance coverage information",
      "schema": {
        "columns": [
          {
            "name": "insurance_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the insurance record",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "insurance_provider",
            "type": "VARCHAR(255)",
            "description": "Name of the insurance company",
            "optional": false
          },
          {
            "name": "policy_number",
            "type": "VARCHAR(100)",
            "description": "Insurance policy number",
            "optional": false
          },
          {
            "name": "group_number",
            "type": "VARCHAR(100)",
            "description": "Insurance group number",
            "optional": true
          },
          {
            "name": "policy_holder_name",
            "type": "VARCHAR(200)",
            "description": "Name of the policy holder",
            "optional": false
          },
          {
            "name": "relationship_to_patient",
            "type": "VARCHAR(20)",
            "description": "Relationship of policy holder to patient",
            "optional": false,
            "enum": [
              "self",
              "spouse",
              "parent",
              "child",
              "other"
            ]
          },
          {
            "name": "coverage_start_date",
            "type": "DATE",
            "description": "Date when coverage starts",
            "optional": true
          },
          {
            "name": "coverage_end_date",
            "type": "DATE",
            "description": "Date when coverage ends",
            "optional": true
          },
          {
            "name": "verification_status",
            "type": "VARCHAR(50)",
            "description": "Status of insurance verification",
            "optional": false,
            "default": "pending_verification"
          },
          {
            "name": "added_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when insurance was added",
            "optional": false
          }
        ],
        "primary_key": "insurance_id"
      }
    },
    {
      "table_name": "payment",
      "description": "Stores payment transactions for telehealth services",
      "schema": {
        "columns": [
          {
            "name": "payment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the payment transaction",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "appointment_id",
            "type": "VARCHAR(10)",
            "description": "Reference to appointment",
            "optional": false,
            "references": "appointment.appointment_id"
          },
          {
            "name": "payment_amount",
            "type": "DECIMAL(10,2)",
            "description": "Amount paid",
            "optional": false
          },
          {
            "name": "payment_method",
            "type": "VARCHAR(50)",
            "description": "Method of payment",
            "optional": false,
            "enum": [
              "credit_card",
              "debit_card",
              "insurance",
              "health_savings_account"
            ]
          },
          {
            "name": "card_last_four",
            "type": "VARCHAR(4)",
            "description": "Last four digits of payment card",
            "optional": true
          },
          {
            "name": "transaction_status",
            "type": "VARCHAR(50)",
            "description": "Status of the payment transaction",
            "optional": false,
            "default": "completed"
          },
          {
            "name": "receipt_number",
            "type": "VARCHAR(50)",
            "description": "Receipt number for the payment",
            "optional": true
          },
          {
            "name": "processed_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when payment was processed",
            "optional": false
          }
        ],
        "primary_key": "payment_id"
      }
    },
    {
      "table_name": "allergy",
      "description": "Stores patient allergy information",
      "schema": {
        "columns": [
          {
            "name": "allergy_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the allergy record",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "allergen",
            "type": "VARCHAR(255)",
            "description": "Name of the allergen",
            "optional": false
          },
          {
            "name": "allergy_type",
            "type": "VARCHAR(50)",
            "description": "Type of allergy",
            "optional": false,
            "enum": [
              "medication",
              "food",
              "environmental",
              "other"
            ]
          },
          {
            "name": "reaction",
            "type": "TEXT",
            "description": "Description of allergic reaction",
            "optional": false
          },
          {
            "name": "severity",
            "type": "VARCHAR(20)",
            "description": "Severity level of the allergy",
            "optional": false,
            "enum": [
              "mild",
              "moderate",
              "severe",
              "life_threatening"
            ]
          },
          {
            "name": "onset_date",
            "type": "DATE",
            "description": "Date when allergy was first identified",
            "optional": true
          },
          {
            "name": "added_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when allergy was added",
            "optional": false
          }
        ],
        "primary_key": "allergy_id"
      }
    },
    {
      "table_name": "medical_condition",
      "description": "Stores patient's medical conditions and diagnoses",
      "schema": {
        "columns": [
          {
            "name": "condition_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the condition record",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "condition_name",
            "type": "VARCHAR(255)",
            "description": "Name of the medical condition",
            "optional": false
          },
          {
            "name": "diagnosis_date",
            "type": "DATE",
            "description": "Date when condition was diagnosed",
            "optional": false
          },
          {
            "name": "condition_status",
            "type": "VARCHAR(50)",
            "description": "Current status of the condition",
            "optional": false,
            "enum": [
              "active",
              "resolved",
              "chronic",
              "in_remission"
            ]
          },
          {
            "name": "severity",
            "type": "VARCHAR(20)",
            "description": "Severity of the condition",
            "optional": true,
            "enum": [
              "mild",
              "moderate",
              "severe"
            ]
          },
          {
            "name": "notes",
            "type": "TEXT",
            "description": "Additional notes about the condition",
            "optional": true
          },
          {
            "name": "added_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when condition was added",
            "optional": false
          }
        ],
        "primary_key": "condition_id"
      }
    },
    {
      "table_name": "vital_sign",
      "description": "Stores patient vital signs measurements from home monitoring",
      "schema": {
        "columns": [
          {
            "name": "vital_signs_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the vital signs record",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "measurement_datetime",
            "type": "TIMESTAMP",
            "description": "Date and time when measurements were taken",
            "optional": false
          },
          {
            "name": "blood_pressure_systolic",
            "type": "INTEGER",
            "description": "Systolic blood pressure in mmHg",
            "optional": true
          },
          {
            "name": "blood_pressure_diastolic",
            "type": "INTEGER",
            "description": "Diastolic blood pressure in mmHg",
            "optional": true
          },
          {
            "name": "heart_rate",
            "type": "INTEGER",
            "description": "Heart rate in beats per minute",
            "optional": true
          },
          {
            "name": "temperature",
            "type": "DECIMAL(4,1)",
            "description": "Body temperature in Fahrenheit",
            "optional": true
          },
          {
            "name": "oxygen_saturation",
            "type": "INTEGER",
            "description": "Blood oxygen saturation percentage",
            "optional": true
          },
          {
            "name": "weight",
            "type": "DECIMAL(5,1)",
            "description": "Body weight in pounds",
            "optional": true
          },
          {
            "name": "recorded_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when record was created",
            "optional": false
          }
        ],
        "primary_key": "vital_signs_id"
      }
    },
    {
      "table_name": "provider_rating",
      "description": "Stores patient ratings and reviews for healthcare providers",
      "schema": {
        "columns": [
          {
            "name": "rating_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the rating record",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "provider_id",
            "type": "VARCHAR(10)",
            "description": "Reference to provider",
            "optional": false,
            "references": "healthcare_provider.provider_id"
          },
          {
            "name": "appointment_id",
            "type": "VARCHAR(10)",
            "description": "Reference to appointment",
            "optional": false,
            "references": "appointment.appointment_id"
          },
          {
            "name": "overall_rating",
            "type": "INTEGER",
            "description": "Overall rating from 1 to 5 stars",
            "optional": false
          },
          {
            "name": "communication_rating",
            "type": "INTEGER",
            "description": "Rating for provider communication",
            "optional": true
          },
          {
            "name": "professionalism_rating",
            "type": "INTEGER",
            "description": "Rating for provider professionalism",
            "optional": true
          },
          {
            "name": "written_review",
            "type": "TEXT",
            "description": "Written review comments",
            "optional": true
          },
          {
            "name": "would_recommend",
            "type": "BOOLEAN",
            "description": "Whether patient would recommend this provider",
            "optional": true
          },
          {
            "name": "submitted_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when rating was submitted",
            "optional": false
          }
        ],
        "primary_key": "rating_id"
      }
    },
    {
      "table_name": "notification_preference",
      "description": "Stores patient notification preferences",
      "schema": {
        "columns": [
          {
            "name": "preference_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the preference record",
            "optional": false
          },
          {
            "name": "patient_id",
            "type": "VARCHAR(10)",
            "description": "Reference to patient",
            "optional": false,
            "references": "patient.patient_id"
          },
          {
            "name": "appointment_reminders",
            "type": "BOOLEAN",
            "description": "Enable appointment reminder notifications",
            "optional": false,
            "default": "true"
          },
          {
            "name": "message_notifications",
            "type": "BOOLEAN",
            "description": "Enable new message notifications",
            "optional": false,
            "default": "true"
          },
          {
            "name": "medication_reminders",
            "type": "BOOLEAN",
            "description": "Enable medication reminder notifications",
            "optional": false,
            "default": "true"
          },
          {
            "name": "lab_result_notifications",
            "type": "BOOLEAN",
            "description": "Enable lab result availability notifications",
            "optional": false,
            "default": "true"
          },
          {
            "name": "updated_at",
            "type": "TIMESTAMP",
            "description": "Timestamp when preferences were updated",
            "optional": true
          }
        ],
        "primary_key": "preference_id"
      }
    },
    {
      "table_name": "notification_channel",
      "description": "Stores preferred notification channels for patients",
      "schema": {
        "columns": [
          {
            "name": "channel_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the channel record",
            "optional": false
          },
          {
            "name": "preference_id",
            "type": "VARCHAR(10)",
            "description": "Reference to notification preference",
            "optional": false,
            "references": "notification_preference.preference_id"
          },
          {
            "name": "channel_type",
            "type": "VARCHAR(50)",
            "description": "Type of notification channel",
            "optional": false,
            "enum": [
              "email",
              "sms",
              "push_notification",
              "in_app"
            ]
          }
        ],
        "primary_key": "channel_id"
      }
    }
  ],
  "tools": [
    {
      "name": "add_insurance_information",
      "description": "Add insurance coverage information to patient's profile",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "insurance_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Insurance information is added to patient's profile",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "insurance_provider": {
            "description": "Name of the insurance company",
            "type": "string",
            "examples": [
              "Blue Cross Blue Shield"
            ]
          },
          "policy_number": {
            "description": "Insurance policy number",
            "type": "string",
            "examples": [
              "BCBS-123456789"
            ]
          },
          "group_number": {
            "description": "Insurance group number",
            "type": "string",
            "examples": [
              "GRP-987654"
            ]
          },
          "policy_holder_name": {
            "description": "Name of the policy holder",
            "type": "string",
            "examples": [
              "John Smith"
            ]
          },
          "relationship_to_patient": {
            "description": "Relationship of policy holder to patient",
            "type": "string",
            "enum": [
              "self",
              "spouse",
              "parent",
              "child",
              "other"
            ],
            "examples": [
              "self"
            ]
          },
          "coverage_start_date": {
            "description": "Date when coverage starts in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "coverage_end_date": {
            "description": "Date when coverage ends in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        },
        "required": [
          "patient_id",
          "insurance_provider",
          "policy_number",
          "policy_holder_name",
          "relationship_to_patient"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "insurance_id": {
            "description": "Unique identifier for the insurance record",
            "type": "string",
            "examples": [
              "INS-20240115-001"
            ]
          },
          "verification_status": {
            "description": "Status of insurance verification",
            "type": "string",
            "examples": [
              "pending_verification"
            ]
          },
          "added_at": {
            "description": "Timestamp when insurance was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 23:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "insurance"
      ]
    },
    {
      "name": "get_vital_signs_history",
      "description": "Retrieve historical vital signs data for a patient with date range filtering",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "health_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Vital signs history is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "start_date": {
            "description": "Start date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-31"
            ]
          },
          "measurement_type": {
            "description": "Specific vital sign to retrieve",
            "type": "string",
            "enum": [
              "blood_pressure",
              "heart_rate",
              "temperature",
              "oxygen_saturation",
              "weight",
              "all"
            ],
            "examples": [
              "blood_pressure"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "vital_signs_records": {
            "description": "List of vital signs measurements",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "measurement_datetime": "2024-01-16 08:00:00",
                  "blood_pressure": "120/80",
                  "heart_rate": 72
                }
              ]
            ]
          },
          "record_count": {
            "description": "Total number of records",
            "type": "integer",
            "examples": [
              30
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "vital_sign"
      ]
    },
    {
      "name": "request_prescription_refill",
      "description": "Submit a request to refill an existing prescription",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "prescription_management",
      "action_category": "data_management",
      "pre_condition": "Prescription must exist and be eligible for refill",
      "post_condition": "Refill request is submitted to provider for approval",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "prescription_id": {
            "description": "Unique identifier of the prescription",
            "type": "string",
            "examples": [
              "RX-20240115-001"
            ]
          },
          "pharmacy_id": {
            "description": "Unique identifier of the preferred pharmacy",
            "type": "string",
            "examples": [
              "PHARM-001"
            ]
          },
          "urgency_level": {
            "description": "Urgency level of the refill request",
            "type": "string",
            "enum": [
              "routine",
              "urgent",
              "emergency"
            ],
            "examples": [
              "routine"
            ]
          },
          "additional_notes": {
            "description": "Additional notes or comments for the refill request",
            "type": "string",
            "examples": [
              "Running low on medication, need refill within 3 days"
            ]
          }
        },
        "required": [
          "patient_id",
          "prescription_id",
          "pharmacy_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "refill_request_id": {
            "description": "Unique identifier for the refill request",
            "type": "string",
            "examples": [
              "REFILL-20240115-001"
            ]
          },
          "request_status": {
            "description": "Status of the refill request",
            "type": "string",
            "examples": [
              "pending_approval"
            ]
          },
          "submitted_at": {
            "description": "Timestamp when request was submitted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 20:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "prescription_refill_request"
      ]
    },
    {
      "name": "download_medical_document",
      "description": "Download a medical document from patient's health records",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "document_management",
      "action_category": "data_management",
      "pre_condition": "Document must exist and patient must have access rights",
      "post_condition": "Document download link is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "Unique identifier of the document",
            "type": "string",
            "examples": [
              "DOC-20240115-001"
            ]
          },
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "document_id",
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "download_url": {
            "description": "Secure URL for downloading the document",
            "type": "string",
            "examples": [
              "https://telehealth.example.com/documents/DOC-20240115-001?token=xyz789"
            ]
          },
          "file_name": {
            "description": "Name of the file",
            "type": "string",
            "examples": [
              "blood_test_results_2024.pdf"
            ]
          },
          "file_size_bytes": {
            "description": "Size of the file in bytes",
            "type": "integer",
            "examples": [
              524288
            ]
          },
          "expires_at": {
            "description": "Expiration time of download URL in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 17:45:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medical_document"
      ]
    },
    {
      "name": "upload_medical_document",
      "description": "Upload a medical document or file to patient's health records",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "document_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated and file must meet format requirements",
      "post_condition": "Document is uploaded and stored securely",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "document_type": {
            "description": "Type of medical document",
            "type": "string",
            "enum": [
              "lab_result",
              "prescription",
              "imaging_report",
              "insurance_card",
              "medical_history",
              "vaccination_record"
            ],
            "examples": [
              "lab_result"
            ]
          },
          "file_name": {
            "description": "Name of the file being uploaded",
            "type": "string",
            "examples": [
              "blood_test_results_2024.pdf"
            ]
          },
          "file_size_bytes": {
            "description": "Size of the file in bytes",
            "type": "integer",
            "examples": [
              524288
            ]
          },
          "file_format": {
            "description": "Format of the file",
            "type": "string",
            "enum": [
              "pdf",
              "jpg",
              "png",
              "docx"
            ],
            "examples": [
              "pdf"
            ]
          },
          "description": {
            "description": "Brief description of the document",
            "type": "string",
            "examples": [
              "Complete blood count results from annual checkup"
            ]
          }
        },
        "required": [
          "patient_id",
          "document_type",
          "file_name",
          "file_size_bytes",
          "file_format"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "Unique identifier for the uploaded document",
            "type": "string",
            "examples": [
              "DOC-20240115-001"
            ]
          },
          "upload_status": {
            "description": "Status of the upload operation",
            "type": "string",
            "examples": [
              "success"
            ]
          },
          "uploaded_at": {
            "description": "Timestamp when document was uploaded in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 16:45:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medical_document"
      ]
    },
    {
      "name": "record_vital_signs",
      "description": "Record patient's vital signs measurements from home monitoring",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "health_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Vital signs are recorded and stored",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "measurement_datetime": {
            "description": "Date and time when measurements were taken in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 08:00:00"
            ]
          },
          "blood_pressure_systolic": {
            "description": "Systolic blood pressure in mmHg",
            "type": "integer",
            "examples": [
              120
            ]
          },
          "blood_pressure_diastolic": {
            "description": "Diastolic blood pressure in mmHg",
            "type": "integer",
            "examples": [
              80
            ]
          },
          "heart_rate": {
            "description": "Heart rate in beats per minute",
            "type": "integer",
            "examples": [
              72
            ]
          },
          "temperature": {
            "description": "Body temperature in Fahrenheit",
            "type": "number",
            "examples": [
              98.6
            ]
          },
          "oxygen_saturation": {
            "description": "Blood oxygen saturation percentage",
            "type": "integer",
            "examples": [
              98
            ]
          },
          "weight": {
            "description": "Body weight in pounds",
            "type": "number",
            "examples": [
              165.5
            ]
          }
        },
        "required": [
          "patient_id",
          "measurement_datetime"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "vital_signs_id": {
            "description": "Unique identifier for the vital signs record",
            "type": "string",
            "examples": [
              "VS-20240116-001"
            ]
          },
          "recorded_at": {
            "description": "Timestamp when record was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 08:05:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "vital_sign"
      ]
    },
    {
      "name": "mark_message_as_read",
      "description": "Mark a message or message thread as read by the patient",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "communication_management",
      "action_category": "state_management",
      "pre_condition": "Message must exist and belong to the patient",
      "post_condition": "Message read status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of the message",
            "type": "string",
            "examples": [
              "MSG-20240115-001"
            ]
          },
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "message_id",
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "update_status": {
            "description": "Status of the update operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "read_at": {
            "description": "Timestamp when message was marked as read in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 11:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "secure_message"
      ]
    },
    {
      "name": "set_medication_reminder",
      "description": "Set up a reminder notification for taking a specific medication",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "medication_management",
      "action_category": "configuration",
      "pre_condition": "Medication must exist in patient's medication list",
      "post_condition": "Medication reminder is configured and activated",
      "parameters": {
        "type": "object",
        "properties": {
          "medication_id": {
            "description": "Unique identifier of the medication",
            "type": "string",
            "examples": [
              "MED-20240115-001"
            ]
          },
          "reminder_times": {
            "description": "List of times to send reminders in HH:MM format",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "08:00",
                "20:00"
              ]
            ]
          },
          "notification_method": {
            "description": "Method for sending reminders",
            "type": "string",
            "enum": [
              "push_notification",
              "sms",
              "email",
              "all"
            ],
            "examples": [
              "push_notification"
            ]
          },
          "reminder_enabled": {
            "description": "Whether the reminder is enabled",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "medication_id",
          "reminder_times",
          "notification_method"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reminder_id": {
            "description": "Unique identifier for the medication reminder",
            "type": "string",
            "examples": [
              "REM-20240115-001"
            ]
          },
          "setup_status": {
            "description": "Status of reminder setup",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "created_at": {
            "description": "Timestamp when reminder was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 19:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medication_reminder",
        "reminder_time"
      ]
    },
    {
      "name": "get_provider_details",
      "description": "Retrieve detailed information about a specific healthcare provider including credentials, specialties, and ratings",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "provider_management",
      "action_category": "data_management",
      "pre_condition": "Provider must exist in the system",
      "post_condition": "Provider details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "provider_id": {
            "description": "Unique identifier of the healthcare provider",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          }
        },
        "required": [
          "provider_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "provider_id": {
            "description": "Unique identifier of the provider",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          },
          "full_name": {
            "description": "Provider's full name with title",
            "type": "string",
            "examples": [
              "Dr. Sarah Johnson"
            ]
          },
          "specialties": {
            "description": "List of provider's medical specialties",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Cardiology",
                "Internal Medicine"
              ]
            ]
          },
          "credentials": {
            "description": "Professional credentials and certifications",
            "type": "string",
            "examples": [
              "MD, FACC, Board Certified"
            ]
          },
          "years_experience": {
            "description": "Number of years in practice",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "average_rating": {
            "description": "Average patient rating out of 5",
            "type": "number",
            "examples": [
              4.8
            ]
          },
          "languages_spoken": {
            "description": "Languages the provider speaks",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "English",
                "Spanish"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "healthcare_provider",
        "provider_specialty",
        "provider_language"
      ]
    },
    {
      "name": "list_patient_messages",
      "description": "Retrieve list of all message threads for a patient with optional filtering",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "communication_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of message threads is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "status_filter": {
            "description": "Filter messages by read status",
            "type": "string",
            "enum": [
              "unread",
              "read",
              "all"
            ],
            "examples": [
              "unread"
            ]
          },
          "provider_id": {
            "description": "Filter messages by specific provider",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "message_threads": {
            "description": "List of message threads",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "thread_id": "THREAD-20240115-001",
                  "subject": "Question about medication",
                  "last_message_at": "2024-01-16 10:00:00"
                }
              ]
            ]
          },
          "unread_count": {
            "description": "Number of unread messages",
            "type": "integer",
            "examples": [
              2
            ]
          },
          "total_threads": {
            "description": "Total number of message threads",
            "type": "integer",
            "examples": [
              8
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "secure_message"
      ]
    },
    {
      "name": "validate_appointment_eligibility",
      "description": "Validate whether a patient is eligible to schedule an appointment based on insurance, medical history, and provider requirements",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "validation",
      "pre_condition": "Patient profile and provider information must be available",
      "post_condition": "Eligibility status is determined and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_age": {
            "description": "Patient's age in years",
            "type": "integer",
            "examples": [
              38
            ]
          },
          "has_active_insurance": {
            "description": "Whether patient has active insurance coverage",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "insurance_covers_telehealth": {
            "description": "Whether insurance covers telehealth services",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "specialty": {
            "description": "Medical specialty of the provider",
            "type": "string",
            "examples": [
              "Cardiology"
            ]
          },
          "appointment_type": {
            "description": "Type of appointment requested",
            "type": "string",
            "enum": [
              "video_consultation",
              "phone_consultation",
              "in_person"
            ],
            "examples": [
              "video_consultation"
            ]
          },
          "has_previous_visits": {
            "description": "Whether patient has had previous visits with this provider",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "patient_age",
          "has_active_insurance",
          "insurance_covers_telehealth",
          "specialty",
          "appointment_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_eligible": {
            "description": "Whether patient is eligible for the appointment",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "eligibility_reasons": {
            "description": "List of reasons affecting eligibility",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Insurance covers service",
                "Age requirement met",
                "Previous patient relationship exists"
              ]
            ]
          },
          "required_actions": {
            "description": "Actions needed if not fully eligible",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "list_patient_appointments",
      "description": "Retrieve list of all appointments for a patient with optional filtering by status and date range",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of patient appointments is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "status_filter": {
            "description": "Filter appointments by status",
            "type": "string",
            "enum": [
              "scheduled",
              "completed",
              "cancelled",
              "no_show",
              "all"
            ],
            "examples": [
              "scheduled"
            ]
          },
          "start_date": {
            "description": "Start date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "appointments": {
            "description": "List of patient appointments",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "appointment_id": "APT-20240120-001",
                  "provider_name": "Dr. Sarah Johnson",
                  "datetime": "2024-01-20 09:00:00"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of appointments",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "appointment"
      ]
    },
    {
      "name": "get_medical_history",
      "description": "Retrieve complete medical history including conditions, surgeries, and family history",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "health_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Complete medical history is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "conditions": {
            "description": "List of medical conditions",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "condition_id": "COND-20240115-001",
                  "condition_name": "Hypertension",
                  "status": "active"
                }
              ]
            ]
          },
          "surgeries": {
            "description": "List of past surgeries",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "surgery_name": "Appendectomy",
                  "date": "2018-07-10"
                }
              ]
            ]
          },
          "family_history": {
            "description": "Relevant family medical history",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "condition": "Diabetes",
                  "relationship": "father"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medical_condition"
      ]
    },
    {
      "name": "get_current_medications",
      "description": "Retrieve list of all current active medications for a patient",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "medication_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of current medications is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "medications": {
            "description": "List of current medications",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "medication_id": "MED-20240115-001",
                  "medication_name": "Lisinopril",
                  "dosage": "10mg",
                  "frequency": "Once daily"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of current medications",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medication"
      ]
    },
    {
      "name": "add_medical_condition",
      "description": "Add a medical condition or diagnosis to patient's health history",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "health_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Medical condition is added to patient's health history",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "condition_name": {
            "description": "Name of the medical condition",
            "type": "string",
            "examples": [
              "Hypertension"
            ]
          },
          "diagnosis_date": {
            "description": "Date when condition was diagnosed in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2020-05-15"
            ]
          },
          "condition_status": {
            "description": "Current status of the condition",
            "type": "string",
            "enum": [
              "active",
              "resolved",
              "chronic",
              "in_remission"
            ],
            "examples": [
              "active"
            ]
          },
          "severity": {
            "description": "Severity of the condition",
            "type": "string",
            "enum": [
              "mild",
              "moderate",
              "severe"
            ],
            "examples": [
              "moderate"
            ]
          },
          "notes": {
            "description": "Additional notes about the condition",
            "type": "string",
            "examples": [
              "Well controlled with medication"
            ]
          }
        },
        "required": [
          "patient_id",
          "condition_name",
          "diagnosis_date",
          "condition_status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "condition_id": {
            "description": "Unique identifier for the condition record",
            "type": "string",
            "examples": [
              "COND-20240115-001"
            ]
          },
          "added_at": {
            "description": "Timestamp when condition was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 11:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medical_condition"
      ]
    },
    {
      "name": "verify_patient_email",
      "description": "Verify patient email address using verification token sent during registration",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "account_management",
      "action_category": "validation",
      "pre_condition": "Patient account exists and email verification is pending",
      "post_condition": "Patient email is verified and account is activated",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient account",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "verification_token": {
            "description": "Email verification token sent to patient",
            "type": "string",
            "examples": [
              "VT-abc123xyz789"
            ]
          }
        },
        "required": [
          "patient_id",
          "verification_token"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "verification_status": {
            "description": "Status of email verification",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "account_status": {
            "description": "Updated account status after verification",
            "type": "string",
            "examples": [
              "active"
            ]
          },
          "verified_at": {
            "description": "Timestamp when email was verified in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 11:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "patient"
      ]
    },
    {
      "name": "get_appointment_details",
      "description": "Retrieve complete details of a specific appointment including provider information and visit reason",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "data_management",
      "pre_condition": "Appointment must exist and patient must have access rights",
      "post_condition": "Appointment details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "appointment_id": {
            "description": "Unique identifier of the appointment",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          }
        },
        "required": [
          "appointment_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "appointment_id": {
            "description": "Unique identifier of the appointment",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          },
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "provider_id": {
            "description": "Unique identifier of the provider",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          },
          "provider_name": {
            "description": "Name of the healthcare provider",
            "type": "string",
            "examples": [
              "Dr. Sarah Johnson"
            ]
          },
          "appointment_datetime": {
            "description": "Scheduled date and time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 09:00:00"
            ]
          },
          "appointment_type": {
            "description": "Type of appointment",
            "type": "string",
            "examples": [
              "video_consultation"
            ]
          },
          "status": {
            "description": "Current status of the appointment",
            "type": "string",
            "examples": [
              "scheduled"
            ]
          },
          "reason_for_visit": {
            "description": "Reason for the appointment",
            "type": "string",
            "examples": [
              "Follow-up consultation for chest pain"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "appointment",
        "patient",
        "healthcare_provider"
      ]
    },
    {
      "name": "search_healthcare_providers",
      "description": "Search for available healthcare providers based on specialty, location, and availability criteria",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "provider_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of matching healthcare providers is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "specialty": {
            "description": "Medical specialty of the provider",
            "type": "string",
            "enum": [
              "General Practice",
              "Cardiology",
              "Dermatology",
              "Pediatrics",
              "Psychiatry",
              "Orthopedics",
              "Neurology",
              "Endocrinology"
            ],
            "examples": [
              "Cardiology"
            ]
          },
          "location": {
            "description": "Geographic location or zip code",
            "type": "string",
            "examples": [
              "10001"
            ]
          },
          "availability_date": {
            "description": "Desired appointment date in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-20"
            ]
          },
          "insurance_provider": {
            "description": "Insurance provider name",
            "type": "string",
            "examples": [
              "Blue Cross Blue Shield"
            ]
          }
        },
        "required": [
          "specialty"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "providers": {
            "description": "List of matching healthcare providers",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "provider_id": "DOC-001",
                  "name": "Dr. Sarah Johnson",
                  "specialty": "Cardiology"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of providers found",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "healthcare_provider",
        "provider_specialty",
        "provider_language"
      ]
    },
    {
      "name": "calculate_appointment_wait_time",
      "description": "Calculate estimated wait time before appointment based on provider schedule and current queue",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "computation",
      "pre_condition": "Appointment must be scheduled",
      "post_condition": "Estimated wait time is calculated and returned",
      "parameters": {
        "type": "object",
        "properties": {
          "appointment_datetime": {
            "description": "Scheduled appointment time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 09:00:00"
            ]
          },
          "current_time": {
            "description": "Current time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 08:45:00"
            ]
          },
          "provider_average_consultation_minutes": {
            "description": "Provider's average consultation duration in minutes",
            "type": "integer",
            "examples": [
              30
            ]
          },
          "appointments_ahead_in_queue": {
            "description": "Number of appointments scheduled before this one",
            "type": "integer",
            "examples": [
              2
            ]
          }
        },
        "required": [
          "appointment_datetime",
          "current_time",
          "provider_average_consultation_minutes",
          "appointments_ahead_in_queue"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "estimated_wait_minutes": {
            "description": "Estimated wait time in minutes",
            "type": "integer",
            "examples": [
              75
            ]
          },
          "estimated_start_time": {
            "description": "Estimated actual start time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 10:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "remove_medication_from_list",
      "description": "Remove a medication from patient's current medication list",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "medication_management",
      "action_category": "data_management",
      "pre_condition": "Medication must exist in patient's medication list",
      "post_condition": "Medication is removed from the list",
      "parameters": {
        "type": "object",
        "properties": {
          "medication_id": {
            "description": "Unique identifier of the medication to remove",
            "type": "string",
            "examples": [
              "MED-20240115-001"
            ]
          },
          "discontinuation_date": {
            "description": "Date when medication was discontinued in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-20"
            ]
          },
          "discontinuation_reason": {
            "description": "Reason for discontinuing the medication",
            "type": "string",
            "examples": [
              "Completed treatment course"
            ]
          }
        },
        "required": [
          "medication_id",
          "discontinuation_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "removal_status": {
            "description": "Status of the removal operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "removed_at": {
            "description": "Timestamp when medication was removed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 10:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medication"
      ]
    },
    {
      "name": "get_message_thread",
      "description": "Retrieve a complete message thread between patient and provider",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "communication_management",
      "action_category": "data_management",
      "pre_condition": "Message thread must exist and patient must have access rights",
      "post_condition": "Message thread with all messages is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier of any message in the thread",
            "type": "string",
            "examples": [
              "MSG-20240115-001"
            ]
          },
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "message_id",
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "thread_id": {
            "description": "Unique identifier for the message thread",
            "type": "string",
            "examples": [
              "THREAD-20240115-001"
            ]
          },
          "messages": {
            "description": "List of all messages in the thread",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "message_id": "MSG-20240115-001",
                  "sender": "patient",
                  "sent_at": "2024-01-15 22:00:00",
                  "message_body": "Question about medication"
                }
              ]
            ]
          },
          "message_count": {
            "description": "Total number of messages in thread",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "secure_message"
      ]
    },
    {
      "name": "update_medication_details",
      "description": "Update details of an existing medication in patient's medication list",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "medication_management",
      "action_category": "data_management",
      "pre_condition": "Medication must exist in patient's medication list",
      "post_condition": "Medication details are updated",
      "parameters": {
        "type": "object",
        "properties": {
          "medication_id": {
            "description": "Unique identifier of the medication",
            "type": "string",
            "examples": [
              "MED-20240115-001"
            ]
          },
          "dosage": {
            "description": "Updated dosage amount and unit",
            "type": "string",
            "examples": [
              "20mg"
            ]
          },
          "frequency": {
            "description": "Updated frequency",
            "type": "string",
            "examples": [
              "Twice daily"
            ]
          },
          "instructions": {
            "description": "Updated instructions",
            "type": "string",
            "examples": [
              "Take one tablet in morning and one in evening with food"
            ]
          }
        },
        "required": [
          "medication_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "update_status": {
            "description": "Status of the update operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "Timestamp when medication was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 09:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medication"
      ]
    },
    {
      "name": "reschedule_appointment",
      "description": "Reschedule an existing appointment to a new date and time",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "data_management",
      "pre_condition": "Original appointment must exist and new time slot must be available",
      "post_condition": "Appointment is rescheduled and confirmations are sent",
      "parameters": {
        "type": "object",
        "properties": {
          "appointment_id": {
            "description": "Unique identifier of the appointment to reschedule",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          },
          "new_appointment_datetime": {
            "description": "New scheduled date and time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-22 14:00:00"
            ]
          },
          "reschedule_reason": {
            "description": "Reason for rescheduling",
            "type": "string",
            "examples": [
              "Patient requested different time"
            ]
          }
        },
        "required": [
          "appointment_id",
          "new_appointment_datetime"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reschedule_status": {
            "description": "Status of the reschedule operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "new_confirmation_number": {
            "description": "New confirmation number for rescheduled appointment",
            "type": "string",
            "examples": [
              "CONF-XYZ789"
            ]
          },
          "rescheduled_at": {
            "description": "Timestamp when appointment was rescheduled in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 11:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "appointment"
      ]
    },
    {
      "name": "update_notification_preferences",
      "description": "Update patient's notification preferences for appointments, messages, and reminders",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "notification_management",
      "action_category": "configuration",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Notification preferences are updated",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "appointment_reminders": {
            "description": "Enable appointment reminder notifications",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "message_notifications": {
            "description": "Enable new message notifications",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "medication_reminders": {
            "description": "Enable medication reminder notifications",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "lab_result_notifications": {
            "description": "Enable lab result availability notifications",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "notification_channels": {
            "description": "Preferred channels for notifications",
            "type": "array",
            "items": {
              "type": "string",
              "enum": [
                "email",
                "sms",
                "push_notification",
                "in_app"
              ]
            },
            "examples": [
              [
                "email",
                "push_notification"
              ]
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "update_status": {
            "description": "Status of preferences update",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "Timestamp when preferences were updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 14:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "notification_preference",
        "notification_channel"
      ]
    },
    {
      "name": "schedule_appointment",
      "description": "Schedule a new telehealth appointment with a healthcare provider for a specific time slot",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "data_management",
      "pre_condition": "Time slot must be available and patient must be authenticated",
      "post_condition": "Appointment is created and confirmation is sent to patient",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "provider_id": {
            "description": "Unique identifier of the healthcare provider",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          },
          "appointment_datetime": {
            "description": "Scheduled date and time of appointment in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 09:00:00"
            ]
          },
          "appointment_type": {
            "description": "Type of appointment",
            "type": "string",
            "enum": [
              "video_consultation",
              "phone_consultation",
              "in_person"
            ],
            "examples": [
              "video_consultation"
            ]
          },
          "reason_for_visit": {
            "description": "Brief description of the reason for the appointment",
            "type": "string",
            "examples": [
              "Follow-up consultation for chest pain"
            ]
          },
          "duration_minutes": {
            "description": "Expected duration of appointment in minutes",
            "type": "integer",
            "examples": [
              30
            ]
          }
        },
        "required": [
          "patient_id",
          "provider_id",
          "appointment_datetime",
          "appointment_type",
          "reason_for_visit"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "appointment_id": {
            "description": "Unique identifier for the scheduled appointment",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          },
          "confirmation_number": {
            "description": "Appointment confirmation number",
            "type": "string",
            "examples": [
              "CONF-ABC123"
            ]
          },
          "status": {
            "description": "Current status of the appointment",
            "type": "string",
            "examples": [
              "scheduled"
            ]
          },
          "created_at": {
            "description": "Timestamp when appointment was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 15:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "appointment",
        "healthcare_provider",
        "patient",
        "provider_language",
        "provider_specialty"
      ]
    },
    {
      "name": "enable_two_factor_authentication",
      "description": "Enable two-factor authentication for patient account security",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "security_management",
      "action_category": "security_operation",
      "pre_condition": "Patient must be authenticated and 2FA must not already be enabled",
      "post_condition": "Two-factor authentication is enabled for the account",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "authentication_method": {
            "description": "Method for two-factor authentication",
            "type": "string",
            "enum": [
              "sms",
              "email",
              "authenticator_app"
            ],
            "examples": [
              "authenticator_app"
            ]
          },
          "phone_number": {
            "description": "Phone number for SMS authentication",
            "type": "string",
            "examples": [
              "+1-555-123-4567"
            ]
          }
        },
        "required": [
          "patient_id",
          "authentication_method"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "setup_status": {
            "description": "Status of 2FA setup",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "qr_code_url": {
            "description": "QR code URL for authenticator app setup",
            "type": "string",
            "examples": [
              "https://telehealth.example.com/2fa/qr/PAT-20240115-001"
            ]
          },
          "backup_codes": {
            "description": "List of backup authentication codes",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "ABC123",
                "DEF456",
                "GHI789"
              ]
            ]
          },
          "enabled_at": {
            "description": "Timestamp when 2FA was enabled in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 13:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "patient"
      ]
    },
    {
      "name": "send_secure_message",
      "description": "Send a secure message to healthcare provider through the patient portal",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "communication_management",
      "action_category": "communication",
      "pre_condition": "Patient must be authenticated and have an active relationship with the provider",
      "post_condition": "Message is sent and stored securely",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient sending the message",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "provider_id": {
            "description": "Unique identifier of the provider receiving the message",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          },
          "subject": {
            "description": "Subject line of the message",
            "type": "string",
            "examples": [
              "Question about medication side effects"
            ]
          },
          "message_body": {
            "description": "Content of the message",
            "type": "string",
            "examples": [
              "I have been experiencing mild dizziness after taking Lisinopril. Is this normal?"
            ]
          },
          "priority": {
            "description": "Priority level of the message",
            "type": "string",
            "enum": [
              "low",
              "normal",
              "high",
              "urgent"
            ],
            "examples": [
              "normal"
            ]
          },
          "attachment_ids": {
            "description": "List of document IDs attached to the message",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "DOC-20240115-002"
              ]
            ]
          }
        },
        "required": [
          "patient_id",
          "provider_id",
          "subject",
          "message_body"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "message_id": {
            "description": "Unique identifier for the sent message",
            "type": "string",
            "examples": [
              "MSG-20240115-001"
            ]
          },
          "sent_at": {
            "description": "Timestamp when message was sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 22:00:00"
            ]
          },
          "delivery_status": {
            "description": "Status of message delivery",
            "type": "string",
            "examples": [
              "delivered"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "secure_message",
        "message_attachment"
      ]
    },
    {
      "name": "add_medication_to_list",
      "description": "Add a new medication to patient's current medication list with dosage and frequency information",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "medication_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Medication is added to patient's medication list",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "medication_name": {
            "description": "Name of the medication",
            "type": "string",
            "examples": [
              "Lisinopril"
            ]
          },
          "dosage": {
            "description": "Dosage amount and unit",
            "type": "string",
            "examples": [
              "10mg"
            ]
          },
          "frequency": {
            "description": "How often the medication should be taken",
            "type": "string",
            "examples": [
              "Once daily"
            ]
          },
          "start_date": {
            "description": "Date when medication was started in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          },
          "prescribing_provider": {
            "description": "Name of the provider who prescribed the medication",
            "type": "string",
            "examples": [
              "Dr. Sarah Johnson"
            ]
          },
          "instructions": {
            "description": "Special instructions for taking the medication",
            "type": "string",
            "examples": [
              "Take with food in the morning"
            ]
          }
        },
        "required": [
          "patient_id",
          "medication_name",
          "dosage",
          "frequency",
          "start_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "medication_id": {
            "description": "Unique identifier for the medication entry",
            "type": "string",
            "examples": [
              "MED-20240115-001"
            ]
          },
          "added_at": {
            "description": "Timestamp when medication was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 18:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medication"
      ]
    },
    {
      "name": "get_patient_profile",
      "description": "Retrieve complete patient profile information including personal details and account settings",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "profile_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Patient profile data is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "first_name": {
            "description": "Patient's first name",
            "type": "string",
            "examples": [
              "John"
            ]
          },
          "last_name": {
            "description": "Patient's last name",
            "type": "string",
            "examples": [
              "Smith"
            ]
          },
          "email": {
            "description": "Patient's email address",
            "type": "string",
            "examples": [
              "john.smith@email.com"
            ]
          },
          "phone_number": {
            "description": "Patient's phone number",
            "type": "string",
            "examples": [
              "+1-555-123-4567"
            ]
          },
          "date_of_birth": {
            "description": "Patient's date of birth in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "1985-06-15"
            ]
          },
          "address": {
            "description": "Patient's residential address",
            "type": "string",
            "examples": [
              "123 Main Street, Apt 4B, New York, NY 10001"
            ]
          },
          "account_status": {
            "description": "Current account status",
            "type": "string",
            "examples": [
              "active"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "patient"
      ]
    },
    {
      "name": "get_outstanding_balance",
      "description": "Retrieve current outstanding balance for a patient",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "payment_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Outstanding balance details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_balance": {
            "description": "Total outstanding balance",
            "type": "number",
            "examples": [
              75.0
            ]
          },
          "itemized_charges": {
            "description": "List of unpaid charges",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "charge_id": "CHG-001",
                  "description": "Copay for consultation",
                  "amount": 25.0,
                  "date": "2024-01-20"
                }
              ]
            ]
          },
          "oldest_charge_date": {
            "description": "Date of oldest unpaid charge in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-15"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "payment"
      ]
    },
    {
      "name": "cancel_appointment",
      "description": "Cancel an existing scheduled appointment and release the time slot",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "data_management",
      "pre_condition": "Appointment must exist and be in scheduled status",
      "post_condition": "Appointment is cancelled and notifications are sent",
      "parameters": {
        "type": "object",
        "properties": {
          "appointment_id": {
            "description": "Unique identifier of the appointment to cancel",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          },
          "cancellation_reason": {
            "description": "Reason for cancelling the appointment",
            "type": "string",
            "examples": [
              "Schedule conflict"
            ]
          },
          "cancelled_by": {
            "description": "Who initiated the cancellation",
            "type": "string",
            "enum": [
              "patient",
              "provider",
              "system"
            ],
            "examples": [
              "patient"
            ]
          }
        },
        "required": [
          "appointment_id",
          "cancellation_reason",
          "cancelled_by"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "cancellation_status": {
            "description": "Status of the cancellation operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "refund_eligible": {
            "description": "Whether the cancellation is eligible for refund",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "cancelled_at": {
            "description": "Timestamp when appointment was cancelled in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-16 10:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "appointment"
      ]
    },
    {
      "name": "create_patient_account",
      "description": "Create a new patient account with basic registration information including personal details and contact information",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "account_management",
      "action_category": "data_management",
      "pre_condition": "Patient email must be unique and not already registered in the system",
      "post_condition": "Patient account is created and activation email is sent",
      "parameters": {
        "type": "object",
        "properties": {
          "first_name": {
            "description": "Patient's first name",
            "type": "string",
            "examples": [
              "John"
            ]
          },
          "last_name": {
            "description": "Patient's last name",
            "type": "string",
            "examples": [
              "Smith"
            ]
          },
          "email": {
            "description": "Patient's email address for account login",
            "type": "string",
            "examples": [
              "john.smith@email.com"
            ]
          },
          "phone_number": {
            "description": "Patient's primary contact phone number",
            "type": "string",
            "examples": [
              "+1-555-123-4567"
            ]
          },
          "date_of_birth": {
            "description": "Patient's date of birth in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "1985-06-15"
            ]
          },
          "password": {
            "description": "Account password meeting security requirements",
            "type": "string",
            "examples": [
              "SecurePass123!"
            ]
          }
        },
        "required": [
          "first_name",
          "last_name",
          "email",
          "phone_number",
          "date_of_birth",
          "password"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier for the newly created patient account",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "account_status": {
            "description": "Current status of the patient account",
            "type": "string",
            "examples": [
              "pending_verification"
            ]
          },
          "created_at": {
            "description": "Timestamp when the account 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": [
        "patient"
      ]
    },
    {
      "name": "get_provider_availability",
      "description": "Retrieve available appointment time slots for a specific healthcare provider within a date range",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "appointment_management",
      "action_category": "data_management",
      "pre_condition": "Provider must exist and have availability calendar configured",
      "post_condition": "List of available time slots is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "provider_id": {
            "description": "Unique identifier of the healthcare provider",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          },
          "start_date": {
            "description": "Start date for availability search in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-20"
            ]
          },
          "end_date": {
            "description": "End date for availability search in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-27"
            ]
          },
          "appointment_type": {
            "description": "Type of appointment requested",
            "type": "string",
            "enum": [
              "video_consultation",
              "phone_consultation",
              "in_person"
            ],
            "examples": [
              "video_consultation"
            ]
          }
        },
        "required": [
          "provider_id",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "available_slots": {
            "description": "List of available appointment time slots",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "slot_id": "SLOT-001",
                  "start_time": "2024-01-20 09:00:00",
                  "end_time": "2024-01-20 09:30:00"
                }
              ]
            ]
          },
          "total_slots": {
            "description": "Total number of available slots",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "healthcare_provider",
        "appointment"
      ]
    },
    {
      "name": "add_pharmacy_to_profile",
      "description": "Add a preferred pharmacy to patient's profile for prescription fulfillment",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "pharmacy_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "Pharmacy is added to patient's profile",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "pharmacy_name": {
            "description": "Name of the pharmacy",
            "type": "string",
            "examples": [
              "CVS Pharmacy"
            ]
          },
          "pharmacy_address": {
            "description": "Full address of the pharmacy",
            "type": "string",
            "examples": [
              "456 Oak Street, New York, NY 10002"
            ]
          },
          "pharmacy_phone": {
            "description": "Phone number of the pharmacy",
            "type": "string",
            "examples": [
              "+1-555-234-5678"
            ]
          },
          "is_primary": {
            "description": "Whether this is the primary pharmacy",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "patient_id",
          "pharmacy_name",
          "pharmacy_address",
          "pharmacy_phone"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "pharmacy_id": {
            "description": "Unique identifier for the pharmacy entry",
            "type": "string",
            "examples": [
              "PHARM-001"
            ]
          },
          "added_at": {
            "description": "Timestamp when pharmacy was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 21:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "pharmacy"
      ]
    },
    {
      "name": "submit_payment",
      "description": "Submit payment for telehealth services or copay",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "payment_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated and have valid payment method",
      "post_condition": "Payment is processed and receipt is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "appointment_id": {
            "description": "Unique identifier of the appointment being paid for",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          },
          "payment_amount": {
            "description": "Amount to be paid",
            "type": "number",
            "examples": [
              25.0
            ]
          },
          "payment_method": {
            "description": "Method of payment",
            "type": "string",
            "enum": [
              "credit_card",
              "debit_card",
              "insurance",
              "health_savings_account"
            ],
            "examples": [
              "credit_card"
            ]
          },
          "card_last_four": {
            "description": "Last four digits of payment card",
            "type": "string",
            "examples": [
              "1234"
            ]
          }
        },
        "required": [
          "patient_id",
          "appointment_id",
          "payment_amount",
          "payment_method"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "payment_id": {
            "description": "Unique identifier for the payment transaction",
            "type": "string",
            "examples": [
              "PAY-20240120-001"
            ]
          },
          "transaction_status": {
            "description": "Status of the payment transaction",
            "type": "string",
            "examples": [
              "completed"
            ]
          },
          "receipt_number": {
            "description": "Receipt number for the payment",
            "type": "string",
            "examples": [
              "RCPT-20240120-001"
            ]
          },
          "processed_at": {
            "description": "Timestamp when payment was processed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 09:05:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "payment"
      ]
    },
    {
      "name": "get_prescription_history",
      "description": "Retrieve complete prescription history for a patient with optional date range filtering",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "prescription_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of prescriptions is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "start_date": {
            "description": "Start date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2023-01-01"
            ]
          },
          "end_date": {
            "description": "End date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          },
          "status_filter": {
            "description": "Filter prescriptions by status",
            "type": "string",
            "enum": [
              "active",
              "completed",
              "cancelled",
              "all"
            ],
            "examples": [
              "active"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "prescriptions": {
            "description": "List of prescriptions",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "prescription_id": "RX-20240115-001",
                  "medication_name": "Lisinopril",
                  "prescribed_date": "2024-01-15",
                  "status": "active"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of prescriptions",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "prescription"
      ]
    },
    {
      "name": "get_payment_history",
      "description": "Retrieve payment history for a patient with optional date range filtering",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "payment_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of payment transactions is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "start_date": {
            "description": "Start date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "payments": {
            "description": "List of payment transactions",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "payment_id": "PAY-20240120-001",
                  "amount": 25.0,
                  "date": "2024-01-20",
                  "status": "completed"
                }
              ]
            ]
          },
          "total_paid": {
            "description": "Total amount paid in the period",
            "type": "number",
            "examples": [
              150.0
            ]
          },
          "transaction_count": {
            "description": "Number of transactions",
            "type": "integer",
            "examples": [
              6
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "payment"
      ]
    },
    {
      "name": "update_patient_profile",
      "description": "Update patient profile information including contact details and emergency contacts",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "profile_management",
      "action_category": "data_management",
      "pre_condition": "Patient account must be active and authenticated",
      "post_condition": "Patient profile information is updated in the system",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "address": {
            "description": "Patient's residential address",
            "type": "string",
            "examples": [
              "123 Main Street, Apt 4B, New York, NY 10001"
            ]
          },
          "emergency_contact_name": {
            "description": "Name of emergency contact person",
            "type": "string",
            "examples": [
              "Jane Smith"
            ]
          },
          "emergency_contact_phone": {
            "description": "Phone number of emergency contact",
            "type": "string",
            "examples": [
              "+1-555-987-6543"
            ]
          },
          "preferred_language": {
            "description": "Patient's preferred language for communication",
            "type": "string",
            "enum": [
              "English",
              "Spanish",
              "French",
              "Chinese",
              "German"
            ],
            "examples": [
              "English"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "update_status": {
            "description": "Status of the profile update operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_at": {
            "description": "Timestamp when profile was updated in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 14:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "patient"
      ]
    },
    {
      "name": "list_patient_documents",
      "description": "Retrieve list of all medical documents for a patient with optional filtering by document type",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "document_management",
      "action_category": "data_management",
      "pre_condition": "Patient must be authenticated",
      "post_condition": "List of patient documents is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "document_type": {
            "description": "Filter documents by type",
            "type": "string",
            "enum": [
              "lab_result",
              "prescription",
              "imaging_report",
              "insurance_card",
              "medical_history",
              "vaccination_record",
              "all"
            ],
            "examples": [
              "lab_result"
            ]
          },
          "start_date": {
            "description": "Start date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date for filtering in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        },
        "required": [
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "documents": {
            "description": "List of medical documents",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "document_id": "DOC-20240115-001",
                  "document_type": "lab_result",
                  "file_name": "blood_test_results_2024.pdf"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of documents",
            "type": "integer",
            "examples": [
              8
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medical_document"
      ]
    },
    {
      "name": "submit_provider_rating",
      "description": "Submit a rating and review for a healthcare provider after an appointment",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "feedback_management",
      "action_category": "data_management",
      "pre_condition": "Appointment must be completed and patient must not have already submitted a rating",
      "post_condition": "Provider rating is recorded and added to provider's profile",
      "parameters": {
        "type": "object",
        "properties": {
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "provider_id": {
            "description": "Unique identifier of the provider being rated",
            "type": "string",
            "examples": [
              "DOC-001"
            ]
          },
          "appointment_id": {
            "description": "Unique identifier of the appointment",
            "type": "string",
            "examples": [
              "APT-20240120-001"
            ]
          },
          "overall_rating": {
            "description": "Overall rating from 1 to 5 stars",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "communication_rating": {
            "description": "Rating for provider communication",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "professionalism_rating": {
            "description": "Rating for provider professionalism",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "written_review": {
            "description": "Written review comments",
            "type": "string",
            "examples": [
              "Dr. Johnson was very thorough and explained everything clearly. Excellent care."
            ]
          },
          "would_recommend": {
            "description": "Whether patient would recommend this provider",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "patient_id",
          "provider_id",
          "appointment_id",
          "overall_rating"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "rating_id": {
            "description": "Unique identifier for the rating record",
            "type": "string",
            "examples": [
              "RATE-20240120-001"
            ]
          },
          "submitted_at": {
            "description": "Timestamp when rating was submitted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-20 15:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "provider_rating"
      ]
    },
    {
      "name": "delete_medical_document",
      "description": "Delete a medical document from patient's health records",
      "group": "healthcare_telemedicine.Telehealth_Patient_Portal",
      "object_category": "document_management",
      "action_category": "data_management",
      "pre_condition": "Document must exist and patient must have deletion rights",
      "post_condition": "Document is permanently deleted from the system",
      "parameters": {
        "type": "object",
        "properties": {
          "document_id": {
            "description": "Unique identifier of the document to delete",
            "type": "string",
            "examples": [
              "DOC-20240115-001"
            ]
          },
          "patient_id": {
            "description": "Unique identifier of the patient",
            "type": "string",
            "examples": [
              "PAT-20240115-001"
            ]
          },
          "deletion_reason": {
            "description": "Reason for deleting the document",
            "type": "string",
            "examples": [
              "Uploaded wrong file"
            ]
          }
        },
        "required": [
          "document_id",
          "patient_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "deletion_status": {
            "description": "Status of the deletion operation",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "deleted_at": {
            "description": "Timestamp when document was deleted in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-01-15 17:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "medical_document"
      ]
    }
  ],
  "schema_classification": {
    "Patient": {
      "schema_name": "Patient",
      "instance_key": "patient_id",
      "fields": [
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，是唯一标识，每次生成都不同"
        },
        {
          "field_name": "first_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名属于自然语言文本，不同表达可能等价"
        },
        {
          "field_name": "last_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名属于自然语言文本，不同表达可能等价"
        },
        {
          "field_name": "email",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "登录账号必须严格匹配，否则业务上是不同账户"
        },
        {
          "field_name": "phone_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "联系方式必须严格匹配，微小差异很重要"
        },
        {
          "field_name": "date_of_birth",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "出生日期必须严格匹配，微小差异很重要"
        },
        {
          "field_name": "password_hash",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "密码哈希每次变动都不同，通常不参与业务等价比较"
        },
        {
          "field_name": "address",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "地址是自然语言文本，不同表达可以等价"
        },
        {
          "field_name": "emergency_contact_name",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "联系人姓名属于自然语言文本，可能不同表达等价"
        },
        {
          "field_name": "emergency_contact_phone",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "联系方式必须严格匹配，微小差异很重要"
        },
        {
          "field_name": "preferred_language",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "语言偏好通常是枚举，必须严格匹配"
        },
        {
          "field_name": "account_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "账户状态通常是枚举值，必须严格匹配"
        },
        {
          "field_name": "email_verified",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须严格匹配"
        },
        {
          "field_name": "two_factor_enabled",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须严格匹配"
        },
        {
          "field_name": "two_factor_method",
          "field_type": "Optional",
          "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": "更新时间必须严格匹配，微小差异很重要"
        },
        {
          "field_name": "verified_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "邮件验证时间必须严格匹配，微小差异很重要"
        }
      ]
    },
    "HealthcareProvider": {
      "schema_name": "HealthcareProvider",
      "instance_key": "provider_id",
      "fields": [
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符，每次生成可能不同"
        },
        {
          "field_name": "full_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人名包含称谓，可能有不同格式但语义相同"
        },
        {
          "field_name": "credentials",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述专业资质，不同措辞可能表达相同含义"
        },
        {
          "field_name": "years_experience",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值字段，必须精确匹配"
        },
        {
          "field_name": "average_rating",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值字段，必须精确匹配"
        },
        {
          "field_name": "average_consultation_minutes",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值字段，必须精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        }
      ]
    },
    "ProviderSpecialty": {
      "schema_name": "ProviderSpecialty",
      "instance_key": "specialty_id",
      "fields": [
        {
          "field_name": "specialty_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识记录，每次生成可能不同"
        },
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用同一医疗服务提供者"
        },
        {
          "field_name": "specialty",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "医疗专科通常为标准枚举或字面量，必须精确匹配专业类型"
        }
      ]
    },
    "ProviderLanguage": {
      "schema_name": "ProviderLanguage",
      "instance_key": "language_id",
      "fields": [
        {
          "field_name": "language_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符，每次生成可能不同"
        },
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向医疗服务提供者，必须精确匹配"
        },
        {
          "field_name": "language",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "标准化语言名称，需严格匹配，细微差异可能代表不同语言"
        }
      ]
    },
    "Appointment": {
      "schema_name": "Appointment",
      "instance_key": "appointment_id",
      "fields": [
        {
          "field_name": "appointment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，由工具随机生成，每次执行都不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用同一患者"
        },
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用同一医疗服务提供者"
        },
        {
          "field_name": "appointment_datetime",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间字段，必须精确匹配"
        },
        {
          "field_name": "appointment_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，类型必须严格一致"
        },
        {
          "field_name": "reason_for_visit",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "duration_minutes",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值字段，必须精确匹配"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，预约状态必须严格一致"
        },
        {
          "field_name": "confirmation_number",
          "field_type": "Optional[str]",
          "comparison_type": "ignore",
          "reason": "预约确认码，通常由系统随机生成，每次执行都不同"
        },
        {
          "field_name": "cancellation_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "cancelled_by",
          "field_type": "Optional",
          "comparison_type": "semantic",
          "reason": "可能为人名或角色，自然语言表达可有多种方式"
        },
        {
          "field_name": "reschedule_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        },
        {
          "field_name": "cancelled_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        },
        {
          "field_name": "rescheduled_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        }
      ]
    },
    "MedicalDocument": {
      "schema_name": "MedicalDocument",
      "instance_key": "document_id",
      "fields": [
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符由系统生成，每次可能不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联正确"
        },
        {
          "field_name": "document_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，类型必须严格一致"
        },
        {
          "field_name": "file_name",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "文件名为具体文件的唯一标识，需严格一致"
        },
        {
          "field_name": "file_size_bytes",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "文件大小为数值，必须精确匹配"
        },
        {
          "field_name": "file_format",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，文件格式需严格一致"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可表达同一内容"
        },
        {
          "field_name": "file_path",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "存储路径为具体字符串，需严格相等"
        },
        {
          "field_name": "upload_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值或状态字符串，需严格一致以反映实际操作状态"
        },
        {
          "field_name": "uploaded_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，需严格一致以反映实际上传时间"
        },
        {
          "field_name": "deleted_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，需严格一致以反映实际删除时间"
        },
        {
          "field_name": "deletion_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "删除原因为自由文本，表达方式可不同但含义一致"
        }
      ]
    },
    "Medication": {
      "schema_name": "Medication",
      "instance_key": "medication_id",
      "fields": [
        {
          "field_name": "medication_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识，每次生成都不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，用于精确标识患者，必须严格匹配"
        },
        {
          "field_name": "medication_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "可能会有不同的命名或拼写，但表达的是同一种药物"
        },
        {
          "field_name": "dosage",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "药物剂量，必须精确匹配，任何差异都可能影响治疗"
        },
        {
          "field_name": "frequency",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "服药频率可以用不同自然语言描述（例如“每日一次”与“每天服用一次”），应进行语义比较"
        },
        {
          "field_name": "start_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "用药开始日期，必须精确匹配"
        },
        {
          "field_name": "prescribing_provider",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "提供者名称，可能有不同写法（简称、全名），但表达同一人"
        },
        {
          "field_name": "instructions",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本说明，不同措辞可能表达相同服药方式"
        },
        {
          "field_name": "is_active",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示药物当前是否有效，必须严格匹配"
        },
        {
          "field_name": "discontinuation_date",
          "field_type": "Optional[date]",
          "comparison_type": "strict",
          "reason": "停药日期，精确匹配"
        },
        {
          "field_name": "discontinuation_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "停药原因为自然语言文本，不同表达可等价"
        },
        {
          "field_name": "added_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录添加时间戳，需严格匹配"
        },
        {
          "field_name": "updated_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "记录更新时间戳，需严格匹配"
        },
        {
          "field_name": "removed_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "记录移除时间戳，需严格匹配"
        }
      ]
    },
    "MedicationReminder": {
      "schema_name": "MedicationReminder",
      "instance_key": "reminder_id",
      "fields": [
        {
          "field_name": "reminder_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符每次执行都不同"
        },
        {
          "field_name": "medication_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的是同一药品"
        },
        {
          "field_name": "notification_method",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须完全相同才能视为等价"
        },
        {
          "field_name": "reminder_enabled",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须完全一致"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，需精确匹配"
        }
      ]
    },
    "ReminderTime": {
      "schema_name": "ReminderTime",
      "instance_key": "reminder_time_id",
      "fields": [
        {
          "field_name": "reminder_time_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成的唯一标识符，每次执行都不同"
        },
        {
          "field_name": "reminder_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的是同一条medication reminder记录"
        },
        {
          "field_name": "reminder_time",
          "field_type": "time",
          "comparison_type": "strict",
          "reason": "时间字段，用于提醒的具体时间点，必须精确匹配"
        }
      ]
    },
    "Prescription": {
      "schema_name": "Prescription",
      "instance_key": "prescription_id",
      "fields": [
        {
          "field_name": "prescription_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确引用患者记录"
        },
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确引用医生/开方者记录"
        },
        {
          "field_name": "medication_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "药品名称可能存在拼写或表达的差异，需语义判断是否为同一种药物"
        },
        {
          "field_name": "prescribed_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "日期，必须精确匹配开方时间"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，处方状态必须严格匹配"
        },
        {
          "field_name": "refills_remaining",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值，剩余可重复次数必须精确匹配"
        },
        {
          "field_name": "created_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，记录创建时间，需严格匹配"
        }
      ]
    },
    "PrescriptionRefillRequest": {
      "schema_name": "PrescriptionRefillRequest",
      "instance_key": "refill_request_id",
      "fields": [
        {
          "field_name": "refill_request_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，由系统随机生成，每次执行都不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格对应患者记录"
        },
        {
          "field_name": "prescription_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格对应处方记录"
        },
        {
          "field_name": "pharmacy_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格对应药房记录"
        },
        {
          "field_name": "urgency_level",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "枚举值或标志，业务上必须严格区分紧急程度"
        },
        {
          "field_name": "additional_notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "request_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，业务流程中必须严格区分请求状态"
        },
        {
          "field_name": "submitted_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间戳，精确反映请求提交时间，必须严格相等"
        }
      ]
    },
    "Pharmacy": {
      "schema_name": "Pharmacy",
      "instance_key": "pharmacy_id",
      "fields": [
        {
          "field_name": "pharmacy_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "pharmacy_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "药店名称属于人名/公司名，可能有小差异但语义相同"
        },
        {
          "field_name": "pharmacy_address",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "地址信息，不同格式或措辞可能语义相同"
        },
        {
          "field_name": "pharmacy_phone",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电话号码，必须精确匹配"
        },
        {
          "field_name": "is_primary",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配"
        },
        {
          "field_name": "added_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        }
      ]
    },
    "SecureMessage": {
      "schema_name": "SecureMessage",
      "instance_key": "message_id",
      "fields": [
        {
          "field_name": "message_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，由工具随机生成，每次执行都不同"
        },
        {
          "field_name": "thread_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，需要精确匹配以确保属于同一消息线程"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用患者记录，必须严格相等"
        },
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用服务提供者记录，必须严格相等"
        },
        {
          "field_name": "sender_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值（Literal），类型必须精确匹配"
        },
        {
          "field_name": "subject",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本标题，不同措辞可能表达相同主题，需语义比较"
        },
        {
          "field_name": "message_body",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自然语言内容，不同措辞可能表达相同含义，需语义比较"
        },
        {
          "field_name": "priority",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "枚举或优先级标识，业务含义明确，需要精确匹配"
        },
        {
          "field_name": "is_read",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否已读，必须严格相等"
        },
        {
          "field_name": "delivery_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "状态标识，通常为固定枚举或字符串，需精确匹配"
        },
        {
          "field_name": "sent_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，表示发送时间，业务上需要精确匹配"
        },
        {
          "field_name": "read_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，表示已读时间，业务上需要严格相等"
        }
      ]
    },
    "MessageAttachment": {
      "schema_name": "MessageAttachment",
      "instance_key": "attachment_id",
      "fields": [
        {
          "field_name": "attachment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "message_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的是同一条消息"
        },
        {
          "field_name": "document_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的是同一份文档"
        }
      ]
    },
    "Insurance": {
      "schema_name": "Insurance",
      "instance_key": "insurance_id",
      "fields": [
        {
          "field_name": "insurance_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "insurance_provider",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "保险公司名称，可能存在不同表达但语义等价"
        },
        {
          "field_name": "policy_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "保单号必须精确匹配"
        },
        {
          "field_name": "group_number",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "保险群组号，通常作为编号，需精确匹配"
        },
        {
          "field_name": "policy_holder_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名可能有不同表达方式但语义等价"
        },
        {
          "field_name": "relationship_to_patient",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "限定枚举值，需精确匹配"
        },
        {
          "field_name": "coverage_start_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期，需精确匹配"
        },
        {
          "field_name": "coverage_end_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期，需精确匹配"
        },
        {
          "field_name": "verification_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "状态字段，需精确匹配"
        },
        {
          "field_name": "added_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，需精确匹配"
        }
      ]
    },
    "Payment": {
      "schema_name": "Payment",
      "instance_key": "payment_id",
      "fields": [
        {
          "field_name": "payment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成的唯一标识符"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以指向同一个患者"
        },
        {
          "field_name": "appointment_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以指向同一个预约"
        },
        {
          "field_name": "payment_amount",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "payment_method",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，支付方式必须一致"
        },
        {
          "field_name": "card_last_four",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "银行卡末四位，必须完全匹配"
        },
        {
          "field_name": "transaction_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "交易状态，枚举值，必须严格相等"
        },
        {
          "field_name": "receipt_number",
          "field_type": "Optional[str]",
          "comparison_type": "ignore",
          "reason": "收据编号，通常由系统随机生成，非业务等价性字段"
        },
        {
          "field_name": "processed_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "处理时间戳，必须精确匹配"
        }
      ]
    },
    "Allergy": {
      "schema_name": "Allergy",
      "instance_key": "allergy_id",
      "fields": [
        {
          "field_name": "allergy_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识此过敏记录，比较时应忽略"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确引用患者，必须严格相等"
        },
        {
          "field_name": "allergen",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "过敏原通常为自然语言文本，可能存在不同表达方式（如花生/花生米），应语义比较"
        },
        {
          "field_name": "allergy_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示过敏类型（如药物、食物），必须严格匹配"
        },
        {
          "field_name": "reaction",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述过敏反应，可能措辞不同但含义相同，应语义比较"
        },
        {
          "field_name": "severity",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示严重程度，必须严格相等"
        },
        {
          "field_name": "onset_date",
          "field_type": "Optional[date]",
          "comparison_type": "strict",
          "reason": "日期类型，过敏首次发现日期，必须严格匹配"
        },
        {
          "field_name": "added_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，记录添加时间，必须严格匹配"
        }
      ]
    },
    "MedicalCondition": {
      "schema_name": "MedicalCondition",
      "instance_key": "condition_id",
      "fields": [
        {
          "field_name": "condition_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识记录，每次生成不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，对其他记录的引用，需精确匹配"
        },
        {
          "field_name": "condition_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "疾病名称，可能存在不同表述但语义相同的情况"
        },
        {
          "field_name": "diagnosis_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "日期字段，诊断日期必须严格一致"
        },
        {
          "field_name": "condition_status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，疾病状态需精确匹配"
        },
        {
          "field_name": "severity",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "严重程度，通常为枚举或数值，需精确匹配"
        },
        {
          "field_name": "notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本备注，不同措辞可表达相同含义"
        },
        {
          "field_name": "added_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录添加时间戳，需严格匹配"
        }
      ]
    },
    "VitalSign": {
      "schema_name": "VitalSign",
      "instance_key": "vital_signs_id",
      "fields": [
        {
          "field_name": "vital_signs_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成，每次执行都不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，需精确匹配以确保对应患者一致"
        },
        {
          "field_name": "measurement_datetime",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，必须完全匹配以确保测量时间一致"
        },
        {
          "field_name": "blood_pressure_systolic",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型生理参数，微小差异有医学意义"
        },
        {
          "field_name": "blood_pressure_diastolic",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型生理参数，微小差异有医学意义"
        },
        {
          "field_name": "heart_rate",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型生理参数，需精确匹配"
        },
        {
          "field_name": "temperature",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值型生理参数，需精确匹配"
        },
        {
          "field_name": "oxygen_saturation",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型生理参数，需精确匹配"
        },
        {
          "field_name": "weight",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值型生理参数，需精确匹配"
        },
        {
          "field_name": "recorded_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录创建时间，必须完全匹配以保证记录一致性"
        }
      ]
    },
    "ProviderRating": {
      "schema_name": "ProviderRating",
      "instance_key": "rating_id",
      "fields": [
        {
          "field_name": "rating_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条评分记录，每次生成不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确指向患者记录，必须严格匹配"
        },
        {
          "field_name": "provider_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确指向服务提供者记录，必须严格匹配"
        },
        {
          "field_name": "appointment_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确指向预约记录，必须严格匹配"
        },
        {
          "field_name": "overall_rating",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值型，代表总体评分，微小差异即有业务意义，必须严格匹配"
        },
        {
          "field_name": "communication_rating",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型，代表沟通评分，微小差异即有业务意义，必须严格匹配"
        },
        {
          "field_name": "professionalism_rating",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型，代表专业性评分，微小差异即有业务意义，必须严格匹配"
        },
        {
          "field_name": "written_review",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本评论，不同表达可能语义等价，应按语义比较"
        },
        {
          "field_name": "would_recommend",
          "field_type": "Optional[bool]",
          "comparison_type": "strict",
          "reason": "布尔值，是否推荐服务提供者，必须严格匹配"
        },
        {
          "field_name": "submitted_at",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，代表提交时间，精确时间有业务意义，必须严格匹配"
        }
      ]
    },
    "NotificationPreference": {
      "schema_name": "NotificationPreference",
      "instance_key": "preference_id",
      "fields": [
        {
          "field_name": "preference_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识，每次生成可能不同"
        },
        {
          "field_name": "patient_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，代表具体的患者"
        },
        {
          "field_name": "appointment_reminders",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配以正确反映设置"
        },
        {
          "field_name": "message_notifications",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配以正确反映设置"
        },
        {
          "field_name": "medication_reminders",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配以正确反映设置"
        },
        {
          "field_name": "lab_result_notifications",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配以正确反映设置"
        },
        {
          "field_name": "updated_at",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，通常用于判断最新状态，需精确匹配"
        }
      ]
    },
    "NotificationChannel": {
      "schema_name": "NotificationChannel",
      "instance_key": "channel_id",
      "fields": [
        {
          "field_name": "channel_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条记录，通常由系统生成，每次执行可能不同"
        },
        {
          "field_name": "preference_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向通知偏好记录，必须精确匹配"
        },
        {
          "field_name": "channel_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示通知渠道类型，必须严格相等"
        }
      ]
    }
  }
}