{ "business": { "name": "J Ξ P House", "phone": "", "address": "Αρχαγγέλου Μιχαήλ, Iraklio, Greece, 713 05", "latitude": "35.33511334452125", "longitude": "25.124573602383947", "url": "https://gm.datelly.gr", "currency": "EUR" }, "businessHours": [ { "day": "Monday", "open": true, "from": "11:00", "to": "20:00" }, { "day": "Tuesday", "open": true, "from": "10:00", "to": "21:00" }, { "day": "Wednesday", "open": true, "from": "10:00", "to": "21:00" }, { "day": "Thursday", "open": true, "from": "10:00", "to": "21:00" }, { "day": "Friday", "open": true, "from": "10:00", "to": "21:00" }, { "day": "Saturday", "open": true, "from": "10:00", "to": "20:00" }, { "day": "Sunday", "open": false, "from": "18:00", "to": "18:01" } ], "services": [ { "id": 1, "name": "Haircut - trimming", "nameEn": "Haircut - trimming", "category": "J Ξ P Barber", "categoryId": 1, "type": "incall", "price": 10, "durationMin": 35, "description": "" }, { "id": 2, "name": "Shaving - Trimming", "nameEn": "Shaving - Trimming", "category": "J Ξ P Barber", "categoryId": 1, "type": "incall", "price": 0, "durationMin": 15, "description": "" }, { "id": 100013, "name": "Hairstyle", "nameEn": "Hairstyle", "category": "J Ξ P Barber", "categoryId": 1, "type": "incall", "price": 2, "durationMin": 5, "description": "+ product" }, { "id": 100014, "name": "Kids haircut", "nameEn": "Kids haircut", "category": "J Ξ P Barber", "categoryId": 1, "type": "incall", "price": 8, "durationMin": 55, "description": "" }, { "id": 100019, "name": "Παρουσίαση εφαρμογής", "nameEn": "Παρουσίαση εφαρμογής", "category": "Datelly", "categoryId": 2, "type": "incall", "price": 0, "durationMin": 30, "description": "Video call" } ], "categories": [ { "id": 1, "name": "J Ξ P Barber" }, { "id": 2, "name": "Datelly" } ], "workers": [ { "id": 1, "name": "Γιώργος", "nameEn": "Giorgos", "incall": true, "outcall": false } ], "workerSchedules": [], "booking": { "deepLinkFormat": "https://gm.datelly.gr/?services={serviceIds}&worker={workerId}&date={YYYY-MM-DD}&time={HH:MM}&name={customerName}&phone={customerPhone}&email={customerEmail}&autobook=1&autobook_token={token}", "autobook_token": "eyJleHAiOjE3NzU2NDMyMDEsInN1YiI6ImdtIiwibm9uY2UiOiIyY2YxZDI2ZTZlNDQ1OWIzIiwiaWF0IjoxNzc1NjQyMzAxfQ.295eea07f5f04820e3f83cd1baf65328c44773d80896bf63af3db7728c0bbd7e", "autobook_token_expires_in": "15 minutes", "parameters": [ { "name": "services", "required": true, "description": "Comma-separated list of service IDs to book. Use the \"id\" field from the services array.", "example": "1,2,3" }, { "name": "worker", "required": false, "description": "Worker/professional ID. If omitted, the first available worker is auto-selected.", "example": "1" }, { "name": "date", "required": false, "description": "Appointment date in YYYY-MM-DD format. Must be today or a future date when the business is open.", "example": "2026-04-09" }, { "name": "time", "required": false, "description": "Desired start time in HH:MM (24-hour) format. Must match an available slot on the selected date.", "example": "10:00" }, { "name": "name", "required": false, "description": "Customer full name (first and last). Auto-fills the booking form.", "example": "John Doe" }, { "name": "phone", "required": false, "description": "Customer phone number (10 digits, no country code prefix).", "example": "6900000000" }, { "name": "email", "required": false, "description": "Customer email address. Auto-fills the booking form.", "example": "john@example.com" }, { "name": "autobook", "required": false, "description": "Set to \"1\" to automatically accept terms and submit the booking. MUST be paired with a valid autobook_token.", "example": "1" }, { "name": "autobook_token", "required": false, "description": "HMAC-signed security token required for autobook. Get a fresh token from this endpoint (booking.autobook_token). Tokens expire after 15 minutes. Without a valid token, autobook will be ignored and the user must manually confirm.", "example": "<use the autobook_token value from this response>" } ], "notes": [ "If a requested service, worker, date, or time is unavailable, the user is shown a warning and can choose an alternative.", "All parameters except \"services\" are optional. If only services are provided, the user starts at the date/time selection step.", "If date and time are both provided, the system auto-navigates to the booking confirmation step.", "Times use 24-hour format (e.g., 14:30 for 2:30 PM).", "IMPORTANT: To use autobook=1, you MUST first fetch this endpoint to get a fresh autobook_token. The token expires in 15 minutes.", "For AI agents: 1) Fetch this endpoint, 2) Get the autobook_token from the response, 3) Include both autobook=1 and autobook_token={token} in the deep-link URL.", "Rate limiting: Max 5 bookings per IP per hour and 3 per phone per day. Duplicate appointments at the same date/time are rejected.", "A hidden honeypot field protects against simple bots. Legitimate AI agents and users are not affected." ] }
}