비동기식 예약 추가하기

<ph type="x-smartling-placeholder">

동기식 예약은 확인되거나 거부된 예약으로 정의됩니다. 있습니다.

비동기식 예약은 판매자가 확인하거나 나중에 거부될 수 있습니다

예약은 가용성 수준입니다 이는 또한 특정 판매자나 서비스에 대해 동기 및 비동기 가용성 슬롯이 둘 다 있을 수 있습니다

적절한 구현을 결정하려면 먼저 인벤토리 유형:

비동기식 예약 기준

  • Actions Center에서 비동기 예약을 수정하는 것은 아닙니다. 지원됩니다.
  • 판매자는 파트너의 온라인 시스템 (예: 식당의 호스트 패널) 호출 판매자를 대리하여 해당 판매자가 수락하거나 예약을 거부하는 것은 허용되지 않습니다.
  • 판매자가 새 예약 시간을 제안할 수 없습니다. 이 예약 요청은 원래 상태에서 수락 또는 거부되어야 합니다.

동기식 예약만 사용 설정

표준 구현은 동기식 예약으로 기본 설정됩니다. 자세한 내용은 약속 엔드 투 엔드 통합 문서를 참고하세요.

비동기 예약 사용 설정

일부 또는 모든 판매자가 비동기식 예약 절차를 사용하는 경우 다음과 같이 변경해야 합니다.

  • 확인 모드: 이제 모든 이용 가능 시간대 표현 예약 방식을 설명하는 confirmation_mode 필드가 포함됩니다. 확인할 수 있습니다 각 이용 가능 시간대의 confirmation_mode 있습니다.

    • 이용 가능 여부 피드에서 confirmation_mode는 가용성 수준
    • Booking Server API 메서드에서 confirmation_mode은 슬롯 수준
    • Real-Time Updates API 메서드에서 confirmation_mode가 지정됩니다. 가용성 수준에서
  • 예약 상태: 예약의 모든 표현에는 예약 상태를 나타내는 status 필드입니다. 3개 새로운 비동기 상태 값(PENDING_CONFIRMATION)이 도입되었습니다. DECLINED_BY_MERCHANT, FAILED 다음과 같은 경우 이 새 상태 값을 사용합니다. 비동기식 예약 생성, 거부, 실패 처리
  • 예약 업데이트: 예약 상태에 대한 모든 비동기식 업데이트는 예약은 Booking Notification API의 bookings.patch 메서드로 전달하세요.

아래 다이어그램은 확인 모드와 예약 상태가 사용되는 방식을 보여줍니다. 일반적인 비동기식 예약 상호작용에서 이를 처리할 수 있습니다

<ph type="x-smartling-placeholder">
</ph> 그림 1: 비동기 예약 흐름
그림 1: 비동기식 예약 흐름
  1. 이용 가능 여부 피드가 업데이트되어 각 이용 가능 시간대의 지정할 수 있습니다. 이 정보를 예약의 비동기식 특성을 초기 단계에 사용자에게 제공할 수 있습니다
  2. 날짜 BatchAvailabilityLookup 드림 또는 CheckAvailability 호출되면 확인 모드가 전달되며 이상적으로 동일한 확인 모드가 반환합니다. 이렇게 하면 사용자에게 적절한 메시지가 표시됩니다.
  3. 날짜 CreateBooking 드림 호출되면 확인 모드를 전달하여 예상되는 확인 모드를 나타냅니다. 비동기식 예약이 요청이 제출되면 예약이 상태와 함께 반환됩니다. PENDING_MERCHANT_CONFIRMATION
  4. 판매자가 예약 요청을 수락하거나 거부하면 예약은 상태는 실시간 업데이트 Booking Notification API의 bookings.patch 메서드로 전달하세요. 다음 경우에 해당하지 않는 예약을 자동으로 거부하려는 경우 응답해야 하므로 동일한 실시간 업데이트를 통해 메서드를 사용하여 축소하도록 요청합니다.

이용 가능 여부 피드

이용 가능 여부 피드에서 각 시간대가 동기식인지 또는 비동기식으로 진행됩니다. 이렇게 하려면 새 confirmation_mode를 설정합니다. 필드를 확인합니다.

<ph type="x-smartling-placeholder">
// 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;
}

어떤 모드도 동기식인 것으로 가정하지만 명시적으로 모드를 지정하는 것이 좋습니다. 실수로 인한 누락에 대한 혼란을 없앱니다.

비동기식

{
  "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"
    }
  ]
}

Sync

{
  "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"
    }
  ]
}

Async 및 Sync

{
  "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에서) 또한 예약이 비동기식인 경우 statusPENDING_MERCHANT_CONFIRMATION로 설정합니다. 다음을 확인하세요. confirmation_mode는 사용자와 예약이 Google은 사용자에게 혼란을 주지 않기를 바랍니다.

비동기식

{
  "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"
  }
}

Sync

{
  "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

async의 초기 출시에서 사용자가 기존 예약을 수정함 지원되지 않습니다. 대신 사용자가 예약을 취소하고 새 예약

실시간 업데이트

이용 가능 여부 실시간 업데이트는 confirmation_mode에서 확인하세요. 지정해야 합니다. 이는 다음 메서드에 적용됩니다.

인벤토리 RTU (ReplaceServiceAvailability 또는 BatchReplaceServiceAvailability)

사용 availability.replace (일괄) 메서드 또는 services.availability.replace 메서드, Availability에서 confirmation_modeCONFIRMATION_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_ASYNCHRONOUS"
        }
      ]
    }
  ]
}

Sync

{
  "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"
        }
      ]
    }
  ]
}

Async 및 Sync

{
  "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

예약 상태는 예약을 통해 비동기식으로 업데이트되어야 합니다. Notification API bookings.patch 메서드를 사용합니다.

상태를 업데이트할 때 status 필드 이름을 포함해야 합니다. updateMask입니다.

상태 설명
CONFIRMED 판매자가 예약을 확인함
FAILED 파트너가 판매자와 예약을 확인하거나 거부할 수 없음
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는 무시됩니다.

<ph type="x-smartling-placeholder">
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"}

이메일 알림

비동기식 예약의 경우 사용자에게 전송된 예약의 상태입니다.

<ph type="x-smartling-placeholder"> <ph type="x-smartling-placeholder">
    </ph>
  • PENDING_MERCHANT_CONFIRMATION
  • CONFIRMED
  • DECLINED_BY_MERCHANT
  • FAILED
  • CANCELED