การจองแบบซิงโครนัสคือการจองที่ได้รับการยืนยันหรือถูกปฏิเสธ แบบเรียลไทม์
การจองแบบอะซิงโครนัสหมายถึงการจองที่ผู้ขายยืนยันหรือปฏิเสธในภายหลัง
การจองจะระบุเป็นแบบเรียลไทม์หรือไม่เรียลไทม์ที่ระดับความพร้อม นอกจากนี้ยังหมายความว่าสำหรับผู้ขายและบริการหนึ่งๆ อาจมีช่วงเวลาที่พร้อมให้บริการทั้งแบบเรียลไทม์และแบบไม่เรียลไทม์
หากต้องการพิจารณาการติดตั้งใช้งานที่เหมาะสม ให้ระบุหมวดหมู่ที่พื้นที่โฆษณาของคุณอยู่ก่อน
- การเปิดใช้การจองแบบซิงโครนัสเท่านั้น ผู้ขายและบริการทั้งหมดจะได้รับการยืนยันทันที
- การเปิดใช้การจองแบบอะซิงโครนัส ผู้ขายและบริการบางรายหรือทั้งหมดกำหนดให้ผู้ขายต้องยืนยันด้วยตนเอง
เกณฑ์การจองแบบอะซิงโครนัส
- ไม่รองรับการแก้ไขการจองแบบไม่พร้อมกันในศูนย์การดำเนินการ
- ผู้ขายควรยอมรับหรือปฏิเสธการจองผ่านระบบออนไลน์ของพาร์ทเนอร์ (เช่น แผงควบคุมโฮสต์สำหรับร้านอาหาร) ได้ ไม่อนุญาตให้โทรหาร้านค้าในนามของผู้ใช้เพื่อตรวจสอบว่าร้านค้ารับหรือ ปฏิเสธการจอง
- ระบบไม่รองรับข้อเสนอของผู้ขายเกี่ยวกับเวลาการจองใหม่ ต้องยอมรับหรือปฏิเสธคำขอจองในสถานะเดิม
เปิดใช้การจองพร้อมกันเท่านั้น
การติดตั้งใช้งานมาตรฐานจะใช้การจองแบบซิงโครนัสโดยค่าเริ่มต้น โปรดดูข้อมูลเพิ่มเติมในเอกสารประกอบการผสานรวมการจองแบบครบวงจร
การเปิดใช้การจองแบบไม่พร้อมกัน
หากผู้ขายบางรายหรือทั้งหมดใช้ขั้นตอนการจองแบบไม่พร้อมกัน คุณจะต้องทำการเปลี่ยนแปลงต่อไปนี้
-
โหมดการยืนยัน: การแสดงช่วงเวลาที่พร้อมให้บริการทั้งหมดจะมีฟิลด์
confirmation_modeซึ่งอธิบายวิธี การยืนยันการจองช่วงเวลาที่พร้อมให้บริการนั้น ระบุconfirmation_modeของช่วงเวลาที่ว่างแต่ละช่วงสำหรับ รายการต่อไปนี้- ในฟีดความพร้อมจำหน่ายสินค้า
confirmation_modeจะระบุที่ ระดับความพร้อมจำหน่ายสินค้า - ในเมธอด Booking Server API จะมีการระบุ
confirmation_modeที่ ระดับช่วงเวลา - ในเมธอด API การอัปเดตแบบเรียลไทม์
confirmation_modeจะระบุ ที่ระดับความพร้อมจำหน่ายสินค้า
- ในฟีดความพร้อมจำหน่ายสินค้า
- สถานะการจอง: การแสดงการจองทั้งหมดจะมีฟิลด์
statusที่แสดงสถานะของการจอง เราได้เพิ่มค่าสถานะแบบอะซิงโครนัสใหม่ 3 ค่า ได้แก่PENDING_CONFIRMATIONDECLINED_BY_MERCHANTและFAILEDใช้ค่าสถานะใหม่เหล่านี้เมื่อ ประมวลผลการสร้าง การปฏิเสธ และความล้มเหลวของการจองแบบไม่พร้อมกัน - การอัปเดตการจอง: การอัปเดตสถานะการจองแบบไม่พร้อมกันทั้งหมดควรรายงานผ่านเมธอด bookings.patch ของ Booking Notification API
แผนภาพด้านล่างแสดงวิธีใช้โหมดการยืนยันและสถานะการจอง ในการโต้ตอบการจองแบบอะซิงโครนัสทั่วไป
- เราได้อัปเดตฟีดความพร้อมจำหน่ายสินค้าเพื่อให้ระบุโหมดการยืนยันของช่วงเวลาที่พร้อมให้บริการแต่ละช่วงได้ การมีข้อมูลนี้ในฟีดเป็นสิ่งสำคัญ เพื่อให้เราอธิบายลักษณะการจองแบบอะซิงโครนัสให้ผู้ใช้ทราบ ตั้งแต่เนิ่นๆ ในขั้นตอนการจอง
- เมื่อมีการเรียกใช้
BatchAvailabilityLookupหรือCheckAvailabilityเราจะส่งต่อโหมดการยืนยันและโหมดการยืนยันเดียวกันเพื่อ ส่งคืน ซึ่งจะช่วยให้ผู้ใช้เห็นข้อความที่เหมาะสม - เมื่อมีการเรียกใช้
CreateBookingเราจะส่งต่อโหมดการยืนยันไปยัง เพื่อระบุโหมดการยืนยันที่คาดไว้ เมื่อส่งคำขอการจองแบบไม่พร้อมกัน ระบบจะแสดงผลการจองพร้อมสถานะPENDING_MERCHANT_CONFIRMATION - เมื่อผู้ขายยอมรับหรือปฏิเสธคำขอจอง ระบบจะอัปเดตสถานะการจองผ่าน API การแจ้งเตือนการจองแบบเรียลไทม์ ด้วยเมธอด bookings.patch หากต้องการปฏิเสธการจองโดยอัตโนมัติเมื่อไม่ได้รับ การตอบกลับอย่างทันท่วงที ให้ดำเนินการผ่านวิธีการอัปเดตแบบเรียลไทม์ เดียวกัน
ฟีดความพร้อมจำหน่ายสินค้า
ในฟีดความพร้อม ให้ระบุว่าแต่ละช่วงเวลาเป็นแบบซิงโครนัสหรือ
แบบอะซิงโครนัส โดยให้ตั้งค่าฟิลด์ confirmation_mode
ใหม่
// Mode by which bookings for an availability slot are confirmed. enum ConfirmationMode { // The confirmation mode was not specified. // Synchronous confirmation will be assumed. CONFIRMATION_MODE_UNSPECIFIED = 0; // Bookings for this availability will be confirmed synchronously. CONFIRMATION_MODE_SYNCHRONOUS = 1; // Bookings for this availability will be confirmed asynchronously. CONFIRMATION_MODE_ASYNCHRONOUS = 2; }
แม้ว่าระบบจะถือว่าโหมดการยืนยันเป็นแบบซิงโครนัสหากไม่ได้ระบุโหมดไว้ แต่เราขอแนะนำให้ระบุโหมดอย่างชัดเจนเพื่อป้องกันความสับสนเกี่ยวกับการละเว้นโดยไม่ตั้งใจ
Async
{
"availability": [
{
"merchant_id": "10001",
"service_id": "1000",
"spots_open": 3,
"spots_total": 3,
"duration_sec": 3600,
"start_sec": 1535806800,
"resources": {
"party_size": 4
},
"confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS"
}
]
}ซิงค์
{
"availability": [
{
"merchant_id": "10001",
"service_id": "1000",
"spots_open": 3,
"spots_total": 3,
"duration_sec": 3600,
"start_sec": 1535806800,
"resources": {
"party_size": 4
},
"confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS"
}
]
}ไม่พร้อมกันและพร้อมกัน
{
"availability": [
{
"merchant_id": "10001",
"service_id": "1000",
"spots_open": 3,
"spots_total": 3,
"duration_sec": 3600,
"start_sec": 1535806800,
"resources": {
"party_size": 4
},
"confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS"
},
{
"merchant_id": "10002",
"service_id": "1000",
"spots_open": 4,
"spots_total": 4,
"duration_sec": 3600,
"start_sec": 1535806800,
"resources": {
"party_size": 2
},
"confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS"
}
]
}เซิร์ฟเวอร์การจอง
BatchAvailabilityLookup หรือ CheckAvailability
ในBatchAvailabilityLookupResponse (BAL)
หรือ
CheckAvailabilityResponse (CA) ให้ส่งคืน confirmation_mode เดียวกันกับที่ระบุไว้ใน
ฟีดความพร้อมจำหน่ายสินค้าและส่งผ่านทาง
BatchAvailabilityLookupRequest
หรือ
CheckAvailabilityRequest
BAL-Async
{
"slot_time_availability": [
{
"slot_time": {
"duration_sec": "3600",
"resource_ids": {
"party_size": 3
},
"service_id": "1000",
"start_sec": "1546458300",
"confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS"
},
"available": true
}
]
}BAL-Sync
{
"slot_time_availability": [
{
"slot_time": {
"duration_sec": "3600",
"resource_ids": {
"party_size": 3
},
"service_id": "1000",
"start_sec": "1546458300",
"confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS"
},
"available": true
}
]
}CA-Async
{
"slot": {
"duration_sec": "3600",
"merchant_id": "317652",
"resources": {
"party_size": 3
},
"service_id": "1000",
"start_sec": "1546458300",
"confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS"
},
"count_available": 1,
"duration_requirement": "DO_NOT_SHOW_DURATION"
}CA-Sync
{
"slot": {
"duration_sec": "3600",
"merchant_id": "317652",
"resources": {
"party_size": 3
},
"service_id": "1000",
"start_sec": "1546458300",
"confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS"
},
"count_available": 1,
"duration_requirement": "DO_NOT_SHOW_DURATION"
}CreateBooking
โปรดตรวจสอบว่าได้ส่งคืนสถานะที่ถูกต้องสำหรับการจองโดยใช้ตัวเลือกที่มีอยู่ ด้านล่าง
// Status of a booking. // // Updating booking status does not change the status of the associated payment. // Prepayment status updates should be done using the PrepaymentStatus enum. enum BookingStatus { // Not specified. BOOKING_STATUS_UNSPECIFIED = 0; // Booking has been confirmed CONFIRMED = 1; // Booking is awaiting confirmation by the merchant before it can transition // into CONFIRMED status. Only applicable to non-payments Dining or // Beauty verticals. PENDING_MERCHANT_CONFIRMATION = 2; // Booking has been canceled on behalf of the user. // The merchant can still trigger a manual refund. CANCELED = 3; // User did not show for the appointment NO_SHOW = 4; // User did not show for the appointment in violation of the cancellation // policy. NO_SHOW_PENALIZED = 5; // Booking could not be completed by the async backend due to a failure. FAILED = 6; // Booking was asynchronously declined by the merchant. Only applicable to // non-payments Dining or Beauty verticals. DECLINED_BY_MERCHANT = 7; }
ใน CreateBookingResponse
ให้แสดง confirmation_mode ปัจจุบันสำหรับช่วงเวลาที่รวบรวมของการจองที่ระบุ
ใน CreateBookingRequest นอกจากนี้ เมื่อการจองเป็นแบบไม่พร้อมกัน ให้ตั้งค่า status เป็น PENDING_MERCHANT_CONFIRMATION โปรดตรวจสอบว่า confirmation_mode ตรงกับที่ผู้ใช้และ Reserve with
Google คาดหวังเพื่อไม่ให้ผู้ใช้สับสน
Async
{ "booking": { "slot": { "duration_sec": "3600", "merchant_id": "100001", "resources": { "party_size": 2 }, "service_id": "1000", "start_sec": "1546647234", "confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS" }, "user_information": { "email": "johnsmith@gmail.com", "family_name": "John", "given_name": "Smith", "telephone": "+1 800-123-4567", "user_id": "2017492857928759285" }, "payment_information": { "prepayment_status": "PREPAYMENT_NOT_PROVIDED" }, "status": "PENDING_MERCHANT_CONFIRMATION" } }
ซิงค์
{ "booking": { "slot": { "duration_sec": "3600", "merchant_id": "100001", "resources": { "party_size": 2 }, "service_id": "1000", "start_sec": "1546647234", "confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS" }, "user_information": { "email": "johnsmith@gmail.com", "family_name": "John", "given_name": "Smith", "telephone": "+1 800-123-4567", "user_id": "2017492857928759285" }, "payment_information": { "prepayment_status": "PREPAYMENT_NOT_PROVIDED" }, "status": "CONFIRMED" } }
UpdateBooking
ในการเปิดตัวแบบไม่พร้อมกันครั้งแรก ระบบจะไม่รองรับการแก้ไขการจองที่มีอยู่โดยผู้ใช้ แต่ผู้ใช้ควรยกเลิกการจองและสร้างการจองใหม่แทน
ข้อมูลอัปเดตแบบเรียลไทม์
หากต้องการอัปเดตความพร้อมแบบเรียลไทม์ ให้ระบุ confirmation_mode
โดยมีผลกับวิธีการต่อไปนี้
RTU ของพื้นที่โฆษณา (ReplaceServiceAvailability หรือ BatchReplaceServiceAvailability)
เมื่อใช้availability.replace (กลุ่ม)
หรือservices.availability.replace
ให้ตั้งค่า confirmation_mode เป็น CONFIRMATION_MODE_ASYNCHRONOUS ใน Availability
Async
{
"extendedServiceAvailability": [
{
"merchantId": "1001",
"serviceId": "12310",
"startTimeRestrict": "2014-10-02T15:01:23.045123456Z",
"endTimeRestrict": "2014-10-02T19:01:23.045123456Z",
"availability": [
{
"startTime": "2014-10-02T15:30:00.00Z",
"duration": "3600s",
"spotsOpen": "0",
"spotsTotal": "2",
"availabilityTag": "1000001",
"confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS"
}
]
}
]
}ซิงค์
{
"extendedServiceAvailability": [
{
"merchantId": "1001",
"serviceId": "12310",
"startTimeRestrict": "2014-10-02T15:01:23.045123456Z",
"endTimeRestrict": "2014-10-02T19:01:23.045123456Z",
"availability": [
{
"startTime": "2014-10-02T15:30:00.00Z",
"duration": "3600s",
"spotsOpen": "0",
"spotsTotal": "2",
"availabilityTag": "1000001",
"confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS"
}
]
}
]
}ไม่พร้อมกันและพร้อมกัน
{
"extendedServiceAvailability": [
{
"merchantId": "1001",
"serviceId": "12310",
"startTimeRestrict": "2014-10-02T15:01:23.045123456Z",
"endTimeRestrict": "2014-10-02T19:01:23.045123456Z",
"availability": [
{
"startTime": "2014-10-02T15:30:00.00Z",
"duration": "3600s",
"spotsOpen": "0",
"spotsTotal": "2",
"availabilityTag": "1000001",
"confirmation_mode": "CONFIRMATION_MODE_ASYNCHRONOUS"
},
{
"startTime": "2014-10-03T11:00:00.00Z",
"duration": "5400s",
"spotsOpen": "1",
"spotsTotal": "1",
"availabilityTag": "1000002",
"confirmation_mode": "CONFIRMATION_MODE_SYNCHRONOUS"
}
]
}
]
}Booking Notification API
การอัปเดตสถานะการจองแบบไม่พร้อมกันควรทำผ่านเมธอด Booking Notification API bookings.patch
เมื่ออัปเดตสถานะ อย่าลืมใส่ชื่อฟิลด์ status ใน
updateMask
| สถานะ | คำอธิบาย |
|---|---|
| ยืนยันแล้ว | ผู้ขายยืนยันการจองแล้ว |
| ล้มเหลว | พาร์ทเนอร์ยืนยันหรือปฏิเสธการจองกับผู้ขายไม่ได้ |
| DECLINED_BY_MERCHANT | ผู้ขายปฏิเสธการจอง |
Request: PATCH https://mapsbooking.googleapis.com/v1alpha/notification/partners/<PARTNER_ID>/bookings/<BOOKING_ID>?updateMask=status Body: {"name":"partners/<PARTNER_ID>/bookings/<BOOKING_ID>", "status":"DECLINED_BY_MERCHANT"}
ในกรณีที่การจองไม่สำเร็จ ให้ตั้งค่าสถานะการจองเป็น FAILED และ
ระบุ booking_failure หากตั้งค่าสถานะเป็นอย่างอื่น ระบบจะไม่สนใจ booking_failure
Request: PATCH https://mapsbooking.googleapis.com/v1alpha/notification/partners/<PARTNER_ID>/bookings/<BOOKING_ID>?updateMask=status&booking_failure.cause="SLOT_UNAVAILABLE" Body: {"name":"partners/<PARTNER_ID>/bookings/<BOOKING_ID>", "status":"FAILED"}
การแจ้งเตือนทางอีเมล
สำหรับการจองแบบไม่พร้อมกัน จะมีอีเมล 5 ฉบับที่อาจเกี่ยวข้องกับ สถานะของการจองซึ่งจะส่งถึงผู้ใช้
PENDING_MERCHANT_CONFIRMATIONCONFIRMEDDECLINED_BY_MERCHANTFAILEDCANCELED