डिलीवरी करने वाले वाहन की जगह की जानकारी अपडेट करना

तरीके

Fleet Engine की सबसे अच्छी परफ़ॉर्मेंस के लिए, इसे हर मिनट में कम से कम एक बार और हर पांच सेकंड में ज़्यादा से ज़्यादा एक बार, वाहन की जगह की जानकारी के अपडेट दें. इन अपडेट को उपलब्ध कराने के लिए, इनमें से कोई एक तरीका इस्तेमाल करें:

  • Driver SDK का इस्तेमाल करें: यह सबसे आसान विकल्प है.
  • कस्टम कोड का इस्तेमाल करें: यह तब काम आता है, जब जगहों की जानकारी आपके बैकएंड के ज़रिए रिले की जाती है या जब Android या iOS के अलावा किसी दूसरे डिवाइस का इस्तेमाल किया जाता है. इस दस्तावेज़ में उस तरीके के बारे में बताया गया है.

वाहन की जगह की जानकारी के अपडेट देने के तरीके से कोई फ़र्क़ नहीं पड़ता. जब डिलीवरी वाहन किसी स्टॉप पर जा रहा हो और जब वह किसी स्टॉप पर पहुंच जाए, तब Fleet Engine को अपडेट करने की ज़िम्मेदारी आपके बैकएंड की होती है. इसमें डिपो भी शामिल है. Fleet Engine इन इवेंट का पता अपने-आप नहीं लगाता.

वाहन की जगह की जानकारी अपडेट करने के उदाहरण

फ़्लीट इंजन में किसी वाहन की जगह की जानकारी अपडेट करने के लिए, Java gRPC लाइब्रेरी का इस्तेमाल किया जा सकता है. इसके अलावा, REST का इस्तेमाल भी किया जा सकता है.

Java

  static final String PROJECT_ID = "my-delivery-co-gcp-project";
  static final String VEHICLE_ID = "vehicle-8241890";

  DeliveryServiceBlockingStub deliveryService =
    DeliveryServiceGrpc.newBlockingStub(channel);

  // Vehicle settings
  String vehicleName = "providers/" + PROJECT_ID + "/deliveryVehicles/" + VEHICLE_ID;
  DeliveryVehicle myDeliveryVehicle = DeliveryVehicle.newBuilder()
      .setLastLocation(DeliveryVehicleLocation.newBuilder()
          .setSupplementalLocation(LatLng.newBuilder()
              .setLatitude(37.3382)
              .setLongitude(121.8863))
          .setSupplementalLocationTime(now())
          .setSupplementalLocationSensor(DeliveryVehicleLocationSensor.CUSTOMER_SUPPLIED_LOCATION)
          .setSupplementalLocationAccuracy(DoubleValue.of(15.0)))  // Optional
      .build();

  // DeliveryVehicle request
  UpdateDeliveryVehicleRequest updateDeliveryVehicleRequest =
    UpdateDeliveryVehicleRequest.newBuilder()  // No need for the header
        .setName(vehicleName)
        .setDeliveryVehicle(myDeliveryVehicle)
        .setUpdateMask(FieldMask.newBuilder()
            .addPaths("last_location"))
        .build();

  try {
    DeliveryVehicle updatedDeliveryVehicle =
        deliveryService.updateDeliveryVehicle(updateDeliveryVehicleRequest);
  } catch (StatusRuntimeException e) {
    Status s = e.getStatus();
    switch (s.getCode()) {
       case NOT_FOUND:
         break;
       case PERMISSION_DENIED:
         break;
    }
    return;
  }

REST

PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles/<id>?updateMask=last_location

अनुरोध की जानकारी

अनुरोध के मुख्य हिस्से में, DeliveryVehicle इकाई शामिल होनी चाहिए. इसमें फ़ील्ड इस तरह से तय किए जाते हैं:

  • ज़रूरी फ़ील्ड:

    फ़ील्डमान
    lastLocation.supplementalLocation वाहन की जगह की जानकारी.
    lastLocation.supplementalLocationTime यह टाइमस्टैंप बताता है कि वाहन आखिरी बार इस जगह पर कब था.
    lastLocation.supplementalLocationSensor इसमें CUSTOMER_SUPPLIED_LOCATION की जानकारी होनी चाहिए.

  • ये फ़ील्ड ज़रूरी नहीं हैं:

    फ़ील्डमान
    lastLocation.supplementalLocationAccuracy जगह की दी गई जानकारी की सटीक दूरी, मीटर में.

  # Set JWT, PROJECT_ID, VEHICLE_ID, TASK1_ID, and TASK2_ID in the local
  # environment
  curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/deliveryVehicles/${VEHICLE_ID}?updateMask=remainingVehicleJourneySegments" \
    -H "Content-type: application/json" \
    -H "Authorization: Bearer ${JWT}" \
    --data-binary @- << EOM
  {
    "lastLocation": {
      "supplementalLocation": {"latitude": 12.1, "longitude": 14.5},
      "supplementalLocationTime": "$(date -u --iso-8601=seconds)",
      "supplementalLocationSensor": "CUSTOMER_SUPPLIED_LOCATION",
      "supplementalLocationAccuracy": 15
    }
  }
  EOM

आगे क्या करना है