GET
/api/public/v1/appointments

List appointments

List appointments for a business with optional date-range and status filters.

Query Parameters

NameTypeRequiredDescription
businessIdstring
Required
Business to query.
limitnumberOptionalMaximum number of items to return (1-100).Default: 20
offsetnumberOptionalNumber of items to skip before starting to collect the result set.Default: 0
sortBystringOptionalField to sort by. Allowed values vary by endpoint.Default: createdAt
sortOrderstring
asc
desc
OptionalSort direction.Default: desc
searchstringOptionalFree-text search across the resource’s primary fields.
createdAfterstringOptionalISO 8601 timestamp — only return items created after this time.
createdBeforestringOptionalISO 8601 timestamp — only return items created before this time.
updatedAfterstringOptionalISO 8601 timestamp — only return items updated after this time.
statusstring
PENDING
CONFIRMED
COMPLETED
CANCELLED
NO_SHOW
OptionalFilter by status.
employeeIdstringOptionalFilter to a specific employee.
scheduledFromstringOptionalISO 8601 date — earliest scheduled date.
scheduledTostringOptionalISO 8601 date — latest scheduled date.
GETExample request
curl
curl -X GET "https://www.pxb.app/api/public/v1/appointments" \
  -H "X-Organization-Id: your_org_id" \
  -H "X-API-Key: your_api_key"
200Example response
json
{
  "message": "Appointments retrieved successfully!",
  "content": {
    "appointments": [
      {
        "id": "appt_1",
        "scheduledDate": "2026-06-01T00:00:00Z",
        "startTime": "09:00",
        "endTime": "10:00",
        "status": "CONFIRMED",
        "customerName": "John Doe"
      }
    ],
    "pagination": {
      "total": 42,
      "limit": 20,
      "offset": 0,
      "hasMore": true
    }
  }
}