In diesem Dokument wird beschrieben, wie Sie eine Fahrt aktualisieren und ihren Status verwalten. Dazu wird eine Feldmaske verwendet, um relevante Felder für eine Fahrt festzulegen. Es wird davon ausgegangen, dass Sie Fleet Engine wie auf dieser Website beschrieben eingerichtet haben und mit einem Fahrzeug arbeiten, das einer Fahrt zugewiesen ist.
Grundlagen zu Updates zu Fahrten
Ihr System verwendet die Fleet Engine, um Fahrten in den folgenden Fällen zu aktualisieren:
- Wenn Sie einem Fahrtenauftrag nach der Erstellung ein Fahrzeug zuweisen.
- Wenn sich der Status der Fahrt ändert, z. B. wenn das Fahrzeug Wegpunkte passiert.
- Wenn Sie Fahrtfelder aktualisieren, z. B. die Anzahl der Fahrgäste und den Abholpunkt.
Wenn Sie eine Fahrt aktualisieren möchten, senden Sie eine Anfrage mit gRPC oder REST.
Verwenden Sie die entsprechenden Anmeldedaten für das Dienstkonto Ihres Projekts, wie unter Fleet Engine: Rollen für Dienstkonten beschrieben.
Reisefelder aktualisieren
Sie können alle unter Fahrtfelder beschriebenen Fahrtfelder unter Fahrt mit einem Ziel erstellen aktualisieren. Wenn Sie beispielsweise eine Fahrt erstellt haben, suchen Sie zuerst ein Fahrzeug und aktualisieren dann das Feld „Fahrt“ vehicle_id
, um es mit dem Fahrzeug zu verknüpfen, das die Fahrt ausführen wird.
Feldmasken verwenden
Mithilfe von Feldmasken können API-Caller die Felder auflisten, die in einer Anfrage abgerufen oder aktualisiert werden sollen. Mit einer FieldMask lassen sich unnötige Arbeitsschritte vermeiden und die Leistung verbessern. In der Fleet Engine werden Feldmasken verwendet, um Felder in allen Ressourcen zu aktualisieren.
Aktualisieren Sie die Fahrt mit der Fahrzeug-ID.
Sie müssen eine Fahrt mit einer Fahrzeug-ID konfigurieren, damit die Fleet Engine das Fahrzeug auf seiner Route verfolgen kann. Das folgende Codebeispiel zeigt, wie die Fahrt mit einer Fahrzeug-ID aktualisiert wird.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "trip-8241890";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to update.
Trip trip = Trip.newBuilder()
.setVehicleId("8241890")
.build();
// The trip update request.
UpdateTripRequest updateTripRequest =
UpdateTripRequest.newBuilder() // No need for the header.
.setName(tripName)
.setTrip(trip)
.setUpdateMask(FieldMask.newBuilder().addPaths("vehicle_id"))
.build();
// Error handling.
// If the Fleet Engine has both a trip and vehicle with IDs, and if the
// credentials validate, then the service updates the trip.
try {
Trip updatedTrip = tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // Neither the trip nor vehicle exist.
break;
case PERMISSION_DENIED:
break;
}
return;
}
Fahrtstatus für Fahrten verwalten
Der Status einer Fahrt wird mit einem der TripStatus
-Aufzählungswerte angegeben. Wenn sich der Status einer Fahrt ändert, z. B. von ENROUTE_TO_PICKUP
in ARRIVED_AT_PICKUP
, aktualisieren Sie den Fahrtstatus in der Fleet Engine. Der Lebenszyklus einer Fahrt beginnt immer mit dem Statuswert NEW
und endet mit dem Wert COMPLETE
oder CANCELED
.
Beispiel für eine Fahrtaktualisierung
Im Folgenden wird gezeigt, wie Sie den Fahrtstatus für eine Fahrt nacheinander in der Fleet Engine aktualisieren.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "trip-8241890";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// Trip settings to be updated.
Trip trip = Trip.newBuilder()
.setTripStatus(TripStatus.ARRIVED_AT_PICKUP)
.build();
// Trip update request
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(FieldMask.newBuilder().addPaths("trip_status"))
.build();
// Error handling.
try {
Trip updatedTrip = tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case FAILED_PRECONDITION: // The given trip status is invalid.
break;
case PERMISSION_DENIED:
break;
}
return;
}
Weitere Beispiele zum Aktualisieren von Fahrten finden Sie im Abschnitt Weitere Fahrttypen.
Fahrtfehler behandeln
Wenn Sie vorhandene Fahrten aktualisieren oder suchen, kann der Fehler DEADLINE_EXCEEDED
auftreten. In diesem Fall ist der Status der Fleet Engine nicht bekannt.
Rufen Sie CreateTrip
zuerst noch einmal mit derselben Fahrt-ID auf, die Sie aktualisieren oder beobachten möchten. Es sollte entweder 201 (CREATED) oder 409 (CONFLICT) zurückgegeben werden. Im letzteren Fall war die vorherige Anfrage vor DEADLINE_EXCEEDED
erfolgreich.
Liste der Netzwerkfehler im Consumer SDK, entweder für Android oder iOS