อัปเดตช่องข้อมูลของยานพาหนะ

เอกสารนี้ครอบคลุมข้อมูลเกี่ยวกับยานพาหนะที่สำคัญซึ่งคุณอัปเดตได้เมื่อสร้างและจัดการยานพาหนะ

  • vehicle_state: กำหนดความพร้อมให้บริการของยานพาหนะสำหรับการเดินทางใหม่
  • vehicle_type: ช่องที่ต้องกรอกเมื่อสร้างยานพาหนะ ช่องนี้ยังใช้เป็นเกณฑ์ตัวกรองสำหรับการจับคู่ยานพาหนะได้ด้วย ดูรายละเอียดเกี่ยวกับการตั้งค่าช่องนี้ได้ที่หัวข้อสร้างยานพาหนะ
  • attributes[]: อาร์เรย์ประเภทตัวเลือก VehicleAttribute ใช้เกณฑ์เหล่านี้เพื่อกำหนดเกณฑ์ที่กำหนดเองเพื่อปรับปรุงลักษณะการกรองเมื่อค้นหาหรือแสดงยานพาหนะ
 

ดูรายการฟิลด์ยานพาหนะทั้งหมดได้ที่

ช่องสถานะยานพาหนะ

ระบบของคุณสามารถตั้งค่าสถานะของยานพาหนะเป็น OFFLINE หรือ ONLINE ได้ เช่น คุณอาจตั้งค่าสถานะยานพาหนะเป็น ONLINE ทุกวัน เวลา 09:00 น. และ OFFLINE ทุกวัน เวลา 17:00 น.

โหมดออฟไลน์ โหมดออนไลน์
ใช้ OFFLINE เพื่อระบุว่ายานพาหนะไม่ยอมรับการเดินทางใหม่ โปรดทราบว่าพาหนะจะยังคงเดินทางตามที่กำหนดไว้จนเสร็จสมบูรณ์ได้ขณะอยู่ในสถานะนี้
  • Vehicle ที่สร้างขึ้นในสถานะ ONLINE อาจแสดงผลทันทีตามคำขอ SearchVehicles ดูรายละเอียดเพิ่มเติมได้ที่ยานพาหนะสำหรับค้นหา
  • ยานพาหนะที่สร้างขึ้นในสถานะ ONLINE ควรใช้ช่อง last_location ในการเรียก CreateVehicle

ฟิลด์แอตทริบิวต์ของยานพาหนะ

ใช้ช่องยานพาหนะ attributes เพื่อสร้างเกณฑ์ที่กำหนดเองเพื่อให้ผู้บริโภคหรือผู้ดำเนินการเดินรถค้นหายานพาหนะในฟลีตของคุณผ่านเกณฑ์การค้นหาที่หลากหลายมากขึ้น การดำเนินการนี้จะช่วยปรับปรุงความสามารถของแอปเพื่อให้จับคู่ยานพาหนะได้ดีขึ้นเมื่อเทียบกับสิ่งที่คุณทำโดยใช้เกณฑ์การค้นหาที่อิงตามช่องยานพาหนะอื่นๆ เพียงอย่างเดียว ยานพาหนะแต่ละคันจะมีแอตทริบิวต์ได้สูงสุด 100 รายการ และแต่ละรายการต้องมีคีย์ที่ไม่ซ้ำกัน ค่าอาจเป็นสตริง บูลีน หรือตัวเลข

เช่น คุณอาจประกาศแอตทริบิวต์ที่กำหนดเองชื่อว่า class เพื่อแยกความแตกต่างของพาหนะสำหรับร่วมเดินทางในระดับชั้นต่างๆ คุณจะใช้ค่าสตริงต่อไปนี้เพื่อแสดงระดับชั้นของยานพาหนะ ECONOMY, STANDARD และ LUXURY

อย่างไรก็ตาม ค่าแอตทริบิวต์ที่กำหนดเองไม่จำเป็นต้องแยกกัน คุณอาจใช้เกณฑ์ เช่น นำสัตว์เลี้ยงเข้าพักได้ ปลอดบุหรี่ และเดินทางได้นานขึ้น รายการเหล่านี้อาจเป็นแอตทริบิวต์ที่กำหนดเองแยกต่างหากซึ่งใช้ค่าบูลีน ยานพาหนะหนึ่งๆ อาจได้รับการกำหนดแอตทริบิวต์ที่กำหนดเองทั้ง 3 รายการนี้ พร้อมกับแอตทริบิวต์ที่กำหนดเอง class ที่ตั้งค่าเป็นสตริงค่าที่เหมาะสม

การใช้แอตทริบิวต์ด้วยวิธีนี้จะช่วยให้คุณมีฟีเจอร์ที่หลากหลายซึ่งเป็นประโยชน์ในการค้นหายานพาหนะสำหรับการเดินทางที่มีความต้องการเฉพาะ ดูวิธีการใช้แอตทริบิวต์ที่กำหนดเองเป็นตัวกรองข้อความค้นหาได้ที่ค้นหายานพาหนะ

อัปเดตแอตทริบิวต์ยานพาหนะ

คุณสามารถอัปเดตแอตทริบิวต์ยานพาหนะได้โดยใช้ UpdateVehicle หรือ UpdateVehicleAttributes คีย์ attributes แต่ละคีย์มีได้เพียงค่าเดียวต่อยานพาหนะ 1 คัน คุณประกาศแอตทริบิวต์ยานพาหนะที่กำหนดเองโดยใช้ attributes ในมาสก์ของช่อง แล้วระบุค่าตามวิธีการด้านล่าง

UpdateVehicle UpdateVehicleAttributes
API นี้ไม่อนุญาตให้อัปเดตเพียงแอตทริบิวต์เดียว เมื่อใช้วิธีนี้ การใช้ช่อง attributes ในมาสก์ของช่องจะส่งผลให้แอตทริบิวต์ยานพาหนะได้รับการประกาศอีกครั้งสำหรับยานพาหนะทั้งชุด ซึ่งจะส่งผลให้มีการเขียนทับแอตทริบิวต์ที่มีอยู่ซึ่งไม่ได้รวมอยู่ในมาสก์ช่องอย่างชัดเจน หากใช้วิธีนี้เพื่อประกาศแอตทริบิวต์ที่กำหนดเองใหม่ คุณจะต้องประกาศแอตทริบิวต์ที่กำหนดเองทุกรายการที่ต้องการให้ยานพาหนะเก็บไว้อีกครั้ง หากคุณยกเว้น attributes ในมาสก์ฟิลด์ วิธีการนี้จะปล่อยแอตทริบิวต์ที่กำหนดเองที่มีอยู่ไว้ตามที่ได้กำหนดไว้ก่อนหน้านี้สำหรับยานพาหนะ หากคุณใช้ attributes ในมาสก์ช่อง แต่ไม่ได้ตั้งค่า การดำเนินการนี้จะเทียบเท่ากับการนำแอตทริบิวต์ที่กำหนดเองทั้งหมดออกจากยานพาหนะ เมธอดนี้ยอมรับรายการที่เฉพาะเจาะจงของแอตทริบิวต์ที่จะอัปเดต คำขอจะอัปเดตหรือเพิ่มเฉพาะแอตทริบิวต์ที่ระบุไว้ในมาสก์ช่อง แอตทริบิวต์ที่มีอยู่เดิมซึ่งไม่ได้ระบุไว้จะยังคงเหมือนเดิม

ตัวอย่างการอัปเดตช่องยานพาหนะ

ส่วนนี้จะแสดงวิธีอัปเดตฟิลด์ยานพาหนะโดยใช้ UpdateVehicleRequest ซึ่งจะมี update_mask เพื่อระบุฟิลด์ที่จะอัปเดต ดูรายละเอียดได้จากเอกสารบัฟเฟอร์โปรโตคอลเกี่ยวกับฟิลด์มาสก์

การอัปเดตฟิลด์อื่นที่ไม่ใช่ last_location ต้องมีสิทธิ์ผู้ดูแลระบบของ Fleet Engine แบบออนดีมานด์

ตัวอย่าง: เปิดใช้ประเภทการเดินทางใหม่และแอตทริบิวต์ที่กำหนดเอง

ตัวอย่างนี้เปิดใช้การเดินทาง back_to_back เที่ยวสำหรับยานพาหนะ และระบุแอตทริบิวต์ใหม่ class ด้วย ตามที่ระบุไว้ในอัปเดตแอตทริบิวต์ยานพาหนะก่อนหน้านี้ การอัปเดตช่อง attributes โดยใช้วิธีนี้กำหนดให้คุณระบุแอตทริบิวต์ที่กำหนดเองทั้งหมดที่ต้องการเก็บไว้ ดังนั้นตัวอย่างจึงแสดงค่า cash_only ที่เขียนไว้เพื่อป้องกันไม่ให้มีการเขียนทับระหว่างการดำเนินการอัปเดตที่ระบุช่อง attributes

หากต้องการอัปเดตเฉพาะค่าของคู่แอตทริบิวต์คีย์-ค่ารายการเดียว ให้ใช้เมธอด UpdateVehicleAttributes แทน และอย่ารวมช่อง attribute ไว้ในมาสก์ช่องสำหรับคำขอ UpdateVehicle

ดูข้อมูลอ้างอิง providers.vehicles.update สำหรับ gRPC และ REST

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

ขั้นตอนถัดไป