Удалить автомобиль

В этом документе описывается, как удалить транспортное средство. Предполагается, что вы настроили Fleet Engine. См. Настройка Fleet Engine .

Основы удаления автомобиля

Ваша система может использовать Fleet Engine для удаления транспортного средства в следующих ситуациях:

  • Для выполнения операций очистки во время тестирования API Fleet Engine.
  • Немедленно удалить Транспортное средство, которое больше не требуется.

Чтобы удалить транспортное средство, отправьте запрос с помощью gRPC или REST.

  • Метод DeleteVehicle() : gRPC или REST
  • Сообщение DeleteVehicleRequest : только gRPC

Используйте соответствующие учетные данные для учетной записи службы вашего проекта, как описано в разделе 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 , и в этом случае существуют поездки, ссылающиеся на транспортное средство. Чтобы продолжить удаление:

  1. Вызовите SearchTrips , чтобы найти поездки, которые ссылаются на Транспортное средство.
  2. Вызовите DeleteTrip , чтобы удалить каждую найденную поездку.

Что дальше