Nachdem ein Kunde eine Bestellung eingereicht hat, können Sie den Kunden über Änderungen an der Bestellung informieren, indem Sie eine Aktualisierungsnachricht an Google senden. Google leitet die Nachricht dann an den Kunden weiter.
Häufige Gründe für das Senden von Bestellaktualisierungen:
- Die geschätzte Auftragsausführungszeit für die Bestellung wird verfügbar oder ändert sich.
- Der Status eines Auftrags ändert sich.
- Die Bestellung kann nicht mehr ausgeführt werden.
- Der Preis eines in der Bestellung enthaltenen Menüelements hat sich geändert.
- Der Kunde hat eine neue Möglichkeit, seine Bestellung zu verwalten, z. B. Kundensupport oder Telefonnummer des Restaurants.
- Der Beleg für die Bestellung ist verfügbar.
Im folgenden Beispiel wird der Status der Bestellung eines Kunden von CREATED
zu CONFIRMED
geändert, nachdem das Restaurant die Bestellung bestätigt hat:
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1: Das Restaurant bestätigt die Bestellung | Eine OrderUpdate mit dem Status CONFIRMED wird an Google gesendet. Er muss actionOrderId , userVisibleOrderId , orderManagementActions und estimatedFulfillmentTime enthalten. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "CONFIRMED", "label": "Provider confirmed" }, "receipt": { "userVisibleOrderId": "userVisibleId1234" }, "updateTime": "2017-07-17T12:00:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "2017-07-17T13:00:00Z/2017-07-17T13:30:00Z" } } } }
Die Grundlagen zum Implementieren von Bestellaktualisierungen für Ihr Projekt finden Sie in der Anleitung Asynchrone Aktualisierungen von Bestellungen.
In den nächsten Abschnitten finden Sie Beispiele für komplexere Szenarien bei der Bestellaktualisierung.
Status „Abgelehnt“
Die folgenden Beispiele zeigen eine AsyncOrderUpdateRequestMessage
für Bestellungen, die aus verschiedenen Gründen abgelehnt wurden. Beispiele für Ablehnungsgründe sind, wenn das Restaurant die Bestellung nicht mehr ausführen kann oder wenn die mit der Bestellung verknüpfte Lieferadresse außerhalb des zulässigen Bereichs liegt.
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1: Die Bestellung wurde abgelehnt, weil der Anbieter das Restaurant nicht kontaktieren kann oder das Restaurant die Bestellung nicht ausführen kann. | OrderUpdate mit dem Status REJECTED an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions , rejectionInfo und foodOrderError vom Fehlertyp NO_CAPACITY sein. |
Anwendungsfall 2:Die Bestellung wurde abgelehnt, weil der Fahrer nicht verfügbar ist oder die Lieferadresse außerhalb des zulässigen Bereichs liegt. | OrderUpdate mit dem Status REJECTED an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions , rejectionInfo und foodOrderError vom Fehlertyp OUT_OF_SERVICE_AREA sein. |
Anwendungsfall 3: Die Bestellung wurde abgelehnt, weil das Restaurant unerwartet oder geschlossen ist. | OrderUpdate mit dem Status REJECTED an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions , rejectionInfo und foodOrderError vom Fehlertyp CLOSED sein. |
Anwendungsfall 4: Der Auftrag wurde abgelehnt, weil einige Artikel nicht auf Lager sind. | OrderUpdate mit dem Status REJECTED an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions , rejectionInfo und foodOrderError vom Fehlertyp AVAILABILITY_CHANGED sein. |
Anwendungsfall 5: Der Auftrag wurde aus unbekannten oder nicht kategorisierten Gründen abgelehnt. | OrderUpdate mit dem Status REJECTED an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions und rejectionInfo vom Fehlertyp UNKNOWN sein. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "REJECTED", "label": "Order rejected" }, "updateTime": "2017-05-10T02:30:00.000Z", "rejectionInfo": { "type": "UNKNOWN", "reason": "Sorry, the restaurant cannot take your order right now." }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "foodOrderErrors": [ { "error": "NO_CAPACITY", "description": "Sorry, the restaurant cannot take your order right now." } ] } } } }
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "REJECTED", "label": "Order rejected" }, "updateTime": "2017-05-10T02:30:00.000Z", "rejectionInfo": { "type": "UNKNOWN", "reason": "Sorry, delivery is currently not available to your address." }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "foodOrderErrors": [ { "error": "OUT_OF_SERVICE_AREA", "description": "Sorry, delivery is currently not available to your address." } ] } } } }
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "REJECTED", "label": "Order rejected" }, "updateTime": "2017-05-10T02:30:00.000Z", "rejectionInfo": { "type": "UNKNOWN", "reason": "Sorry, the restaurant is closed unexpectedly." }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "foodOrderErrors": [ { "error": "CLOSED", "description": "Sorry, the restaurant is closed unexpectedly." } ] } } } }
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "REJECTED", "label": "Order rejected" }, "updateTime": "2017-05-10T02:30:00.000Z", "rejectionInfo": { "type": "UNKNOWN", "reason": "Sorry, some of items are not available right now." }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "foodOrderErrors": [ { "error": "AVAILABILITY_CHANGED", "id": "sample_menu_item_id", "description": "Sorry, some of the items are not available right now." } ] } } } }
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "REJECTED", "label": "Order rejected" }, "updateTime": "2017-05-10T02:30:00.000Z", "rejectionInfo": { "type": "UNKNOWN", "reason": "Sorry, your order is rejected." }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ] } } }
Status „Storniert“
Das folgende Beispiel zeigt ein AsyncOrderUpdateRequestMessage
für Bestellungen, die durch eine Kundenanfrage storniert wurden.
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1: Bestellung wird auf Anfrage des Kunden storniert | OrderUpdate mit dem Status CANCELLED an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions und cancellationInfo enthalten. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "CANCELLED", "label": "Order cancelled" }, "updateTime": "2017-05-10T02:30:00.000Z", "cancellationInfo": { "reason": "Customer requested" }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ] } } }
Erfüllter Status
Das folgende Beispiel zeigt ein AsyncOrderUpdateRequestMessage
für Bestellungen, die ausgeführt wurden.
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1:Bestellung wird ausgeführt | OrderUpdate mit dem Status FULFILLED an Google senden. Er muss actionOrderId , userVisibleOrderId und orderManagementActions enthalten. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "FULFILLED", "label": "Order delivered" }, "updateTime": "2017-05-10T02:30:00.000Z", "fulfillmentInfo": { "deliveryTime": "2017-05-10T02:30:00.000Z" }, "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ] } } }
Status der Übertragung
Das folgende Beispiel zeigt einen AsyncOrderUpdateRequestMessage
für Lieferaufträge, die an den Kunden gesendet werden.
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1: Lieferung ist unterwegs. | OrderUpdate mit dem Status IN_TRANSIT an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions und estimatedFulfillmentTime enthalten. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "IN_TRANSIT", "label": "Order is on the way" }, "inTransitInfo": { "updatedTime": "2017-07-17T12:00:00Z" }, "updateTime": "2017-07-17T12:00:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "PT20M" } } } }
Abholbereit
Das folgende Beispiel zeigt einen AsyncOrderUpdateRequestMessage
für Bestellungen, die vom Kunden abgeholt werden können.
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1: Die Bestellung kann abgeholt werden. | OrderUpdate mit dem Status READY_FOR_PICKUP an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions und estimatedFulfillmentTime enthalten. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "READY_FOR_PICKUP", "label": "Order is ready for pickup" }, "updateTime": "2018-04-15T12:00:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "PT20M" } } } }
Status der Zubereitung
Das folgende Beispiel zeigt einen AsyncOrderUpdateRequestMessage
für Bestellungen, die vom Restaurant zubereitet werden.
Anwendungsfall | Implementierung |
---|---|
Anwendungsfall 1:Die Bestellung wird vom Restaurant vorbereitet. | OrderUpdate mit dem Status IN_PREPARATION an Google senden. Er muss actionOrderId , userVisibleOrderId , orderManagementActions und estimatedFulfillmentTime enthalten. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "IN_PREPARATION", "label": "Order is being prepared" }, "updateTime": "2018-04-15T11:30:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "PT20M" } } } }
Bestelländerungsstatus
Die folgenden Beispiele zeigen eine AsyncOrderUpdateRequestMessage
für verschiedene Änderungen an der Bestellung eines Kunden.
Anwendungsfall 1: Die geschätzte Dauer für die Auftragsausführung muss aktualisiert werden. | Sende eine OrderUpdate mit dem Bestellstatus, actionOrderId , userVisibleOrderId , orderManagementAction und dem aktualisierten estimatedFulfillmentTime an Google. |
Anwendungsfall 2: Der Gesamtpreis der Bestellung muss aktualisiert werden. | Sende eine OrderUpdate mit dem Bestellstatus, actionOrderId , userVisibleOrderId , orderManagementAction , estimatedFulfillmentTime und dem aktualisierten totalPrice an Google. |
Anwendungsfall 3: Aktionen der Bestellverwaltung des Auftrags müssen aktualisiert werden. | Sende eine OrderUpdate mit dem Bestellstatus, actionOrderId , userVisibleOrderId , estimatedFulfillmentTime und dem aktualisierten orderManagementActions an Google. |
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "CONFIRMED", "label": "Provider confirmed" }, "receipt": { "userVisibleOrderId": "userVisibleId1234" }, "updateTime": "2017-07-17T12:00:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "2017-07-17T13:00:00Z/2017-07-17T13:30:00Z" } } } }
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "CONFIRMED", "label": "Provider confirmed" }, "receipt": { "userVisibleOrderId": "userVisibleId1234" }, "totalPrice": { "type": "ESTIMATE", "amount": { "currencyCode": "USD", "units": "20", "nanos": 500000000 } }, "updateTime": "2017-07-17T12:00:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "2017-07-17T13:00:00Z/2017-07-17T13:30:00Z" } } } }
JSON
{ "isInSandbox": true, "customPushMessage": { "orderUpdate": { "actionOrderId": "sample_action_order_id", "orderState": { "state": "CONFIRMED", "label": "Provider confirmed" }, "receipt": { "userVisibleOrderId": "userVisibleId1234" }, "updateTime": "2017-07-17T12:00:00Z", "orderManagementActions": [ { "type": "CUSTOMER_SERVICE", "button": { "title": "Contact customer service", "openUrlAction": { "url": "mailto:support@example.com" } } }, { "type": "EMAIL", "button": { "title": "Email restaurant", "openUrlAction": { "url": "mailto:person@example.com" } } }, { "type": "CALL_RESTAURANT", "button": { "title": "Call restaurant", "openUrlAction": { "url": "tel:+16505554679" } } }, { "type": "CALL_DRIVER", "button": { "title": "Call driver", "openUrlAction": { "url": "tel:+16505554681" } } } ], "infoExtension": { "@type": "type.googleapis.com/google.actions.v2.orders.FoodOrderUpdateExtension", "estimatedFulfillmentTimeIso8601": "2017-07-17T13:00:00Z/2017-07-17T13:30:00Z" } } } }