В этом документе описывается, как удалить транспортное средство. Предполагается, что вы настроили Fleet Engine. См. Настройка Fleet Engine .
Основы удаления автомобиля
Ваша система может использовать Fleet Engine для удаления транспортного средства в следующих ситуациях:
- Для выполнения операций очистки во время тестирования API Fleet Engine.
- Немедленно удалить Транспортное средство, которое больше не требуется.
Чтобы удалить транспортное средство, отправьте запрос с помощью gRPC или REST.
Используйте соответствующие учетные данные для учетной записи службы вашего проекта, как описано в разделе Fleet Engine: роли учетной записи службы .
Пример: удалить автомобиль
В следующем примере показано, как использовать библиотеку Java gRPC для удаления транспортного средства.
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String VEHICLE_ID = "vehicle-8241890";
String vehicleName = "providers/" + PROJECT_ID + "/vehicles/" + VEHICLE_ID;
VehicleServiceBlockingStub vehicleService = VehicleService.newBlockingStub(channel);
// Delete Vehicle request
DeleteVehicleRequest deleteVehicleRequest = DeleteVehicleRequest.newBuilder()
.setName(vehicleName)
.build();
try {
vehicleService.deleteVehicle(deleteVehicleRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The vehicle doesn't exist.
break;
case FAILED_PRECONDITION: // There are trip(s) that reference vehicle.
break;
case PERMISSION_DENIED:
break;
}
return;
}
В следующем примере показано, как удалить транспортное средство из Fleet Engine с помощью REST, вызвав метод DeleteVehicle
.
# DELETE https://fleetengine.googleapis.com/v1/providers/<project_id>/vehicles/<vehicleId>
# Set JWT, PROJECT_ID, and VEHICLE_ID in the local environment
curl -X DELETE -H "Authorization: Bearer ${JWT}" \
"https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/vehicles/${VEHICLE_ID}"
Если операция удаления прошла успешно, API возвращает пустой ответ.
Обработка ошибок
При удалении транспортного средства вы можете столкнуться с ошибкой FAILED_PRECONDITION
, и в этом случае существуют поездки, ссылающиеся на транспортное средство. Чтобы продолжить удаление:
- Вызовите
SearchTrips
, чтобы найти поездки, которые ссылаются на Транспортное средство. - Вызовите
DeleteTrip
, чтобы удалить каждую найденную поездку.