{
  "domain": "football",
  "databases": [
    {
      "table_name": "match",
      "description": "Stores football match information including teams, venue, date, and competition details",
      "schema": {
        "columns": [
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the match",
            "optional": false
          },
          {
            "name": "home_team",
            "type": "VARCHAR(100)",
            "description": "Name of the home team",
            "optional": false
          },
          {
            "name": "away_team",
            "type": "VARCHAR(100)",
            "description": "Name of the away team",
            "optional": false
          },
          {
            "name": "match_date",
            "type": "DATETIME",
            "description": "Date and time of the match",
            "optional": false
          },
          {
            "name": "venue_name",
            "type": "VARCHAR(100)",
            "description": "Name of the venue",
            "optional": false
          },
          {
            "name": "competition",
            "type": "VARCHAR(100)",
            "description": "Name of the competition",
            "optional": false
          },
          {
            "name": "season",
            "type": "VARCHAR(20)",
            "description": "Season information",
            "optional": false
          },
          {
            "name": "is_postponed",
            "type": "BOOLEAN",
            "description": "Whether the match has been postponed",
            "default": "false",
            "optional": false
          },
          {
            "name": "original_date",
            "type": "DATETIME",
            "description": "Original match date if rescheduled",
            "optional": true
          },
          {
            "name": "postponement_reason",
            "type": "TEXT",
            "description": "Reason for postponement if applicable",
            "optional": true
          }
        ],
        "primary_key": "match_id"
      }
    },
    {
      "table_name": "seat",
      "description": "Stores seat information including location, category, pricing, and availability status",
      "schema": {
        "columns": [
          {
            "name": "seat_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the seat",
            "optional": false
          },
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Associated match identifier",
            "optional": false,
            "references": "match.match_id"
          },
          {
            "name": "venue_name",
            "type": "VARCHAR(100)",
            "description": "Name of the venue",
            "optional": false
          },
          {
            "name": "section",
            "type": "VARCHAR(50)",
            "description": "Stadium section name",
            "optional": false
          },
          {
            "name": "row",
            "type": "VARCHAR(10)",
            "description": "Row identifier",
            "optional": false
          },
          {
            "name": "seat_number",
            "type": "VARCHAR(10)",
            "description": "Seat number within the row",
            "optional": false
          },
          {
            "name": "category",
            "type": "VARCHAR(50)",
            "description": "Seat category",
            "optional": false,
            "enum": [
              "VIP",
              "Premium",
              "Standard",
              "Economy",
              "Family Stand"
            ]
          },
          {
            "name": "price",
            "type": "DECIMAL(10,2)",
            "description": "Seat price",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Seat status",
            "optional": false,
            "enum": [
              "available",
              "reserved",
              "sold",
              "used"
            ]
          },
          {
            "name": "wheelchair_accessible",
            "type": "BOOLEAN",
            "description": "Whether seat is wheelchair accessible",
            "default": "false",
            "optional": false
          },
          {
            "name": "companion_seat",
            "type": "BOOLEAN",
            "description": "Whether seat is designated as companion seat",
            "default": "false",
            "optional": false
          },
          {
            "name": "elevator_access",
            "type": "BOOLEAN",
            "description": "Whether elevator access is available",
            "default": "false",
            "optional": false
          }
        ],
        "primary_key": "seat_id"
      }
    },
    {
      "table_name": "reservation",
      "description": "Stores temporary seat reservations with expiration time before final booking",
      "schema": {
        "columns": [
          {
            "name": "reservation_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the reservation",
            "optional": false
          },
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Associated match identifier",
            "optional": false,
            "references": "match.match_id"
          },
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Customer who made the reservation",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "reservation_time",
            "type": "DATETIME",
            "description": "Time when reservation was created",
            "optional": false
          },
          {
            "name": "expiration_time",
            "type": "DATETIME",
            "description": "Expiration time of the reservation",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Reservation status",
            "optional": false,
            "enum": [
              "active",
              "expired",
              "converted",
              "released"
            ]
          }
        ],
        "primary_key": "reservation_id"
      }
    },
    {
      "table_name": "reservation_seat",
      "description": "Junction table linking reservations to specific seats",
      "schema": {
        "columns": [
          {
            "name": "reservation_seat_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the reservation-seat relationship",
            "optional": false
          },
          {
            "name": "reservation_id",
            "type": "VARCHAR(10)",
            "description": "Associated reservation identifier",
            "optional": false,
            "references": "reservation.reservation_id"
          },
          {
            "name": "seat_id",
            "type": "VARCHAR(10)",
            "description": "Associated seat identifier",
            "optional": false,
            "references": "seat.seat_id"
          }
        ],
        "primary_key": "reservation_seat_id"
      }
    },
    {
      "table_name": "booking",
      "description": "Stores confirmed ticket bookings with payment and customer information",
      "schema": {
        "columns": [
          {
            "name": "booking_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the booking",
            "optional": false
          },
          {
            "name": "booking_reference",
            "type": "VARCHAR(50)",
            "description": "Human-readable booking reference code",
            "optional": false
          },
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Associated match identifier",
            "optional": false,
            "references": "match.match_id"
          },
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Customer who made the booking",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "reservation_id",
            "type": "VARCHAR(10)",
            "description": "Original reservation identifier",
            "optional": true,
            "references": "reservation.reservation_id"
          },
          {
            "name": "payment_id",
            "type": "VARCHAR(10)",
            "description": "Associated payment transaction identifier",
            "optional": false,
            "references": "payment.payment_id"
          },
          {
            "name": "email",
            "type": "VARCHAR(255)",
            "description": "Customer contact email",
            "optional": false
          },
          {
            "name": "phone",
            "type": "VARCHAR(20)",
            "description": "Customer contact phone number",
            "optional": true
          },
          {
            "name": "total_price",
            "type": "DECIMAL(10,2)",
            "description": "Total price paid for the booking",
            "optional": false
          },
          {
            "name": "booking_time",
            "type": "DATETIME",
            "description": "Time when booking was created",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current booking status",
            "optional": false,
            "enum": [
              "confirmed",
              "cancelled",
              "completed",
              "pending"
            ]
          },
          {
            "name": "cancellation_time",
            "type": "DATETIME",
            "description": "Time when booking was cancelled",
            "optional": true
          },
          {
            "name": "cancellation_reason",
            "type": "TEXT",
            "description": "Reason for cancellation",
            "optional": true
          },
          {
            "name": "refund_amount",
            "type": "DECIMAL(10,2)",
            "description": "Amount refunded if cancelled",
            "optional": true
          }
        ],
        "primary_key": "booking_id"
      }
    },
    {
      "table_name": "booking_seat",
      "description": "Junction table linking bookings to specific seats with ticket usage tracking",
      "schema": {
        "columns": [
          {
            "name": "booking_seat_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the booking-seat relationship",
            "optional": false
          },
          {
            "name": "booking_id",
            "type": "VARCHAR(10)",
            "description": "Associated booking identifier",
            "optional": false,
            "references": "booking.booking_id"
          },
          {
            "name": "seat_id",
            "type": "VARCHAR(10)",
            "description": "Associated seat identifier",
            "optional": false,
            "references": "seat.seat_id"
          },
          {
            "name": "is_used",
            "type": "BOOLEAN",
            "description": "Whether ticket has been used for entry",
            "default": "false",
            "optional": false
          },
          {
            "name": "entry_time",
            "type": "DATETIME",
            "description": "Time when ticket was used for entry",
            "optional": true
          },
          {
            "name": "entry_gate",
            "type": "VARCHAR(50)",
            "description": "Gate number where entry occurred",
            "optional": true
          },
          {
            "name": "qr_code_data",
            "type": "TEXT",
            "description": "QR code data for ticket validation",
            "optional": true
          }
        ],
        "primary_key": "booking_seat_id"
      }
    },
    {
      "table_name": "customer",
      "description": "Stores customer information including membership status and loyalty details",
      "schema": {
        "columns": [
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the customer",
            "optional": false
          },
          {
            "name": "email",
            "type": "VARCHAR(255)",
            "description": "Customer email address",
            "optional": false
          },
          {
            "name": "phone",
            "type": "VARCHAR(20)",
            "description": "Customer phone number",
            "optional": true
          },
          {
            "name": "is_season_ticket_holder",
            "type": "BOOLEAN",
            "description": "Whether customer is a season ticket holder",
            "default": "false",
            "optional": false
          },
          {
            "name": "loyalty_tier",
            "type": "VARCHAR(20)",
            "description": "Customer loyalty tier",
            "optional": true,
            "enum": [
              "bronze",
              "silver",
              "gold",
              "platinum"
            ]
          },
          {
            "name": "total_loyalty_points",
            "type": "INTEGER",
            "description": "Total accumulated loyalty points",
            "default": "0",
            "optional": false
          },
          {
            "name": "age",
            "type": "INTEGER",
            "description": "Customer age in years",
            "optional": true
          }
        ],
        "primary_key": "customer_id"
      }
    },
    {
      "table_name": "payment",
      "description": "Stores payment transaction information for bookings",
      "schema": {
        "columns": [
          {
            "name": "payment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the payment",
            "optional": false
          },
          {
            "name": "booking_id",
            "type": "VARCHAR(10)",
            "description": "Associated booking identifier",
            "optional": true,
            "references": "booking.booking_id"
          },
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Customer who made the payment",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "payment_method",
            "type": "VARCHAR(50)",
            "description": "Payment method used",
            "optional": false,
            "enum": [
              "credit_card",
              "debit_card",
              "paypal",
              "bank_transfer",
              "alipay",
              "wechat_pay"
            ]
          },
          {
            "name": "amount",
            "type": "DECIMAL(10,2)",
            "description": "Payment amount",
            "optional": false
          },
          {
            "name": "payment_status",
            "type": "VARCHAR(20)",
            "description": "Payment status",
            "optional": false,
            "enum": [
              "pending",
              "completed",
              "failed",
              "refunded"
            ]
          },
          {
            "name": "payment_time",
            "type": "DATETIME",
            "description": "Time when payment was processed",
            "optional": false
          },
          {
            "name": "transaction_reference",
            "type": "VARCHAR(100)",
            "description": "Payment gateway transaction reference",
            "optional": true
          }
        ],
        "primary_key": "payment_id"
      }
    },
    {
      "table_name": "discount_code",
      "description": "Stores discount codes with validation rules and usage tracking",
      "schema": {
        "columns": [
          {
            "name": "discount_code",
            "type": "VARCHAR(50)",
            "description": "Discount code string",
            "optional": false
          },
          {
            "name": "discount_type",
            "type": "VARCHAR(20)",
            "description": "Type of discount",
            "optional": false,
            "enum": [
              "percentage",
              "fixed_amount"
            ]
          },
          {
            "name": "discount_value",
            "type": "DECIMAL(10,2)",
            "description": "Discount value (percentage or amount)",
            "optional": false
          },
          {
            "name": "expiration_date",
            "type": "DATE",
            "description": "Expiration date of the discount code",
            "optional": false
          },
          {
            "name": "is_active",
            "type": "BOOLEAN",
            "description": "Whether discount code is currently active",
            "default": "true",
            "optional": false
          },
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Specific match the code applies to (if applicable)",
            "optional": true,
            "references": "match.match_id"
          },
          {
            "name": "min_purchase_amount",
            "type": "DECIMAL(10,2)",
            "description": "Minimum purchase amount required",
            "optional": true
          },
          {
            "name": "max_uses",
            "type": "INTEGER",
            "description": "Maximum number of times code can be used",
            "optional": true
          },
          {
            "name": "times_used",
            "type": "INTEGER",
            "description": "Number of times code has been used",
            "default": "0",
            "optional": false
          }
        ],
        "primary_key": "discount_code"
      }
    },
    {
      "table_name": "ticket_transfer",
      "description": "Stores ticket transfer records between customers",
      "schema": {
        "columns": [
          {
            "name": "transfer_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the transfer",
            "optional": false
          },
          {
            "name": "booking_id",
            "type": "VARCHAR(10)",
            "description": "Original booking identifier",
            "optional": false,
            "references": "booking.booking_id"
          },
          {
            "name": "seat_id",
            "type": "VARCHAR(10)",
            "description": "Seat being transferred",
            "optional": false,
            "references": "seat.seat_id"
          },
          {
            "name": "from_customer_id",
            "type": "VARCHAR(10)",
            "description": "Original owner customer ID",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "to_customer_id",
            "type": "VARCHAR(10)",
            "description": "New owner customer ID",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "transfer_time",
            "type": "DATETIME",
            "description": "Time when transfer was completed",
            "optional": false
          },
          {
            "name": "transfer_reason",
            "type": "TEXT",
            "description": "Reason for transfer",
            "optional": true
          },
          {
            "name": "new_booking_reference",
            "type": "VARCHAR(50)",
            "description": "New booking reference for the recipient",
            "optional": false
          }
        ],
        "primary_key": "transfer_id"
      }
    },
    {
      "table_name": "venue",
      "description": "Stores venue information including capacity and facilities",
      "schema": {
        "columns": [
          {
            "name": "venue_name",
            "type": "VARCHAR(100)",
            "description": "Name of the venue",
            "optional": false
          },
          {
            "name": "total_capacity",
            "type": "INTEGER",
            "description": "Total seating capacity",
            "optional": false
          },
          {
            "name": "address",
            "type": "TEXT",
            "description": "Venue address",
            "optional": true
          },
          {
            "name": "wifi_available",
            "type": "BOOLEAN",
            "description": "Whether WiFi is available",
            "default": "false",
            "optional": false
          }
        ],
        "primary_key": "venue_name"
      }
    },
    {
      "table_name": "venue_section",
      "description": "Stores venue section details and capacity information",
      "schema": {
        "columns": [
          {
            "name": "section_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the section",
            "optional": false
          },
          {
            "name": "venue_name",
            "type": "VARCHAR(100)",
            "description": "Associated venue name",
            "optional": false,
            "references": "venue.venue_name"
          },
          {
            "name": "section",
            "type": "VARCHAR(50)",
            "description": "Name of the section",
            "optional": false
          },
          {
            "name": "capacity",
            "type": "INTEGER",
            "description": "Section capacity",
            "optional": false
          }
        ],
        "primary_key": "section_id"
      }
    },
    {
      "table_name": "venue_facility",
      "description": "Stores venue facilities information such as parking, food outlets, and accessibility features",
      "schema": {
        "columns": [
          {
            "name": "facility_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the facility",
            "optional": false
          },
          {
            "name": "venue_name",
            "type": "VARCHAR(100)",
            "description": "Associated venue name",
            "optional": false,
            "references": "venue.venue_name"
          },
          {
            "name": "facility_type",
            "type": "VARCHAR(50)",
            "description": "Type of facility",
            "optional": false,
            "enum": [
              "parking",
              "food_outlet",
              "accessibility",
              "restroom",
              "merchandise"
            ]
          },
          {
            "name": "facility_name",
            "type": "VARCHAR(100)",
            "description": "Name of the facility",
            "optional": false
          },
          {
            "name": "capacity",
            "type": "INTEGER",
            "description": "Facility capacity (if applicable)",
            "optional": true
          },
          {
            "name": "price",
            "type": "DECIMAL(10,2)",
            "description": "Facility price (if applicable)",
            "optional": true
          }
        ],
        "primary_key": "facility_id"
      }
    },
    {
      "table_name": "pricing_tier",
      "description": "Stores pricing tiers and categories for matches",
      "schema": {
        "columns": [
          {
            "name": "pricing_tier_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the pricing tier",
            "optional": false
          },
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Associated match identifier",
            "optional": false,
            "references": "match.match_id"
          },
          {
            "name": "tier_name",
            "type": "VARCHAR(50)",
            "description": "Name of the pricing tier",
            "optional": false
          },
          {
            "name": "base_price",
            "type": "DECIMAL(10,2)",
            "description": "Base price for the tier",
            "optional": false
          },
          {
            "name": "member_price",
            "type": "DECIMAL(10,2)",
            "description": "Price for members",
            "optional": true
          },
          {
            "name": "child_price",
            "type": "DECIMAL(10,2)",
            "description": "Price for children",
            "optional": true
          },
          {
            "name": "senior_price",
            "type": "DECIMAL(10,2)",
            "description": "Price for seniors",
            "optional": true
          }
        ],
        "primary_key": "pricing_tier_id"
      }
    },
    {
      "table_name": "season_ticket",
      "description": "Stores season ticket holder information and assigned seats",
      "schema": {
        "columns": [
          {
            "name": "season_ticket_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the season ticket",
            "optional": false
          },
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Associated customer identifier",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "season",
            "type": "VARCHAR(20)",
            "description": "Season identifier",
            "optional": false
          },
          {
            "name": "venue_name",
            "type": "VARCHAR(100)",
            "description": "Venue name",
            "optional": false,
            "references": "venue.venue_name"
          },
          {
            "name": "section",
            "type": "VARCHAR(50)",
            "description": "Assigned section",
            "optional": false
          },
          {
            "name": "row",
            "type": "VARCHAR(10)",
            "description": "Assigned row",
            "optional": false
          },
          {
            "name": "seat_number",
            "type": "VARCHAR(10)",
            "description": "Assigned seat number",
            "optional": false
          },
          {
            "name": "priority_window_start",
            "type": "DATETIME",
            "description": "Start time of priority booking window",
            "optional": true
          }
        ],
        "primary_key": "season_ticket_id"
      }
    },
    {
      "table_name": "waitlist",
      "description": "Stores customer waitlist entries for sold-out matches",
      "schema": {
        "columns": [
          {
            "name": "waitlist_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the waitlist entry",
            "optional": false
          },
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Customer on the waitlist",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "match_id",
            "type": "VARCHAR(10)",
            "description": "Match identifier",
            "optional": false,
            "references": "match.match_id"
          },
          {
            "name": "ticket_quantity",
            "type": "INTEGER",
            "description": "Number of tickets desired",
            "optional": false
          },
          {
            "name": "preferred_category",
            "type": "VARCHAR(50)",
            "description": "Preferred seat category",
            "optional": true,
            "enum": [
              "VIP",
              "Premium",
              "Standard",
              "Economy",
              "Family Stand"
            ]
          },
          {
            "name": "position",
            "type": "INTEGER",
            "description": "Position in the waitlist",
            "optional": false
          },
          {
            "name": "joined_time",
            "type": "DATETIME",
            "description": "Time when customer joined waitlist",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Waitlist status",
            "optional": false,
            "enum": [
              "active",
              "notified",
              "converted",
              "expired"
            ]
          },
          {
            "name": "notification_sent",
            "type": "BOOLEAN",
            "description": "Whether availability notification has been sent",
            "default": "false",
            "optional": false
          }
        ],
        "primary_key": "waitlist_id"
      }
    },
    {
      "table_name": "resale_listing",
      "description": "Stores tickets listed for resale on the official platform",
      "schema": {
        "columns": [
          {
            "name": "resale_listing_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the resale listing",
            "optional": false
          },
          {
            "name": "booking_id",
            "type": "VARCHAR(10)",
            "description": "Original booking identifier",
            "optional": false,
            "references": "booking.booking_id"
          },
          {
            "name": "seat_id",
            "type": "VARCHAR(10)",
            "description": "Seat being listed for resale",
            "optional": false,
            "references": "seat.seat_id"
          },
          {
            "name": "seller_customer_id",
            "type": "VARCHAR(10)",
            "description": "Customer ID of the seller",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "resale_price",
            "type": "DECIMAL(10,2)",
            "description": "Price listed for resale",
            "optional": false
          },
          {
            "name": "listed_time",
            "type": "DATETIME",
            "description": "Time when ticket was listed",
            "optional": false
          },
          {
            "name": "listing_status",
            "type": "VARCHAR(20)",
            "description": "Current status of the listing",
            "optional": false,
            "enum": [
              "active",
              "sold",
              "expired",
              "withdrawn"
            ]
          },
          {
            "name": "sold_time",
            "type": "DATETIME",
            "description": "Time when ticket was sold",
            "optional": true
          },
          {
            "name": "buyer_customer_id",
            "type": "VARCHAR(10)",
            "description": "Customer ID of the buyer (if sold)",
            "optional": true,
            "references": "customer.customer_id"
          },
          {
            "name": "seller_payout_amount",
            "type": "DECIMAL(10,2)",
            "description": "Amount to be paid to seller after fees",
            "optional": true
          }
        ],
        "primary_key": "resale_listing_id"
      }
    },
    {
      "table_name": "communication_log",
      "description": "Stores log of all communications sent to customers",
      "schema": {
        "columns": [
          {
            "name": "message_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the message",
            "optional": false
          },
          {
            "name": "customer_id",
            "type": "VARCHAR(10)",
            "description": "Recipient customer identifier",
            "optional": false,
            "references": "customer.customer_id"
          },
          {
            "name": "booking_id",
            "type": "VARCHAR(10)",
            "description": "Associated booking identifier (if applicable)",
            "optional": true,
            "references": "booking.booking_id"
          },
          {
            "name": "communication_type",
            "type": "VARCHAR(50)",
            "description": "Type of communication",
            "optional": false,
            "enum": [
              "confirmation",
              "reminder",
              "notification",
              "cancellation",
              "update"
            ]
          },
          {
            "name": "channel",
            "type": "VARCHAR(20)",
            "description": "Communication channel",
            "optional": false,
            "enum": [
              "email",
              "sms",
              "push"
            ]
          },
          {
            "name": "recipient_address",
            "type": "VARCHAR(255)",
            "description": "Email address or phone number",
            "optional": false
          },
          {
            "name": "sent_time",
            "type": "DATETIME",
            "description": "Time when message was sent",
            "optional": false
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Delivery status",
            "optional": false,
            "enum": [
              "sent",
              "delivered",
              "failed"
            ]
          }
        ],
        "primary_key": "message_id"
      }
    }
  ],
  "tools": [
    {
      "name": "create_booking",
      "description": "Create a new ticket booking for reserved seats",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_creation",
      "pre_condition": "Valid reservation must exist and payment must be confirmed",
      "post_condition": "Booking is created and seats are confirmed",
      "parameters": {
        "type": "object",
        "properties": {
          "reservation_id": {
            "description": "Unique identifier for the reservation",
            "type": "string",
            "examples": [
              "R99999"
            ]
          },
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "payment_id": {
            "description": "Unique identifier for the payment transaction",
            "type": "string",
            "examples": [
              "P11111"
            ]
          },
          "customer_email": {
            "description": "Customer contact email",
            "type": "string",
            "examples": [
              "customer@example.com"
            ]
          },
          "customer_phone": {
            "description": "Customer contact phone number",
            "type": "string",
            "examples": [
              "+44 20 1234 5678"
            ]
          }
        },
        "required": [
          "reservation_id",
          "customer_id",
          "payment_id",
          "customer_email"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "booking_reference": {
            "description": "Human-readable booking reference code",
            "type": "string",
            "examples": [
              "MU-2024-ABC123"
            ]
          },
          "booking_time": {
            "description": "Time when booking was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 10:55:00"
            ]
          },
          "status": {
            "description": "Current booking status",
            "type": "string",
            "enum": [
              "confirmed",
              "cancelled",
              "completed",
              "pending"
            ],
            "examples": [
              "confirmed"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "booking_seat",
        "customer",
        "match",
        "payment",
        "reservation",
        "reservation_seat",
        "seat"
      ]
    },
    {
      "name": "process_postponement_refund",
      "description": "Process refund for bookings when a match is postponed and customer opts for refund",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_modification",
      "pre_condition": "Match must be postponed and booking must exist",
      "post_condition": "Refund is processed for the booking",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the postponed match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "refund_preference": {
            "description": "Customer refund preference",
            "type": "string",
            "enum": [
              "full_refund",
              "credit",
              "transfer"
            ],
            "examples": [
              "full_refund"
            ]
          }
        },
        "required": [
          "booking_id",
          "match_id",
          "refund_preference"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "refund_processed": {
            "description": "Whether refund was processed successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "refund_amount": {
            "description": "Amount refunded",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "refund_method": {
            "description": "Method of refund",
            "type": "string",
            "enum": [
              "original_payment_method",
              "credit",
              "bank_transfer"
            ],
            "examples": [
              "original_payment_method"
            ]
          },
          "processing_time": {
            "description": "Time when refund was processed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-18 14:00:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "match",
        "payment"
      ]
    },
    {
      "name": "check_resale_eligibility",
      "description": "Check if a ticket is eligible for resale on the official resale platform",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "validation",
      "pre_condition": "Booking and seat information must exist",
      "post_condition": "Returns resale eligibility status",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "seat_id": {
            "description": "Unique identifier for the seat",
            "type": "string",
            "examples": [
              "S001"
            ]
          },
          "resale_request_time": {
            "description": "Time when resale is requested in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-18 10:00:00"
            ]
          }
        },
        "required": [
          "booking_id",
          "seat_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_eligible": {
            "description": "Whether ticket is eligible for resale",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "reasons": {
            "description": "Reasons for eligibility or ineligibility",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Match is more than 48 hours away",
                "Ticket has not been used"
              ]
            ]
          },
          "resale_deadline": {
            "description": "Deadline for listing ticket for resale in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-19 15:00:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "booking_seat",
        "match"
      ]
    },
    {
      "name": "validate_ticket_qr_code",
      "description": "Validate a ticket QR code at venue entrance to verify authenticity and usage status",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "validation",
      "pre_condition": "QR code data must be provided",
      "post_condition": "Returns validation result with ticket details",
      "parameters": {
        "type": "object",
        "properties": {
          "qr_code_data": {
            "description": "QR code data string to validate",
            "type": "string",
            "examples": [
              "B55555-M12345-S001-2024031515"
            ]
          },
          "scan_time": {
            "description": "Time when QR code was scanned in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 14:30:00"
            ]
          }
        },
        "required": [
          "qr_code_data"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the QR code is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "booking_id": {
            "description": "Associated booking identifier",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "seat_info": {
            "description": "Seat information",
            "type": "object",
            "examples": [
              {
                "seat_id": "S001",
                "row": "A",
                "seat_number": "15"
              }
            ]
          },
          "already_used": {
            "description": "Whether the ticket has already been used",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "validation_message": {
            "description": "Validation message",
            "type": "string",
            "examples": [
              "Valid ticket - Entry permitted"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "booking_seat",
        "booking"
      ]
    },
    {
      "name": "check_match_postponement",
      "description": "Check if a match has been postponed or rescheduled",
      "group": "football.Ticket_Booking",
      "object_category": "match_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID must exist",
      "post_condition": "Returns match status and any postponement information",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_postponed": {
            "description": "Whether the match has been postponed",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "original_date": {
            "description": "Original match date in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-20 15:00:00"
            ]
          },
          "new_date": {
            "description": "Rescheduled date if applicable in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              null
            ]
          },
          "postponement_reason": {
            "description": "Reason for postponement if applicable",
            "type": "string",
            "examples": [
              null
            ]
          },
          "ticket_validity": {
            "description": "Whether existing tickets remain valid",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "match"
      ]
    },
    {
      "name": "get_booking_details",
      "description": "Retrieve complete details of a specific booking",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_retrieval",
      "pre_condition": "Booking ID must exist in the system",
      "post_condition": "Returns complete booking information",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          }
        },
        "required": [
          "booking_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "booking_reference": {
            "description": "Human-readable booking reference code",
            "type": "string",
            "examples": [
              "MU-2024-ABC123"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "seats": {
            "description": "List of booked seats",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "seat_id": "S001",
                  "row": "A",
                  "seat_number": "15"
                }
              ]
            ]
          },
          "total_price": {
            "description": "Total price paid",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "booking_time": {
            "description": "Time when booking was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 10:55:00"
            ]
          },
          "status": {
            "description": "Current booking status",
            "type": "string",
            "enum": [
              "confirmed",
              "cancelled",
              "completed",
              "pending"
            ],
            "examples": [
              "confirmed"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "booking_seat",
        "seat",
        "match"
      ]
    },
    {
      "name": "calculate_group_booking_discount",
      "description": "Calculate discount for group bookings based on quantity and group type",
      "group": "football.Ticket_Booking",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Valid group booking details must be provided",
      "post_condition": "Returns calculated group discount",
      "parameters": {
        "type": "object",
        "properties": {
          "base_price": {
            "description": "Base price per ticket",
            "type": "number",
            "examples": [
              80.0
            ]
          },
          "ticket_quantity": {
            "description": "Number of tickets in group booking",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "group_type": {
            "description": "Type of group",
            "type": "string",
            "enum": [
              "corporate",
              "school",
              "family",
              "charity",
              "club"
            ],
            "examples": [
              "school"
            ]
          }
        },
        "required": [
          "base_price",
          "ticket_quantity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "discount_percentage": {
            "description": "Applicable discount percentage",
            "type": "number",
            "examples": [
              15.0
            ]
          },
          "discount_per_ticket": {
            "description": "Discount amount per ticket",
            "type": "number",
            "examples": [
              12.0
            ]
          },
          "discounted_price_per_ticket": {
            "description": "Final price per ticket after discount",
            "type": "number",
            "examples": [
              68.0
            ]
          },
          "total_savings": {
            "description": "Total amount saved",
            "type": "number",
            "examples": [
              180.0
            ]
          },
          "total_price": {
            "description": "Total price for all tickets",
            "type": "number",
            "examples": [
              1020.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "search_available_matches",
      "description": "Search for available football matches based on filters such as date range, team, competition, and venue",
      "group": "football.Ticket_Booking",
      "object_category": "match_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match schedule data must be available in the system",
      "post_condition": "Returns a list of matches matching the search criteria",
      "parameters": {
        "type": "object",
        "properties": {
          "start_date": {
            "description": "Start date for match search in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-03-01"
            ]
          },
          "end_date": {
            "description": "End date for match search in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-03-31"
            ]
          },
          "team_name": {
            "description": "Name of the team to filter matches",
            "type": "string",
            "examples": [
              "Manchester United"
            ]
          },
          "competition_name": {
            "description": "Name of the competition to filter matches",
            "type": "string",
            "examples": [
              "Premier League"
            ]
          },
          "venue_name": {
            "description": "Name of the venue to filter matches",
            "type": "string",
            "examples": [
              "Old Trafford"
            ]
          }
        },
        "required": []
      },
      "returns": {
        "type": "object",
        "properties": {
          "matches": {
            "description": "List of available matches matching the search criteria",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "match_id": "M12345",
                  "home_team": "Manchester United",
                  "away_team": "Liverpool",
                  "match_date": "2024-03-15 15:00:00",
                  "venue": "Old Trafford",
                  "competition": "Premier League"
                }
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "match"
      ]
    },
    {
      "name": "generate_ticket_qr_code",
      "description": "Generate QR code data for a ticket that can be scanned at venue entrance",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "content_generation",
      "pre_condition": "Valid booking and seat information must be provided",
      "post_condition": "Returns QR code data for the ticket",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "seat_id": {
            "description": "Unique identifier for the seat",
            "type": "string",
            "examples": [
              "S001"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "booking_id",
          "seat_id",
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "qr_code_data": {
            "description": "QR code data string",
            "type": "string",
            "examples": [
              "B55555-M12345-S001-2024031515"
            ]
          },
          "qr_code_image": {
            "description": "Base64 encoded QR code image",
            "type": "string",
            "examples": [
              "iVBORw0KGgoAAAANSUhEUgAA..."
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "check_age_restrictions",
      "description": "Check if customer meets age restrictions for specific seat categories or match types",
      "group": "football.Ticket_Booking",
      "object_category": "customer_management",
      "action_category": "validation",
      "pre_condition": "Customer age and seat category must be provided",
      "post_condition": "Returns age restriction validation result",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_age": {
            "description": "Age of the customer in years",
            "type": "integer",
            "examples": [
              25
            ]
          },
          "seat_category": {
            "description": "Seat category being booked",
            "type": "string",
            "enum": [
              "VIP",
              "Premium",
              "Standard",
              "Economy",
              "Family Stand"
            ],
            "examples": [
              "Family Stand"
            ]
          },
          "match_type": {
            "description": "Type of match",
            "type": "string",
            "enum": [
              "league",
              "cup",
              "european",
              "friendly"
            ],
            "examples": [
              "league"
            ]
          }
        },
        "required": [
          "customer_age",
          "seat_category"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "meets_requirements": {
            "description": "Whether customer meets age requirements",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "minimum_age": {
            "description": "Minimum age required",
            "type": "integer",
            "examples": [
              0
            ]
          },
          "maximum_age": {
            "description": "Maximum age if applicable",
            "type": "integer",
            "examples": [
              null
            ]
          },
          "restrictions": {
            "description": "List of age-related restrictions",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Children under 14 must be accompanied by an adult"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_match_attendance_stats",
      "description": "Retrieve attendance statistics for a specific match including tickets sold and capacity utilization",
      "group": "football.Ticket_Booking",
      "object_category": "match_management",
      "action_category": "data_analysis",
      "pre_condition": "Match ID must exist in the system",
      "post_condition": "Returns attendance statistics",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_capacity": {
            "description": "Total venue capacity",
            "type": "integer",
            "examples": [
              74879
            ]
          },
          "tickets_sold": {
            "description": "Number of tickets sold",
            "type": "integer",
            "examples": [
              68500
            ]
          },
          "tickets_available": {
            "description": "Number of tickets still available",
            "type": "integer",
            "examples": [
              6379
            ]
          },
          "capacity_percentage": {
            "description": "Percentage of capacity sold",
            "type": "number",
            "examples": [
              91.5
            ]
          },
          "sales_by_category": {
            "description": "Breakdown of sales by seat category",
            "type": "object",
            "examples": [
              {
                "VIP": 200,
                "Premium": 5000,
                "Standard": 63300
              }
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "match",
        "seat",
        "booking_seat"
      ]
    },
    {
      "name": "get_pricing_tiers",
      "description": "Retrieve all pricing tiers and categories available for a specific match",
      "group": "football.Ticket_Booking",
      "object_category": "pricing_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID must exist in the system",
      "post_condition": "Returns pricing tier information",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "pricing_tiers": {
            "description": "List of pricing tiers with details",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "tier_name": "Category A",
                  "base_price": 80.0,
                  "member_price": 72.0,
                  "child_price": 40.0,
                  "senior_price": 64.0
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "pricing_tier"
      ]
    },
    {
      "name": "validate_booking_modification",
      "description": "Validate whether a booking can be modified based on match timing and booking policies",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "validation",
      "pre_condition": "Booking must exist",
      "post_condition": "Returns modification eligibility status",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "modification_type": {
            "description": "Type of modification",
            "type": "string",
            "enum": [
              "seat_change",
              "date_change",
              "cancel",
              "contact_update"
            ],
            "examples": [
              "seat_change"
            ]
          },
          "modification_request_time": {
            "description": "Time when modification is requested in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-18 10:00:00"
            ]
          }
        },
        "required": [
          "booking_id",
          "modification_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_modifiable": {
            "description": "Whether booking can be modified",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "reasons": {
            "description": "Reasons for modification eligibility or restrictions",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Modification allowed up to 24 hours before match"
              ]
            ]
          },
          "modification_deadline": {
            "description": "Deadline for making modifications in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-19 15:00:00"
            ]
          },
          "modification_fee": {
            "description": "Fee for making the modification",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "match"
      ]
    },
    {
      "name": "check_accessibility_requirements",
      "description": "Check if seats meet specific accessibility requirements for customers with disabilities",
      "group": "football.Ticket_Booking",
      "object_category": "seat_management",
      "action_category": "validation",
      "pre_condition": "Seat IDs and accessibility requirements must be provided",
      "post_condition": "Returns whether seats meet accessibility criteria",
      "parameters": {
        "type": "object",
        "properties": {
          "seat_ids": {
            "description": "List of seat identifiers to check",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "S001",
                "S002"
              ]
            ]
          },
          "wheelchair_accessible": {
            "description": "Whether wheelchair accessibility is required",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "companion_seat_required": {
            "description": "Whether companion seat is required",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "elevator_access_required": {
            "description": "Whether elevator access is required",
            "type": "boolean",
            "examples": [
              false
            ]
          }
        },
        "required": [
          "seat_ids"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "meets_requirements": {
            "description": "Whether seats meet all accessibility requirements",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "accessibility_features": {
            "description": "List of accessibility features available",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Wheelchair space",
                "Companion seat",
                "Level access"
              ]
            ]
          },
          "missing_features": {
            "description": "List of required features not available",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": []
          }
        },
        "raises": "ValueError"
      },
      "raises": "",
      "tool_type": "READ",
      "related_databases": [
        "seat"
      ]
    },
    {
      "name": "get_match_day_transport_info",
      "description": "Retrieve transport and travel information for match day",
      "group": "football.Ticket_Booking",
      "object_category": "venue_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID and venue must exist",
      "post_condition": "Returns match day transport information",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "venue_name": {
            "description": "Name of the venue",
            "type": "string",
            "examples": [
              "Old Trafford"
            ]
          }
        },
        "required": [
          "match_id",
          "venue_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "public_transport": {
            "description": "Public transport options",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "type": "Metrolink",
                  "station": "Old Trafford",
                  "frequency": "Every 12 minutes",
                  "service_changes": "Extended service until 23:00"
                }
              ]
            ]
          },
          "road_closures": {
            "description": "List of road closures on match day",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Sir Matt Busby Way closed from 13:00"
              ]
            ]
          },
          "recommended_arrival_time": {
            "description": "Recommended arrival time before kick-off in minutes",
            "type": "integer",
            "examples": [
              90
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "match",
        "venue"
      ]
    },
    {
      "name": "get_match_details",
      "description": "Retrieve detailed information about a specific football match including teams, venue, time, and competition",
      "group": "football.Ticket_Booking",
      "object_category": "match_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID must exist in the system",
      "post_condition": "Returns complete match details",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "home_team": {
            "description": "Name of the home team",
            "type": "string",
            "examples": [
              "Manchester United"
            ]
          },
          "away_team": {
            "description": "Name of the away team",
            "type": "string",
            "examples": [
              "Liverpool"
            ]
          },
          "match_date": {
            "description": "Date and time of the match in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 15:00:00"
            ]
          },
          "venue_name": {
            "description": "Name of the venue",
            "type": "string",
            "examples": [
              "Old Trafford"
            ]
          },
          "competition": {
            "description": "Name of the competition",
            "type": "string",
            "examples": [
              "Premier League"
            ]
          },
          "season": {
            "description": "Season information",
            "type": "string",
            "examples": [
              "2023-2024"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "match"
      ]
    },
    {
      "name": "update_booking_contact_info",
      "description": "Update contact information for an existing booking",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_modification",
      "pre_condition": "Booking must exist and be modifiable",
      "post_condition": "Booking contact information is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "new_email": {
            "description": "New email address",
            "type": "string",
            "examples": [
              "newemail@example.com"
            ]
          },
          "new_phone": {
            "description": "New phone number",
            "type": "string",
            "examples": [
              "+44 20 9876 5432"
            ]
          }
        },
        "required": [
          "booking_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "updated": {
            "description": "Whether update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "update_time": {
            "description": "Time when update was made in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-16 14:00:00"
            ]
          },
          "updated_fields": {
            "description": "List of fields that were updated",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "email",
                "phone"
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking"
      ]
    },
    {
      "name": "release_seat_reservation",
      "description": "Release previously reserved seats making them available again",
      "group": "football.Ticket_Booking",
      "object_category": "seat_management",
      "action_category": "state_management",
      "pre_condition": "Reservation must exist and be active",
      "post_condition": "Seats are released and marked as available",
      "parameters": {
        "type": "object",
        "properties": {
          "reservation_id": {
            "description": "Unique identifier for the reservation to release",
            "type": "string",
            "examples": [
              "R99999"
            ]
          }
        },
        "required": [
          "reservation_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "released_seats": {
            "description": "List of seat IDs that were released",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "S001",
                "S002"
              ]
            ]
          },
          "release_time": {
            "description": "Time when seats were released in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 10:50:00"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "reservation",
        "reservation_seat",
        "seat"
      ]
    },
    {
      "name": "send_booking_confirmation",
      "description": "Send booking confirmation details to customer via email",
      "group": "football.Ticket_Booking",
      "object_category": "communication_management",
      "action_category": "communication",
      "pre_condition": "Booking must be confirmed and customer email must be valid",
      "post_condition": "Confirmation email is sent to customer",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "customer_email": {
            "description": "Customer email address",
            "type": "string",
            "examples": [
              "customer@example.com"
            ]
          },
          "include_qr_code": {
            "description": "Whether to include QR code for tickets",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "booking_id",
          "customer_email"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "email_sent": {
            "description": "Whether email was sent successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "sent_time": {
            "description": "Time when email was sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 11:05:00"
            ]
          },
          "message_id": {
            "description": "Email message identifier",
            "type": "string",
            "examples": [
              "MSG123456"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "communication_log"
      ]
    },
    {
      "name": "get_venue_facilities_info",
      "description": "Retrieve information about venue facilities such as parking, food outlets, and amenities",
      "group": "football.Ticket_Booking",
      "object_category": "venue_management",
      "action_category": "data_retrieval",
      "pre_condition": "Venue name must be provided",
      "post_condition": "Returns venue facilities information",
      "parameters": {
        "type": "object",
        "properties": {
          "venue_name": {
            "description": "Name of the venue",
            "type": "string",
            "examples": [
              "Old Trafford"
            ]
          }
        },
        "required": [
          "venue_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "parking_facilities": {
            "description": "Information about parking options",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "North Car Park",
                  "capacity": 500,
                  "price": 15.0
                }
              ]
            ]
          },
          "food_outlets": {
            "description": "List of food and beverage outlets",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Red Cafe",
                "Stretford End Bar",
                "Family Stand Kiosk"
              ]
            ]
          },
          "accessibility_features": {
            "description": "Accessibility features available",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Wheelchair access",
                "Disabled toilets",
                "Hearing loop system"
              ]
            ]
          },
          "wifi_available": {
            "description": "Whether WiFi is available",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "venue",
        "venue_facility"
      ]
    },
    {
      "name": "transfer_ticket",
      "description": "Transfer a ticket from one customer to another",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "resource_transfer",
      "pre_condition": "Booking must exist and be transferable, both customers must be valid",
      "post_condition": "Ticket ownership is transferred to new customer",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "seat_id": {
            "description": "Unique identifier for the seat to transfer",
            "type": "string",
            "examples": [
              "S001"
            ]
          },
          "from_customer_id": {
            "description": "Current owner customer ID",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "to_customer_id": {
            "description": "New owner customer ID",
            "type": "string",
            "examples": [
              "C77777"
            ]
          },
          "transfer_reason": {
            "description": "Reason for transfer",
            "type": "string",
            "enum": [
              "gift",
              "resale",
              "unable_to_attend",
              "change_of_plans",
              "other"
            ],
            "examples": [
              "gift"
            ]
          }
        },
        "required": [
          "booking_id",
          "seat_id",
          "from_customer_id",
          "to_customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "transfer_id": {
            "description": "Unique identifier for the transfer",
            "type": "string",
            "examples": [
              "T88888"
            ]
          },
          "transfer_time": {
            "description": "Time when transfer was completed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-16 12:00:00"
            ]
          },
          "new_booking_reference": {
            "description": "New booking reference for the recipient",
            "type": "string",
            "examples": [
              "MU-2024-XYZ789"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "ticket_transfer",
        "booking",
        "booking_seat",
        "customer"
      ]
    },
    {
      "name": "get_booking_invoice",
      "description": "Generate and retrieve invoice details for a booking",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "content_generation",
      "pre_condition": "Booking must exist and be confirmed",
      "post_condition": "Returns invoice details",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          }
        },
        "required": [
          "booking_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "invoice_number": {
            "description": "Unique invoice number",
            "type": "string",
            "examples": [
              "INV-2024-001234"
            ]
          },
          "invoice_date": {
            "description": "Date invoice was generated in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-03-15"
            ]
          },
          "line_items": {
            "description": "List of invoice line items",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "description": "Match Ticket - VIP",
                  "quantity": 2,
                  "unit_price": 150.0,
                  "total": 300.0
                }
              ]
            ]
          },
          "subtotal": {
            "description": "Subtotal amount",
            "type": "number",
            "examples": [
              300.0
            ]
          },
          "tax_amount": {
            "description": "Tax amount",
            "type": "number",
            "examples": [
              0.0
            ]
          },
          "total_amount": {
            "description": "Total invoice amount",
            "type": "number",
            "examples": [
              285.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "booking_seat",
        "seat"
      ]
    },
    {
      "name": "get_venue_seating_map",
      "description": "Retrieve the seating map layout for a specific venue",
      "group": "football.Ticket_Booking",
      "object_category": "venue_management",
      "action_category": "data_retrieval",
      "pre_condition": "Venue information must exist in the system",
      "post_condition": "Returns venue seating map with section details",
      "parameters": {
        "type": "object",
        "properties": {
          "venue_name": {
            "description": "Name of the venue",
            "type": "string",
            "examples": [
              "Old Trafford"
            ]
          },
          "match_id": {
            "description": "Optional match ID to show availability overlay",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "venue_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "venue_name": {
            "description": "Name of the venue",
            "type": "string",
            "examples": [
              "Old Trafford"
            ]
          },
          "total_capacity": {
            "description": "Total seating capacity",
            "type": "integer",
            "examples": [
              74879
            ]
          },
          "sections": {
            "description": "List of seating sections with details",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "section_name": "North Stand",
                  "capacity": 25000,
                  "categories": [
                    "VIP",
                    "Premium",
                    "Standard"
                  ]
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "venue",
        "venue_section",
        "seat"
      ]
    },
    {
      "name": "send_booking_reminder",
      "description": "Send reminder notification to customer about upcoming match",
      "group": "football.Ticket_Booking",
      "object_category": "communication_management",
      "action_category": "communication",
      "pre_condition": "Booking must exist and be confirmed",
      "post_condition": "Reminder notification is sent to customer",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "reminder_type": {
            "description": "Type of reminder",
            "type": "string",
            "enum": [
              "24_hours",
              "2_hours",
              "1_week",
              "3_days",
              "match_day"
            ],
            "examples": [
              "24_hours"
            ]
          },
          "notification_channels": {
            "description": "Channels to send reminder through",
            "type": "array",
            "items": {
              "type": "string",
              "enum": [
                "email",
                "sms",
                "push"
              ]
            },
            "examples": [
              [
                "email",
                "sms"
              ]
            ]
          }
        },
        "required": [
          "booking_id",
          "reminder_type"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reminder_sent": {
            "description": "Whether reminder was sent successfully",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "sent_time": {
            "description": "Time when reminder was sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-19 15:00:00"
            ]
          },
          "channels_used": {
            "description": "Channels that successfully sent the reminder",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "email",
                "sms"
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "communication_log"
      ]
    },
    {
      "name": "get_booking_history",
      "description": "Retrieve complete booking history for a customer including past and upcoming bookings",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_retrieval",
      "pre_condition": "Customer ID must exist in the system",
      "post_condition": "Returns customer booking history",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "include_cancelled": {
            "description": "Whether to include cancelled bookings",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "limit": {
            "description": "Maximum number of bookings to return",
            "type": "integer",
            "examples": [
              50
            ]
          }
        },
        "required": [
          "customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_bookings": {
            "description": "Total number of bookings",
            "type": "integer",
            "examples": [
              25
            ]
          },
          "upcoming_bookings": {
            "description": "List of upcoming bookings",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "booking_id": "B55555",
                  "match_date": "2024-03-20 15:00:00",
                  "status": "confirmed"
                }
              ]
            ]
          },
          "past_bookings": {
            "description": "List of past bookings",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "booking_id": "B44444",
                  "match_date": "2024-02-15 15:00:00",
                  "status": "completed"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "customer"
      ]
    },
    {
      "name": "generate_booking_reference",
      "description": "Generate a unique human-readable booking reference code",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "content_generation",
      "pre_condition": "Match and customer information must be provided",
      "post_condition": "Returns a unique booking reference code",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "booking_date": {
            "description": "Date of booking in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-03-15"
            ]
          }
        },
        "required": [
          "match_id",
          "customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "booking_reference": {
            "description": "Generated booking reference code",
            "type": "string",
            "examples": [
              "MU-2024-ABC123"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "reserve_seats",
      "description": "Reserve selected seats for a specific duration to allow customer to complete booking",
      "group": "football.Ticket_Booking",
      "object_category": "seat_management",
      "action_category": "state_management",
      "pre_condition": "Seats must be available and not already reserved",
      "post_condition": "Seats are marked as reserved with expiration time",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "seat_ids": {
            "description": "List of seat identifiers to reserve",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "S001",
                "S002"
              ]
            ]
          },
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "reservation_duration_minutes": {
            "description": "Duration in minutes to hold the reservation",
            "type": "integer",
            "examples": [
              15
            ]
          }
        },
        "required": [
          "match_id",
          "seat_ids",
          "customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "reservation_id": {
            "description": "Unique identifier for the reservation",
            "type": "string",
            "examples": [
              "R99999"
            ]
          },
          "expiration_time": {
            "description": "Expiration time of the reservation in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 10:45:00"
            ]
          },
          "reserved_seats": {
            "description": "List of successfully reserved seat IDs",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "S001",
                "S002"
              ]
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "reservation",
        "reservation_seat",
        "seat"
      ]
    },
    {
      "name": "apply_discount_code",
      "description": "Validate and apply a discount code to calculate the discounted price",
      "group": "football.Ticket_Booking",
      "object_category": "pricing_management",
      "action_category": "validation",
      "pre_condition": "Discount code must exist and booking details must be provided",
      "post_condition": "Returns validation result and discount amount if valid",
      "parameters": {
        "type": "object",
        "properties": {
          "discount_code": {
            "description": "Discount code to validate and apply",
            "type": "string",
            "examples": [
              "SAVE10"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "original_price": {
            "description": "Original price before discount",
            "type": "number",
            "examples": [
              300.0
            ]
          }
        },
        "required": [
          "discount_code",
          "original_price"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the discount code is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "discount_type": {
            "description": "Type of discount",
            "type": "string",
            "enum": [
              "percentage",
              "fixed_amount"
            ],
            "examples": [
              "percentage"
            ]
          },
          "discount_value": {
            "description": "Discount value (percentage or amount)",
            "type": "number",
            "examples": [
              10.0
            ]
          },
          "discount_amount": {
            "description": "Calculated discount amount",
            "type": "number",
            "examples": [
              30.0
            ]
          },
          "final_price": {
            "description": "Final price after discount",
            "type": "number",
            "examples": [
              270.0
            ]
          },
          "expiration_date": {
            "description": "Expiration date of the discount code in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "discount_code"
      ]
    },
    {
      "name": "calculate_loyalty_points",
      "description": "Calculate loyalty points earned from a ticket booking",
      "group": "football.Ticket_Booking",
      "object_category": "customer_management",
      "action_category": "computation",
      "pre_condition": "Booking details must be provided",
      "post_condition": "Returns calculated loyalty points",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_amount": {
            "description": "Total booking amount",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "customer_tier": {
            "description": "Customer loyalty tier",
            "type": "string",
            "enum": [
              "bronze",
              "silver",
              "gold",
              "platinum"
            ],
            "examples": [
              "gold"
            ]
          },
          "match_importance": {
            "description": "Match importance level",
            "type": "string",
            "enum": [
              "regular",
              "important",
              "derby",
              "final"
            ],
            "examples": [
              "derby"
            ]
          }
        },
        "required": [
          "booking_amount"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "base_points": {
            "description": "Base loyalty points earned",
            "type": "integer",
            "examples": [
              285
            ]
          },
          "tier_bonus": {
            "description": "Bonus points from customer tier",
            "type": "integer",
            "examples": [
              57
            ]
          },
          "match_bonus": {
            "description": "Bonus points from match importance",
            "type": "integer",
            "examples": [
              100
            ]
          },
          "total_points": {
            "description": "Total loyalty points earned",
            "type": "integer",
            "examples": [
              442
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "validate_payment_amount",
      "description": "Validate that the payment amount matches the calculated booking total",
      "group": "football.Ticket_Booking",
      "object_category": "pricing_management",
      "action_category": "validation",
      "pre_condition": "Booking details and payment amount must be provided",
      "post_condition": "Returns validation result",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_amount": {
            "description": "Calculated total from booking system",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "payment_amount": {
            "description": "Amount being paid by customer",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "tolerance": {
            "description": "Acceptable difference tolerance",
            "type": "number",
            "examples": [
              0.01
            ]
          }
        },
        "required": [
          "booking_amount",
          "payment_amount"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether payment amount is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "difference": {
            "description": "Difference between calculated and paid amounts",
            "type": "number",
            "examples": [
              0.0
            ]
          },
          "validation_message": {
            "description": "Validation result message",
            "type": "string",
            "examples": [
              "Payment amount matches booking total"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "purchase_resale_ticket",
      "description": "Purchase a ticket from the official resale platform",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "resource_transfer",
      "pre_condition": "Resale listing must be active and available",
      "post_condition": "Ticket is transferred to buyer and removed from resale platform",
      "parameters": {
        "type": "object",
        "properties": {
          "resale_listing_id": {
            "description": "Unique identifier for the resale listing",
            "type": "string",
            "examples": [
              "RL12345"
            ]
          },
          "buyer_customer_id": {
            "description": "Customer ID of the buyer",
            "type": "string",
            "examples": [
              "C88888"
            ]
          },
          "payment_id": {
            "description": "Payment transaction identifier",
            "type": "string",
            "examples": [
              "P22222"
            ]
          }
        },
        "required": [
          "resale_listing_id",
          "buyer_customer_id",
          "payment_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "new_booking_id": {
            "description": "New booking ID for the buyer",
            "type": "string",
            "examples": [
              "B66666"
            ]
          },
          "purchase_time": {
            "description": "Time when purchase was completed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-18 11:00:00"
            ]
          },
          "seller_payout_amount": {
            "description": "Amount to be paid to seller after fees",
            "type": "number",
            "examples": [
              142.5
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "resale_listing",
        "booking",
        "booking_seat",
        "payment"
      ]
    },
    {
      "name": "get_booking_payment_details",
      "description": "Retrieve payment details and transaction information for a specific booking",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_retrieval",
      "pre_condition": "Booking ID must exist in the system",
      "post_condition": "Returns payment details for the booking",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          }
        },
        "required": [
          "booking_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "payment_id": {
            "description": "Payment transaction identifier",
            "type": "string",
            "examples": [
              "P11111"
            ]
          },
          "payment_method": {
            "description": "Payment method used",
            "type": "string",
            "enum": [
              "credit_card",
              "debit_card",
              "paypal",
              "bank_transfer",
              "alipay",
              "wechat_pay"
            ],
            "examples": [
              "credit_card"
            ]
          },
          "payment_status": {
            "description": "Current payment status",
            "type": "string",
            "enum": [
              "pending",
              "completed",
              "failed",
              "refunded"
            ],
            "examples": [
              "completed"
            ]
          },
          "amount_paid": {
            "description": "Total amount paid",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "payment_time": {
            "description": "Time when payment was processed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 10:55:00"
            ]
          },
          "transaction_reference": {
            "description": "Payment gateway transaction reference",
            "type": "string",
            "examples": [
              "TXN987654321"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "payment"
      ]
    },
    {
      "name": "notify_waitlist_availability",
      "description": "Notify customers on waitlist when tickets become available",
      "group": "football.Ticket_Booking",
      "object_category": "waitlist_management",
      "action_category": "communication",
      "pre_condition": "Tickets must be available and waitlist must exist",
      "post_condition": "Notifications are sent to waitlisted customers",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "available_seats": {
            "description": "Number of seats that became available",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "seat_category": {
            "description": "Category of available seats",
            "type": "string",
            "enum": [
              "VIP",
              "Premium",
              "Standard",
              "Economy",
              "Family Stand"
            ],
            "examples": [
              "Standard"
            ]
          }
        },
        "required": [
          "match_id",
          "available_seats"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "notifications_sent": {
            "description": "Number of notifications sent",
            "type": "integer",
            "examples": [
              5
            ]
          },
          "notified_customers": {
            "description": "List of customer IDs notified",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "C67890",
                "C77777",
                "C88888"
              ]
            ]
          },
          "notification_time": {
            "description": "Time when notifications were sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-17 10:00:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "waitlist",
        "communication_log"
      ]
    },
    {
      "name": "validate_seat_selection",
      "description": "Validate that selected seats meet booking requirements such as adjacency and availability",
      "group": "football.Ticket_Booking",
      "object_category": "seat_management",
      "action_category": "validation",
      "pre_condition": "Seat selection data must be provided",
      "post_condition": "Returns validation result with any errors or warnings",
      "parameters": {
        "type": "object",
        "properties": {
          "seat_ids": {
            "description": "List of seat identifiers to validate",
            "type": "array",
            "items": {
              "type": "string",
              "enum": []
            },
            "examples": [
              [
                "S001",
                "S002"
              ]
            ]
          },
          "require_adjacent": {
            "description": "Whether seats must be adjacent to each other",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "max_seats_per_booking": {
            "description": "Maximum number of seats allowed per booking",
            "type": "integer",
            "examples": [
              6
            ]
          }
        },
        "required": [
          "seat_ids"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Whether the seat selection is valid",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "errors": {
            "description": "List of validation errors",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Seats are not adjacent"
              ]
            ]
          },
          "warnings": {
            "description": "List of validation warnings",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Seats are in different sections"
              ]
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "check_booking_eligibility",
      "description": "Check if a customer is eligible to book tickets based on membership status, age restrictions, and purchase limits",
      "group": "football.Ticket_Booking",
      "object_category": "customer_management",
      "action_category": "validation",
      "pre_condition": "Customer ID must exist in the system",
      "post_condition": "Returns eligibility status with reasons",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "ticket_quantity": {
            "description": "Number of tickets to book",
            "type": "integer",
            "examples": [
              2
            ]
          }
        },
        "required": [
          "customer_id",
          "match_id",
          "ticket_quantity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_eligible": {
            "description": "Whether the customer is eligible to book",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "reasons": {
            "description": "List of reasons for eligibility or ineligibility",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Customer is a season ticket holder"
              ]
            ]
          },
          "restrictions": {
            "description": "Any restrictions that apply",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Maximum 4 tickets per customer"
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "customer",
        "booking",
        "season_ticket"
      ]
    },
    {
      "name": "join_match_waitlist",
      "description": "Add customer to the waitlist for a sold-out match",
      "group": "football.Ticket_Booking",
      "object_category": "waitlist_management",
      "action_category": "data_creation",
      "pre_condition": "Match must be sold out and customer must not already be on waitlist",
      "post_condition": "Customer is added to the waitlist",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "ticket_quantity": {
            "description": "Number of tickets desired",
            "type": "integer",
            "examples": [
              2
            ]
          },
          "preferred_category": {
            "description": "Preferred seat category",
            "type": "string",
            "enum": [
              "VIP",
              "Premium",
              "Standard",
              "Economy",
              "Family Stand"
            ],
            "examples": [
              "Standard"
            ]
          }
        },
        "required": [
          "customer_id",
          "match_id",
          "ticket_quantity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "waitlist_id": {
            "description": "Unique identifier for the waitlist entry",
            "type": "string",
            "examples": [
              "WL99999"
            ]
          },
          "position": {
            "description": "Initial position in the waitlist",
            "type": "integer",
            "examples": [
              251
            ]
          },
          "joined_time": {
            "description": "Time when added to waitlist in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-16 15:00:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "waitlist"
      ]
    },
    {
      "name": "check_duplicate_booking",
      "description": "Check if a customer already has a booking for the same match to prevent duplicates",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "validation",
      "pre_condition": "Customer ID and match ID must be provided",
      "post_condition": "Returns whether duplicate booking exists",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "customer_id",
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "has_existing_booking": {
            "description": "Whether customer already has a booking for this match",
            "type": "boolean",
            "examples": [
              false
            ]
          },
          "existing_booking_ids": {
            "description": "List of existing booking IDs if any",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [],
            "total_tickets_booked": {
              "description": "Total number of tickets already booked by customer for this match",
              "type": "integer",
              "examples": [
                0
              ]
            }
          }
        },
        "raises": "KeyError"
      },
      "raises": "",
      "tool_type": "READ",
      "related_databases": [
        "booking"
      ]
    },
    {
      "name": "calculate_ticket_price",
      "description": "Calculate the total price for selected tickets including base price and any applicable fees",
      "group": "football.Ticket_Booking",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Valid seat selection and pricing information provided",
      "post_condition": "Returns calculated total price with breakdown",
      "parameters": {
        "type": "object",
        "properties": {
          "base_price": {
            "description": "Base price per ticket",
            "type": "number",
            "examples": [
              150.0
            ]
          },
          "ticket_quantity": {
            "description": "Number of tickets",
            "type": "integer",
            "examples": [
              2
            ]
          },
          "service_fee_percentage": {
            "description": "Service fee as a percentage of base price",
            "type": "number",
            "examples": [
              5.0
            ]
          },
          "discount_percentage": {
            "description": "Discount percentage to apply",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        },
        "required": [
          "base_price",
          "ticket_quantity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "subtotal": {
            "description": "Subtotal before fees and discounts",
            "type": "number",
            "examples": [
              300.0
            ]
          },
          "service_fee": {
            "description": "Calculated service fee",
            "type": "number",
            "examples": [
              15.0
            ]
          },
          "discount_amount": {
            "description": "Calculated discount amount",
            "type": "number",
            "examples": [
              30.0
            ]
          },
          "total_price": {
            "description": "Final total price",
            "type": "number",
            "examples": [
              285.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "calculate_refund_amount",
      "description": "Calculate the refund amount for a cancelled booking based on cancellation policy and timing",
      "group": "football.Ticket_Booking",
      "object_category": "pricing_management",
      "action_category": "computation",
      "pre_condition": "Booking details and cancellation time must be provided",
      "post_condition": "Returns calculated refund amount with breakdown",
      "parameters": {
        "type": "object",
        "properties": {
          "original_price": {
            "description": "Original booking price",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "booking_time": {
            "description": "Time when booking was made in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 10:55:00"
            ]
          },
          "cancellation_time": {
            "description": "Time when cancellation is requested in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-16 09:00:00"
            ]
          },
          "match_date": {
            "description": "Date and time of the match in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-20 15:00:00"
            ]
          },
          "cancellation_fee_percentage": {
            "description": "Cancellation fee as percentage of original price",
            "type": "number",
            "examples": [
              10.0
            ]
          }
        },
        "required": [
          "original_price",
          "booking_time",
          "cancellation_time",
          "match_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "refund_amount": {
            "description": "Calculated refund amount",
            "type": "number",
            "examples": [
              256.5
            ]
          },
          "cancellation_fee": {
            "description": "Cancellation fee deducted",
            "type": "number",
            "examples": [
              28.5
            ]
          },
          "refund_percentage": {
            "description": "Percentage of original price refunded",
            "type": "number",
            "examples": [
              90.0
            ]
          },
          "days_before_match": {
            "description": "Number of days before match when cancelled",
            "type": "integer",
            "examples": [
              4
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_waitlist_position",
      "description": "Get customer's position on the waitlist for sold-out matches",
      "group": "football.Ticket_Booking",
      "object_category": "waitlist_management",
      "action_category": "data_retrieval",
      "pre_condition": "Customer must be on the waitlist",
      "post_condition": "Returns waitlist position information",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "customer_id",
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_on_waitlist": {
            "description": "Whether customer is on the waitlist",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "position": {
            "description": "Position in the waitlist",
            "type": "integer",
            "examples": [
              45
            ]
          },
          "total_waitlist_size": {
            "description": "Total number of customers on waitlist",
            "type": "integer",
            "examples": [
              250
            ]
          },
          "joined_time": {
            "description": "Time when customer joined waitlist in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-10 09:00:00"
            ]
          },
          "estimated_availability": {
            "description": "Estimated likelihood of tickets becoming available",
            "type": "string",
            "enum": [
              "Very High",
              "High",
              "Medium",
              "Low",
              "Very Low"
            ],
            "examples": [
              "Medium"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "waitlist"
      ]
    },
    {
      "name": "get_seat_availability",
      "description": "Retrieve available seats for a specific match including seat categories and pricing",
      "group": "football.Ticket_Booking",
      "object_category": "seat_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID must exist and seat inventory must be initialized",
      "post_condition": "Returns available seat information by category",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          }
        },
        "required": [
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "seat_categories": {
            "description": "List of seat categories with availability and pricing",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "category": "VIP",
                  "available_seats": 50,
                  "price": 150.0,
                  "section": "North Stand"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "seat"
      ]
    },
    {
      "name": "list_ticket_for_resale",
      "description": "List a ticket on the official resale platform for other customers to purchase",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "data_creation",
      "pre_condition": "Ticket must be eligible for resale",
      "post_condition": "Ticket is listed on resale platform",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "seat_id": {
            "description": "Unique identifier for the seat",
            "type": "string",
            "examples": [
              "S001"
            ]
          },
          "resale_price": {
            "description": "Price to list ticket for resale",
            "type": "number",
            "examples": [
              150.0
            ]
          },
          "seller_customer_id": {
            "description": "Customer ID of the seller",
            "type": "string",
            "examples": [
              "C67890"
            ]
          }
        },
        "required": [
          "booking_id",
          "seat_id",
          "resale_price",
          "seller_customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "resale_listing_id": {
            "description": "Unique identifier for the resale listing",
            "type": "string",
            "examples": [
              "RL12345"
            ]
          },
          "listed_time": {
            "description": "Time when ticket was listed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-18 10:30:00"
            ]
          },
          "listing_status": {
            "description": "Current status of the listing",
            "type": "string",
            "enum": [
              "active",
              "sold",
              "expired",
              "withdrawn"
            ],
            "examples": [
              "active"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "resale_listing",
        "booking",
        "booking_seat"
      ]
    },
    {
      "name": "get_season_ticket_benefits",
      "description": "Retrieve benefits and privileges for season ticket holders",
      "group": "football.Ticket_Booking",
      "object_category": "customer_management",
      "action_category": "data_retrieval",
      "pre_condition": "Customer must be a season ticket holder",
      "post_condition": "Returns season ticket benefits information",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "season": {
            "description": "Season identifier",
            "type": "string",
            "examples": [
              "2023-2024"
            ]
          }
        },
        "required": [
          "customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_season_ticket_holder": {
            "description": "Whether customer is a season ticket holder",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "benefits": {
            "description": "List of benefits available",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "Priority booking",
                "10% merchandise discount",
                "Free ticket transfers"
              ]
            ]
          },
          "priority_window_start": {
            "description": "Start time of priority booking window in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-01 09:00:00"
            ]
          },
          "assigned_seat": {
            "description": "Season ticket assigned seat information",
            "type": "object",
            "examples": [
              {
                "seat_id": "S001",
                "section": "North Stand",
                "row": "A",
                "seat_number": "15"
              }
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "customer",
        "season_ticket"
      ]
    },
    {
      "name": "search_customer_bookings",
      "description": "Search and retrieve all bookings for a specific customer",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_retrieval",
      "pre_condition": "Customer ID must exist in the system",
      "post_condition": "Returns list of customer bookings",
      "parameters": {
        "type": "object",
        "properties": {
          "customer_id": {
            "description": "Unique identifier for the customer",
            "type": "string",
            "examples": [
              "C67890"
            ]
          },
          "status_filter": {
            "description": "Filter bookings by status",
            "type": "string",
            "enum": [
              "confirmed",
              "cancelled",
              "completed",
              "pending"
            ],
            "examples": [
              "confirmed"
            ]
          },
          "start_date": {
            "description": "Start date for booking search in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-01-01"
            ]
          },
          "end_date": {
            "description": "End date for booking search in yyyy-mm-dd format",
            "type": "string",
            "examples": [
              "2024-12-31"
            ]
          }
        },
        "required": [
          "customer_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "bookings": {
            "description": "List of customer bookings",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "booking_id": "B55555",
                  "booking_reference": "MU-2024-ABC123",
                  "match_id": "M12345",
                  "booking_time": "2024-03-15 10:55:00",
                  "status": "confirmed"
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "customer"
      ]
    },
    {
      "name": "search_resale_tickets",
      "description": "Search for available tickets on the official resale platform",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID must be provided",
      "post_condition": "Returns list of available resale tickets",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "max_price": {
            "description": "Maximum price filter",
            "type": "number",
            "examples": [
              200.0
            ]
          },
          "preferred_section": {
            "description": "Preferred stadium section",
            "type": "string",
            "examples": [
              "North Stand"
            ]
          },
          "min_quantity": {
            "description": "Minimum number of adjacent seats",
            "type": "integer",
            "examples": [
              2
            ]
          }
        },
        "required": [
          "match_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "available_tickets": {
            "description": "List of available resale tickets",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "resale_listing_id": "RL12345",
                  "seat_id": "S001",
                  "section": "North Stand",
                  "row": "A",
                  "seat_number": "15",
                  "price": 150.0
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "resale_listing",
        "seat"
      ]
    },
    {
      "name": "get_specific_seats",
      "description": "Retrieve specific seat details including row, seat number, and availability status",
      "group": "football.Ticket_Booking",
      "object_category": "seat_management",
      "action_category": "data_retrieval",
      "pre_condition": "Match ID and seat category must exist",
      "post_condition": "Returns detailed seat information",
      "parameters": {
        "type": "object",
        "properties": {
          "match_id": {
            "description": "Unique identifier for the match",
            "type": "string",
            "examples": [
              "M12345"
            ]
          },
          "seat_category": {
            "description": "Seat category to retrieve seats from",
            "type": "string",
            "enum": [
              "VIP",
              "Premium",
              "Standard",
              "Economy",
              "Family Stand"
            ],
            "examples": [
              "VIP"
            ]
          },
          "section": {
            "description": "Stadium section name",
            "type": "string",
            "examples": [
              "North Stand"
            ]
          }
        },
        "required": [
          "match_id",
          "seat_category"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "seats": {
            "description": "List of specific seats with details",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "seat_id": "S001",
                  "row": "A",
                  "seat_number": "15",
                  "status": "available",
                  "price": 150.0
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "seat"
      ]
    },
    {
      "name": "cancel_booking",
      "description": "Cancel an existing booking and release the associated seats",
      "group": "football.Ticket_Booking",
      "object_category": "booking_management",
      "action_category": "data_modification",
      "pre_condition": "Booking must exist and be in a cancellable state",
      "post_condition": "Booking is marked as cancelled and seats are released",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking to cancel",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "cancellation_reason": {
            "description": "Reason for cancellation",
            "type": "string",
            "enum": [
              "customer_request",
              "duplicate_booking",
              "event_cancelled",
              "schedule_conflict",
              "payment_failed",
              "other"
            ],
            "examples": [
              "customer_request"
            ]
          }
        },
        "required": [
          "booking_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the cancelled booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "cancellation_time": {
            "description": "Time when booking was cancelled in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 11:00:00"
            ]
          },
          "refund_amount": {
            "description": "Amount to be refunded",
            "type": "number",
            "examples": [
              285.0
            ]
          },
          "status": {
            "description": "Updated booking status",
            "type": "string",
            "enum": [
              "cancelled"
            ],
            "examples": [
              "cancelled"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking",
        "booking_seat",
        "seat"
      ]
    },
    {
      "name": "mark_ticket_as_used",
      "description": "Mark a ticket as used after successful entry at venue",
      "group": "football.Ticket_Booking",
      "object_category": "ticket_management",
      "action_category": "state_management",
      "pre_condition": "Ticket must be valid and not already used",
      "post_condition": "Ticket is marked as used with entry timestamp",
      "parameters": {
        "type": "object",
        "properties": {
          "booking_id": {
            "description": "Unique identifier for the booking",
            "type": "string",
            "examples": [
              "B55555"
            ]
          },
          "seat_id": {
            "description": "Unique identifier for the seat",
            "type": "string",
            "examples": [
              "S001"
            ]
          },
          "entry_time": {
            "description": "Time when ticket was used in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 14:30:00"
            ]
          },
          "entry_gate": {
            "description": "Gate number where entry occurred",
            "type": "string",
            "examples": [
              "Gate A"
            ]
          }
        },
        "required": [
          "booking_id",
          "seat_id",
          "entry_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "marked_as_used": {
            "description": "Whether ticket was successfully marked as used",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "entry_time": {
            "description": "Recorded entry time in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-03-15 14:30:00"
            ]
          }
        }
      },
      "raises": "RuntimeError",
      "tool_type": "READ",
      "related_databases": [
        "booking_seat"
      ]
    }
  ],
  "schema_classification": {
    "Match": {
      "schema_name": "Match",
      "instance_key": "match_id",
      "fields": [
        {
          "field_name": "match_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "home_team",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "球队名称，不同表达可能指代同一支球队"
        },
        {
          "field_name": "away_team",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "球队名称，不同表达可能指代同一支球队"
        },
        {
          "field_name": "match_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "比赛时间必须精确匹配"
        },
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "场馆名称，不同表达可能指代同一场馆"
        },
        {
          "field_name": "competition",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "赛事名称，不同表达可能指代同一赛事"
        },
        {
          "field_name": "season",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "赛季信息通常有严格格式，必须精确匹配"
        },
        {
          "field_name": "is_postponed",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否延期必须精确匹配"
        },
        {
          "field_name": "original_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "原定比赛时间必须精确匹配"
        },
        {
          "field_name": "postponement_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "延期原因是自由文本描述，不同措辞可以表达相同含义"
        }
      ]
    },
    "Seat": {
      "schema_name": "Seat",
      "instance_key": "seat_id",
      "fields": [
        {
          "field_name": "seat_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "match_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "场馆名称，人类会认为不同表达可能表示同一场馆"
        },
        {
          "field_name": "section",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "场馆分区名称，自然语言表达，同一分区可能有不同名称表达"
        },
        {
          "field_name": "row",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "行号/标识符，通常需要精确匹配"
        },
        {
          "field_name": "seat_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "座位号，必须精确匹配"
        },
        {
          "field_name": "category",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "座位类别，枚举值，必须严格一致"
        },
        {
          "field_name": "price",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "价格，数值，必须严格一致"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "座位状态，枚举值，必须严格一致"
        },
        {
          "field_name": "wheelchair_accessible",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否可供轮椅，布尔值，必须严格一致"
        },
        {
          "field_name": "companion_seat",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否为陪同座，布尔值，必须严格一致"
        },
        {
          "field_name": "elevator_access",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "是否有电梯可达，布尔值，必须严格一致"
        }
      ]
    },
    "Reservation": {
      "schema_name": "Reservation",
      "instance_key": "reservation_id",
      "fields": [
        {
          "field_name": "reservation_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每个预订记录，通常由系统随机生成，每次执行都不同"
        },
        {
          "field_name": "match_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向关联比赛，必须精确匹配"
        },
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向客户，必须精确匹配"
        },
        {
          "field_name": "reservation_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配以确保预订时刻一致"
        },
        {
          "field_name": "expiration_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配以确保过期时刻一致"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，表示预订状态，任何微小差异都很重要，需精确匹配"
        }
      ]
    },
    "ReservationSeat": {
      "schema_name": "ReservationSeat",
      "instance_key": "reservation_seat_id",
      "fields": [
        {
          "field_name": "reservation_seat_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成的唯一标识符"
        },
        {
          "field_name": "reservation_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配以保证关联正确"
        },
        {
          "field_name": "seat_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配以保证关联正确"
        }
      ]
    },
    "Booking": {
      "schema_name": "Booking",
      "instance_key": "booking_id",
      "fields": [
        {
          "field_name": "booking_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键；唯一标识符由系统生成，每次不同"
        },
        {
          "field_name": "booking_reference",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "人类可读的预订参考码，通常为随机生成，用于用户识别，实际业务等价性不依赖此字段"
        },
        {
          "field_name": "match_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向比赛记录，必须精确一致"
        },
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向客户，必须精确一致"
        },
        {
          "field_name": "reservation_id",
          "field_type": "Optional[str]",
          "comparison_type": "ignore",
          "reason": "原始预订号，通常为外部或临时系统生成，仅用于追溯，实际业务等价性不依赖此字段"
        },
        {
          "field_name": "payment_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向付款记录，必须精确一致"
        },
        {
          "field_name": "email",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "邮箱属于自由文本，可能有大小写或别名差异，但业务上视为语义等价"
        },
        {
          "field_name": "phone",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "电话属于自由文本，格式、国家码等可能不同但实际号码等价"
        },
        {
          "field_name": "total_price",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "booking_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，表示当前状态，必须严格一致"
        },
        {
          "field_name": "cancellation_time",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配"
        },
        {
          "field_name": "cancellation_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可能表达同一原因"
        },
        {
          "field_name": "refund_amount",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        }
      ]
    },
    "BookingSeat": {
      "schema_name": "BookingSeat",
      "instance_key": "booking_seat_id",
      "fields": [
        {
          "field_name": "booking_seat_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具自动生成，每次执行都不同"
        },
        {
          "field_name": "booking_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联关系正确"
        },
        {
          "field_name": "seat_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保座位关联正确"
        },
        {
          "field_name": "is_used",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否入场，差异具有业务意义"
        },
        {
          "field_name": "entry_time",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，表示入场时间，必须精确匹配"
        },
        {
          "field_name": "entry_gate",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "门号，通常为编号或标识，需精确匹配"
        },
        {
          "field_name": "qr_code_data",
          "field_type": "Optional[str]",
          "comparison_type": "ignore",
          "reason": "二维码数据，随机生成用于验证，每次生成不同"
        }
      ]
    },
    "Customer": {
      "schema_name": "Customer",
      "instance_key": "customer_id",
      "fields": [
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "email",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电子邮箱地址必须完全匹配，通常用于唯一识别"
        },
        {
          "field_name": "phone",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "电话号码需要精确匹配，不同号码视为不同客户"
        },
        {
          "field_name": "is_season_ticket_holder",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，客户是否是季票持有者必须严格相等"
        },
        {
          "field_name": "loyalty_tier",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "枚举值（bronze, silver, gold, platinum），必须严格匹配"
        },
        {
          "field_name": "total_loyalty_points",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值字段，累计积分必须严格相等"
        },
        {
          "field_name": "age",
          "field_type": "Optional[int]",
          "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": "booking_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保关联的预订一致"
        },
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保付款客户一致"
        },
        {
          "field_name": "payment_method",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，付款方式必须严格一致"
        },
        {
          "field_name": "amount",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "payment_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，支付状态必须严格一致"
        },
        {
          "field_name": "payment_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须严格匹配"
        },
        {
          "field_name": "transaction_reference",
          "field_type": "Optional[str]",
          "comparison_type": "ignore",
          "reason": "支付网关交易参考号，通常为随机生成，每次不同"
        }
      ]
    },
    "DiscountCode": {
      "schema_name": "DiscountCode",
      "instance_key": "discount_code",
      "fields": [
        {
          "field_name": "discount_code",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，作为唯一标识符，通常为随机生成，每次执行不同"
        },
        {
          "field_name": "discount_type",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值（折扣类型），必须严格匹配以保证业务规则一致"
        },
        {
          "field_name": "discount_value",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值字段，折扣金额或百分比，需精确匹配"
        },
        {
          "field_name": "expiration_date",
          "field_type": "date",
          "comparison_type": "strict",
          "reason": "日期字段，折扣有效期，需严格一致"
        },
        {
          "field_name": "is_active",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，折扣码是否可用，需精确匹配"
        },
        {
          "field_name": "match_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID（可能指向比赛），需严格匹配以保证业务逻辑一致"
        },
        {
          "field_name": "min_purchase_amount",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值字段，最低消费金额，需精确匹配"
        },
        {
          "field_name": "max_uses",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值字段，最大使用次数，需严格一致"
        },
        {
          "field_name": "times_used",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值字段，已使用次数，需精确匹配"
        }
      ]
    },
    "TicketTransfer": {
      "schema_name": "TicketTransfer",
      "instance_key": "transfer_id",
      "fields": [
        {
          "field_name": "transfer_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具随机生成，每次执行都不同"
        },
        {
          "field_name": "booking_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确标识原始预订，必须严格相等"
        },
        {
          "field_name": "seat_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确标识座位，必须严格相等"
        },
        {
          "field_name": "from_customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确标识原持有客户，必须严格相等"
        },
        {
          "field_name": "to_customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，精确标识新持有客户，必须严格相等"
        },
        {
          "field_name": "transfer_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，必须精确匹配"
        },
        {
          "field_name": "transfer_reason",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "new_booking_reference",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID或唯一标识码，必须严格相等"
        }
      ]
    },
    "Venue": {
      "schema_name": "Venue",
      "instance_key": "venue_name",
      "fields": [
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "total_capacity",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "必须精确匹配的数值容量"
        },
        {
          "field_name": "address",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "地址属于自然语言文本，不同表达可等价"
        },
        {
          "field_name": "wifi_available",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配是否有WiFi"
        }
      ]
    },
    "VenueSection": {
      "schema_name": "VenueSection",
      "instance_key": "section_id",
      "fields": [
        {
          "field_name": "section_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符，每次生成可能不同"
        },
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "场馆名称，可能有不同表达方式但语义等价"
        },
        {
          "field_name": "section",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "分区名称，不同措辞可表达相同分区"
        },
        {
          "field_name": "capacity",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "容量为数值字段，必须精确匹配"
        }
      ]
    },
    "VenueFacility": {
      "schema_name": "VenueFacility",
      "instance_key": "facility_id",
      "fields": [
        {
          "field_name": "facility_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "场馆名称属于名称类字段，不同措辞可能表达同一场馆"
        },
        {
          "field_name": "facility_type",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，必须严格匹配"
        },
        {
          "field_name": "facility_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "设施名称属于名称类字段，不同措辞可能表达同一设施"
        },
        {
          "field_name": "capacity",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型字段，必须严格匹配"
        },
        {
          "field_name": "price",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值型字段，必须严格匹配"
        }
      ]
    },
    "PricingTier": {
      "schema_name": "PricingTier",
      "instance_key": "pricing_tier_id",
      "fields": [
        {
          "field_name": "pricing_tier_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识定价层，每次生成可能不同"
        },
        {
          "field_name": "match_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，关联到具体赛事，必须精确匹配"
        },
        {
          "field_name": "tier_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "定价层名称，自由文本，可能有不同表达但含义相同"
        },
        {
          "field_name": "base_price",
          "field_type": "Decimal",
          "comparison_type": "strict",
          "reason": "数值字段，基础价格，必须精确匹配"
        },
        {
          "field_name": "member_price",
          "field_type": "Optional[Decimal]",
          "comparison_type": "strict",
          "reason": "数值字段，会员价格，必须精确匹配"
        },
        {
          "field_name": "child_price",
          "field_type": "Optional[Decimal]",
          "comparison_type": "strict",
          "reason": "数值字段，儿童价格，必须精确匹配"
        },
        {
          "field_name": "senior_price",
          "field_type": "Optional[Decimal]",
          "comparison_type": "strict",
          "reason": "数值字段，老年人价格，必须精确匹配"
        }
      ]
    },
    "SeasonTicket": {
      "schema_name": "SeasonTicket",
      "instance_key": "season_ticket_id",
      "fields": [
        {
          "field_name": "season_ticket_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，标识关联的客户"
        },
        {
          "field_name": "season",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "赛季标识符，通常为枚举或字符串代码，必须精确匹配"
        },
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "场馆名称属于自然语言文本，不同表达可能等价"
        },
        {
          "field_name": "section",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "分区编号或名称，作为场馆座位分配的重要属性，需精确匹配"
        },
        {
          "field_name": "row",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "行号，需精确匹配，否则实际座位不同"
        },
        {
          "field_name": "seat_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "座位号，需精确匹配，否则实际座位不同"
        },
        {
          "field_name": "priority_window_start",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "优先购票时间窗口的起始时间，必须精确匹配"
        }
      ]
    },
    "Waitlist": {
      "schema_name": "Waitlist",
      "instance_key": "waitlist_id",
      "fields": [
        {
          "field_name": "waitlist_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "match_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "ticket_quantity",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "preferred_category",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "座位类别为自然语言文本，可能有不同表达但语义相同"
        },
        {
          "field_name": "position",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "joined_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，业务语义上每个状态都不同，需精确匹配"
        },
        {
          "field_name": "notification_sent",
          "field_type": "bool",
          "comparison_type": "strict",
          "reason": "布尔值，必须精确匹配"
        }
      ]
    },
    "ResaleListing": {
      "schema_name": "ResaleListing",
      "instance_key": "resale_listing_id",
      "fields": [
        {
          "field_name": "resale_listing_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次生成都不同"
        },
        {
          "field_name": "booking_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "seat_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "座位标识，必须精确匹配"
        },
        {
          "field_name": "seller_customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "resale_price",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "listed_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        },
        {
          "field_name": "listing_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值，状态必须精确匹配"
        },
        {
          "field_name": "sold_time",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        },
        {
          "field_name": "buyer_customer_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配"
        },
        {
          "field_name": "seller_payout_amount",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        }
      ]
    },
    "CommunicationLog": {
      "schema_name": "CommunicationLog",
      "instance_key": "message_id",
      "fields": [
        {
          "field_name": "message_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每条消息，由工具或系统自动生成，每次执行都不同"
        },
        {
          "field_name": "customer_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，用于唯一标识接收者，必须完全匹配"
        },
        {
          "field_name": "booking_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，可选字段，但只要有值就必须严格匹配"
        },
        {
          "field_name": "communication_type",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值（如确认、提醒、通知），业务含义不同，必须严格相等"
        },
        {
          "field_name": "channel",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值（如email、sms、push），不同渠道业务行为不同，需严格匹配"
        },
        {
          "field_name": "recipient_address",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电子邮件或电话号码，作为联系方式标识，需完全匹配"
        },
        {
          "field_name": "sent_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，代表消息发送时间，业务上精确匹配很重要"
        },
        {
          "field_name": "status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值（如sent, delivered, failed），业务含义不同，必须严格相等"
        }
      ]
    }
  }
}