W tym dokumencie opisujemy, jak utworzyć pojazd ze środowiska serwera za pomocą gRPC lub REST. Możesz utworzyć pojazd za pomocą pakietu Driver SDK, pod warunkiem że udostępniasz aplikację jako zaufane środowisko przy użyciu odpowiednich dane logowania.
Aby dowiedzieć się, jak używać pakietu Driver SDK do tworzenia pojazdów, przeczytaj te artykuły:
- Pakiet SDK sterowników do zaplanowanych zadań
- Role konta usługi w sekcji Podstawy Fleet Engine.
Aby utworzyć nowy pojazd ze środowiska serwera, utwórz
CreateDeliveryVehicle
prośba do Fleet Engine. Użyj obiektu CreateDeliveryVehicleRequest
, aby zdefiniować atrybuty nowego pojazdu dostawczego.
Pola dotyczące pojazdów w planowanych zadaniach
Podczas tworzenia obiektu DeliveryVehicle
ustawiasz te pola opcjonalne:
attributes
last_location
type
Aby utworzyć pojazd bez ustawiania pól opcjonalnych, możesz pozostawić pole DeliveryVehicle
niezaznaczone w sekcji CreateDeliveryVehicleRequest
.
Przykład tworzenia pojazdu
Do utworzenia pojazdu lub REST możesz użyć biblioteki Java gRPC.
Java
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String VEHICLE_ID = "vehicle-8241890"; // Avoid auto-incrementing IDs.
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Vehicle settings
String parent = "providers/" + PROJECT_ID;
DeliveryVehicle vehicle = DeliveryVehicle.newBuilder()
.addAttributes(DeliveryVehicleAttribute.newBuilder()
.setKey("route_number").setValue("1")) // Opaque to the Fleet Engine
.build();
// Vehicle request
CreateDeliveryVehicleRequest createVehicleRequest =
CreateDeliveryVehicleRequest.newBuilder() // No need for the header
.setParent(parent)
.setDeliveryVehicleId(VEHICLE_ID) // Vehicle ID assigned by the Provider
.setDeliveryVehicle(vehicle)
.build();
// Error handling
// If Fleet Engine does not have vehicle with that ID and the credentials of the
// requestor pass, the service creates the vehicle successfully.
try {
DeliveryVehicle createdVehicle =
deliveryService.createDeliveryVehicle(createVehicleRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case ALREADY_EXISTS:
break;
case PERMISSION_DENIED:
break;
}
return;
}
REST
Aby utworzyć pojazd w środowisku serwera, wywołaj interfejs HTTP REST, korzystając z adresu CreateDeliveryVehicle
:
POST https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles?deliveryVehicleId=<id>
Treść POST reprezentuje encję DeliveryVehicle
, która ma zostać utworzona. Możesz podać te pola opcjonalne:
attributes
lastLocation
type
# Set $JWT, $PROJECT_ID, and $VEHICLE_ID in the local
# environment
curl -X POST "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/deliveryVehicles?deliveryVehicleId=${VEHICLE_ID}" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}" \
--data-binary @- << EOM
{
"attributes": [{"key": "model", "value": "sedan"}],
"lastLocation": {"location": {"latitude": 12.1, "longitude": 14.5}}
}
EOM
Aby utworzyć pojazd bez ustawiania żadnych pól, pozostaw treść żądania POST
puste żądanie. Nowo utworzony pojazd wyodrębnia identyfikator z
deliveryVehicleId
w adresie URL żądania POST.
Przykład:
# Set $JWT, $PROJECT_ID, and $VEHICLE_ID in the local
# environment
curl -X POST "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/deliveryVehicles?deliveryVehicleId=${VEHICLE_ID}" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}"