Cập nhật các trường về xe

Tài liệu này đề cập đến các trường quan trọng về xe mà bạn có thể cập nhật khi tạo và quản lý xe.

  • vehicle_state: Xác định tình trạng sẵn có của xe cho các chuyến đi mới.
  • vehicle_type: Trường bắt buộc khi tạo xe. Trường này cũng có thể đóng vai trò là tiêu chí lọc để so khớp xe. Hãy xem bài viết Tạo xe để biết thông tin chi tiết về cách thiết lập trường này.
  • attributes[]: Một mảng không bắt buộc thuộc loại VehicleAttribute. Hãy sử dụng các thuộc tính này để xác định tiêu chí tuỳ chỉnh nhằm tăng cường hành vi lọc khi tìm kiếm hoặc liệt kê xe.
 

Để xem danh sách đầy đủ các trường về xe, hãy xem:

Trường trạng thái xe

Hệ thống của bạn có thể đặt trạng thái xe thành OFFLINE hoặc ONLINE. Ví dụ: bạn có thể đặt trạng thái xe thành ONLINE mỗi ngày vào lúc 9:00 và OFFLINE mỗi ngày vào lúc 17:00.

Chế độ NGOẠI TUYẾN Chế độ TRỰC TUYẾN
Hãy sử dụng OFFLINE để cho biết rằng một chiếc xe không chấp nhận các chuyến đi mới. Xin lưu ý rằng xe vẫn có thể hoàn thành các chuyến đi được chỉ định khi ở trạng thái này.
  • Một Vehicle được tạo ở trạng thái ONLINE có thể được trả về ngay lập tức để phản hồi các truy vấn SearchVehicles. Hãy xem bài viết Tìm kiếm xe để biết thêm thông tin chi tiết.
  • Các xe được tạo ở trạng thái ONLINE phải sử dụng trường last_location trong lệnh gọi CreateVehicle.

Trường thuộc tính xe

Hãy sử dụng trường attributes của xe để tạo tiêu chí tuỳ chỉnh, giúp người tiêu dùng hoặc nhà điều hành đội xe tìm thấy xe trong đội xe của bạn theo nhiều tiêu chí tìm kiếm hơn. Điều này giúp tăng cường khả năng của ứng dụng để cung cấp các kết quả so khớp xe tốt hơn so với việc bạn chỉ sử dụng tiêu chí tìm kiếm dựa trên các trường khác về xe. Mỗi xe có thể có tối đa 100 thuộc tính và mỗi thuộc tính phải có một khoá riêng. Giá trị có thể là chuỗi, boolean hoặc số.

Ví dụ: bạn có thể khai báo một thuộc tính tùy chỉnh có tên là class để phân biệt các xe đi chung xe theo các cấp lớp. Bạn sẽ sử dụng các giá trị chuỗi sau đây để biểu thị các cấp lớp xe: ECONOMY, STANDARDLUXURY.

Tuy nhiên, các giá trị thuộc tính tùy chỉnh không nhất thiết phải loại trừ lẫn nhau. Bạn có thể sử dụng các tiêu chí như pet-friendly, non-smokingable to take longer trips. Mỗi tiêu chí này có thể là một thuộc tính tùy chỉnh riêng biệt sử dụng các giá trị Boolean. Một chiếc xe cụ thể có thể được chỉ định cả 3 thuộc tính tùy chỉnh này cùng với thuộc tính tùy chỉnh class được đặt thành giá trị chuỗi thích hợp.

Việc sử dụng thuộc tính theo cách này có thể cung cấp cho bạn nhiều tính năng hữu ích để tìm xe cho các chuyến đi có nhu cầu cụ thể. Để biết hướng dẫn về cách sử dụng các thuộc tính tuỳ chỉnh làm bộ lọc truy vấn, hãy xem bài viết Tìm kiếm xe.

Cập nhật thuộc tính xe

Bạn có thể cập nhật thuộc tính xe bằng cách sử dụng UpdateVehicle hoặc UpdateVehicleAttributes. Mỗi khoá attributes chỉ có thể có một giá trị cho mỗi xe. Bạn khai báo các thuộc tính tuỳ chỉnh của xe bằng cách sử dụng attributes trong mặt nạ trường, sau đó cung cấp các giá trị dựa trên phương thức bên dưới.

UpdateVehicle UpdateVehicleAttributes
API này không cho phép chỉ cập nhật một thuộc tính. Khi sử dụng phương thức này, mọi việc sử dụng trường attributes trong mặt nạ trường sẽ dẫn đến việc toàn bộ tập hợp thuộc tính xe được khai báo lại cho xe. Điều này dẫn đến việc ghi đè mọi thuộc tính đã tồn tại trước đó không được đưa vào mặt nạ trường một cách rõ ràng. Nếu bạn sử dụng phương thức này để khai báo một thuộc tính tuỳ chỉnh mới, bạn cũng phải khai báo lại mọi thuộc tính tuỳ chỉnh mà bạn muốn xe giữ lại. Nếu bạn loại trừ attributes trong mặt nạ trường, thì phương thức này sẽ giữ nguyên các thuộc tính tuỳ chỉnh hiện có như đã xác định trước đó cho xe. Nếu bạn sử dụng attributes trong mặt nạ trường, nhưng không đặt giá trị, thì điều đó tương đương với việc xoá tất cả các thuộc tính tuỳ chỉnh khỏi xe. Phương thức này chấp nhận một danh sách cụ thể các thuộc tính cần cập nhật. Yêu cầu này chỉ cập nhật hoặc thêm những thuộc tính được chỉ định trong mặt nạ trường. Các thuộc tính đã tồn tại trước đó không được chỉ định vẫn không thay đổi.

Ví dụ về cách cập nhật các trường về xe

Phần này trình bày cách cập nhật các trường về xe bằng cách sử dụng UpdateVehicleRequest, bao gồm update_mask để cho biết những trường cần cập nhật. Hãy xem tài liệu về Bộ đệm giao thức về mặt nạ trường để biết thông tin chi tiết.

Để cập nhật các trường không phải là last_location, bạn cần có đặc quyền Quản trị viên Fleet Engine theo yêu cầu.

Ví dụ: bật loại chuyến đi mới và thuộc tính tuỳ chỉnh

Ví dụ này bật các chuyến đi back_to_back cho xe và cũng chỉ định một thuộc tính mới: class. Như đã lưu ý trong phần Cập nhật thuộc tính xe trước đó, việc cập nhật trường attributes bằng phương pháp này yêu cầu bạn phải cho biết tất cả các thuộc tính tuỳ chỉnh mà bạn muốn giữ lại. Do đó, ví dụ này cho thấy giá trị cash_only được ghi để tránh bị ghi đè trong thao tác cập nhật chỉ định trường attributes.

Để chỉ cập nhật giá trị của một cặp thuộc tính khoá-giá trị, hãy sử dụng phương thức UpdateVehicleAttributes thay thế và không đưa trường attribute vào mặt nạ trường cho yêu cầu UpdateVehicle.

Hãy xem tài liệu tham khảo providers.vehicles.update cho gRPCREST.

gRPC

static final String PROJECT_ID = "project-id";
static final String VEHICLE_ID = "vid-8241890";

VehicleServiceBlockingStub vehicleService = VehicleService.newBlockingStub(channel);

String vehicleName = "providers/" + PROJECT_ID + "/vehicles/" + VEHICLE_ID;
Vehicle updatedVehicle = Vehicle.newBuilder()
    .setVehicleState(VehicleState.ONLINE)
    .addAllAttributes(ImmutableList.of(
        VehicleAttribute.newBuilder().setKey("class").setValue("ECONOMY").build(),
        VehicleAttribute.newBuilder().setKey("cash_only").setValue("false").build()))
    .setBackToBackEnabled(true)
    .build();

UpdateVehicleRequest updateVehicleRequest = UpdateVehicleRequest.newBuilder()
    .setName(vehicleName)
    .setVehicle(updatedVehicle)
    .setUpdateMask(FieldMask.newBuilder()
        .addPaths("vehicle_state")
        .addPaths("attributes")
        .addPaths("back_to_back_enabled"))
    .build();

try {
  Vehicle updatedVehicle =
      vehicleService.updateVehicle(updateVehicleRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
    case NOT_FOUND:
      // Most implementations will call CreateVehicle in this case
      break;
    case PERMISSION_DENIED:
      break;
  }
  return;
}
// If no Exception, Vehicle updated successfully.

REST

curl -X PUT \
  "https://fleetengine.googleapis.com/v1/providers/project-id/vehicles/vid-8241890?updateMask=vehicle_state,attributes,back_to_back_enabled" \
  -H "Authorization: Bearer $JWT" \
  -H "Content-Type: application/json" \
  --data-binary @- << EOM
{
    "vehicleState": "ONLINE",
    "attributes": [
      {"key": "class", "value": "LUXURY"},
      {"key": "cash_only", "value": "false"}
    ],
    "backToBackEnabled": true
}
EOM

Bước tiếp theo