{
  "openapi": "3.0.3",
  "info": {
    "title": "Seek & Thrill API",
    "version": "1.0.0",
    "description": "Search and discover 149,000+ outdoor adventure activities from 22,000+ providers across 109 countries. Free, no authentication required for read operations. Please include an `agent` query parameter or `X-Agent` header identifying your agent for usage tracking.",
    "contact": {
      "url": "https://seekandthrill.com"
    }
  },
  "servers": [
    {
      "url": "https://seekandthrill.com",
      "description": "Production"
    },
    {
      "url": "https://adventuredb-api.pierretokns.workers.dev",
      "description": "Direct API Worker"
    }
  ],
  "paths": {
    "/api/activities": {
      "get": {
        "operationId": "searchActivities",
        "summary": "Search and filter activities",
        "description": "Search activities by text query, category, country, city, price range, geo radius. Returns paginated results sorted by relevance, price, date, or rating.",
        "parameters": [
          {
            "name": "q",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "Text search query"
          },
          {
            "name": "category",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "Category slug: water-sports, hiking, climbing, tours, wellness, extreme, cultural, food-wine, horseback"
          },
          {
            "name": "subcategory",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "Subcategory name (e.g., Kayaking, Surfing, Scuba Diving)"
          },
          {
            "name": "country",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "Country name (e.g., Iceland, United States)"
          },
          {
            "name": "city",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "City name (e.g., Reykjavik, Boston)"
          },
          {
            "name": "region",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "State/region name (e.g., California, Massachusetts)"
          },
          {
            "name": "priceMin",
            "in": "query",
            "schema": {
              "type": "integer"
            },
            "description": "Minimum price in cents (1000 = $10)"
          },
          {
            "name": "priceMax",
            "in": "query",
            "schema": {
              "type": "integer"
            },
            "description": "Maximum price in cents (50000 = $500)"
          },
          {
            "name": "lat",
            "in": "query",
            "schema": {
              "type": "number"
            },
            "description": "Latitude for geo radius search"
          },
          {
            "name": "lng",
            "in": "query",
            "schema": {
              "type": "number"
            },
            "description": "Longitude for geo radius search"
          },
          {
            "name": "radius",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 50
            },
            "description": "Radius in km (max 500)"
          },
          {
            "name": "sort",
            "in": "query",
            "schema": {
              "type": "string",
              "enum": [
                "featured",
                "price_asc",
                "price_desc",
                "newest",
                "top_rated"
              ]
            },
            "description": "Sort order"
          },
          {
            "name": "limit",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 24,
              "maximum": 100
            },
            "description": "Results per page"
          },
          {
            "name": "offset",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 0
            },
            "description": "Pagination offset"
          }
        ],
        "responses": {
          "200": {
            "description": "Paginated activity results",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/ActivityListResponse"
                }
              }
            }
          }
        }
      }
    },
    "/api/activities/by-slug/{slug}": {
      "get": {
        "operationId": "getActivityBySlug",
        "summary": "Get activity by URL slug",
        "parameters": [
          {
            "name": "slug",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Activity URL slug"
          }
        ],
        "responses": {
          "200": {
            "description": "Activity detail",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/Activity"
                }
              }
            }
          }
        }
      }
    },
    "/api/find": {
      "get": {
        "operationId": "fullTextSearch",
        "summary": "Full-text BM25 search",
        "description": "Search across activity names, descriptions, headlines, locations, and provider names using FTS5 BM25 ranking.",
        "parameters": [
          {
            "name": "q",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Search query"
          },
          {
            "name": "limit",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 20
            },
            "description": "Max results"
          },
          {
            "name": "offset",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 0
            }
          },
          {
            "name": "category",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "country",
            "in": "query",
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Search results",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/ActivityListResponse"
                }
              }
            }
          }
        }
      }
    },
    "/api/autocomplete": {
      "get": {
        "operationId": "autocomplete",
        "summary": "Federated autocomplete search",
        "description": "Returns matching activities, providers, destinations, and categories for typeahead search.",
        "parameters": [
          {
            "name": "q",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string",
              "minLength": 2
            },
            "description": "Search query (min 2 chars)"
          },
          {
            "name": "limit",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 5,
              "maximum": 10
            },
            "description": "Max results per section"
          }
        ],
        "responses": {
          "200": {
            "description": "Autocomplete results with sections"
          }
        }
      }
    },
    "/api/categories/counts": {
      "get": {
        "operationId": "getCategoryCounts",
        "summary": "Get category counts",
        "description": "Returns all categories with activity counts, optionally filtered by country/city.",
        "parameters": [
          {
            "name": "country",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "city",
            "in": "query",
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Category count array"
          }
        }
      }
    },
    "/api/countries": {
      "get": {
        "operationId": "listCountries",
        "summary": "List countries with activity counts",
        "responses": {
          "200": {
            "description": "Country array sorted by count descending"
          }
        }
      }
    },
    "/api/countries/{country}/regions": {
      "get": {
        "operationId": "listRegions",
        "summary": "List regions/states for a country",
        "parameters": [
          {
            "name": "country",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Region array with counts"
          }
        }
      }
    },
    "/api/providers": {
      "get": {
        "operationId": "listProviders",
        "summary": "List booking providers",
        "parameters": [
          {
            "name": "q",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "Search provider names"
          },
          {
            "name": "country",
            "in": "query",
            "schema": {
              "type": "string"
            }
          },
          {
            "name": "platform",
            "in": "query",
            "schema": {
              "type": "string",
              "enum": [
                "fareharbor",
                "planyo",
                "regiondo",
                "bokun",
                "amc",
                "musement",
                "osm"
              ]
            }
          },
          {
            "name": "limit",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 20
            }
          },
          {
            "name": "offset",
            "in": "query",
            "schema": {
              "type": "integer",
              "default": 0
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Provider list"
          }
        }
      }
    },
    "/api/providers/{slug}": {
      "get": {
        "operationId": "getProvider",
        "summary": "Get provider by slug",
        "parameters": [
          {
            "name": "slug",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Provider detail"
          }
        }
      }
    },
    "/api/providers/{slug}/activities": {
      "get": {
        "operationId": "getProviderActivities",
        "summary": "List activities for a provider",
        "parameters": [
          {
            "name": "slug",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Activity list"
          }
        }
      }
    }
  },
  "components": {
    "schemas": {
      "Activity": {
        "type": "object",
        "properties": {
          "id": {
            "type": "integer"
          },
          "name": {
            "type": "string"
          },
          "slug": {
            "type": "string"
          },
          "description": {
            "type": "string",
            "nullable": true
          },
          "headline": {
            "type": "string",
            "nullable": true
          },
          "category": {
            "type": "string"
          },
          "subcategory": {
            "type": "string",
            "nullable": true
          },
          "min_price_cents": {
            "type": "integer",
            "nullable": true,
            "description": "Price in cents (divide by 100 for dollars)"
          },
          "max_price_cents": {
            "type": "integer",
            "nullable": true
          },
          "currency": {
            "type": "string",
            "default": "USD"
          },
          "duration_minutes": {
            "type": "integer",
            "nullable": true
          },
          "image_url": {
            "type": "string",
            "nullable": true
          },
          "provider_id": {
            "type": "integer"
          },
          "provider_name": {
            "type": "string"
          },
          "provider_slug": {
            "type": "string"
          },
          "provider_city": {
            "type": "string",
            "nullable": true
          },
          "provider_country": {
            "type": "string",
            "nullable": true
          },
          "provider_state": {
            "type": "string",
            "nullable": true
          },
          "latitude": {
            "type": "number",
            "nullable": true
          },
          "longitude": {
            "type": "number",
            "nullable": true
          },
          "rating_avg": {
            "type": "number",
            "nullable": true
          },
          "rating_count": {
            "type": "integer",
            "nullable": true
          },
          "start_date": {
            "type": "string",
            "format": "date",
            "nullable": true
          },
          "end_date": {
            "type": "string",
            "format": "date",
            "nullable": true
          },
          "video_url": {
            "type": "string",
            "nullable": true
          }
        }
      },
      "ActivityListResponse": {
        "type": "object",
        "properties": {
          "activities": {
            "type": "array",
            "items": {
              "$ref": "#/components/schemas/Activity"
            }
          },
          "total": {
            "type": "integer"
          },
          "offset": {
            "type": "integer"
          },
          "limit": {
            "type": "integer"
          }
        }
      }
    }
  }
}