অন-ডিমান্ড ট্রিপের জন্য একটি গাড়ি তৈরি করুন

অন-ডিমান্ড ট্রিপের জন্য Fleet Engine-এ একটি গাড়ি তৈরি করতে, CreateVehicleRequest সহ CreateVehicle এন্ডপয়েন্ট ব্যবহার করুন। এই এন্ডপয়েন্টের জন্য Fleet Engine On-demand অ্যাডমিন ভূমিকা সহ একটি অ্যাকাউন্ট প্রয়োজন।

চাহিদা অনুযায়ী ট্রিপ যানবাহনের জন্য ক্ষেত্র

অন-ডিমান্ড ট্রিপের জন্য যানবাহন তৈরি করার সময়, আপনাকে অবশ্যই প্রয়োজনীয় ক্ষেত্রগুলি সেট করতে হবে। ফ্লিট ইঞ্জিনের অন্যান্য কার্যকারিতার উপর নির্দিষ্ট যানবাহন ক্ষেত্রগুলি কীভাবে প্রভাব ফেলে তা সম্পর্কেও আপনার পরিচিত হওয়া উচিত। এর জন্য যানবাহন ক্ষেত্রগুলি আপডেট করুন দেখুন।

চাহিদা অনুযায়ী ভ্রমণের জন্য প্রয়োজনীয় ক্ষেত্র

  • vehicle_state : ডিফল্টভাবে অজানা, তবে অনলাইন বা অফলাইনে সেট করা উচিত। Update vehicle fields- এ vehicle state ক্ষেত্র সেট করার তথ্য দেখুন।
  • supported_trip_types : ডিফল্টভাবে অজানা, তবে SHARED, EXCLUSIVE, অথবা উভয়ই সেট করা উচিত। বিস্তারিত জানার জন্য অন-ডিমান্ড ট্রিপ গাইডে ট্রিপের ধরণগুলি দেখুন।
  • maximum_capacity : গাড়িটি বহন করতে পারে এমন যাত্রীর সংখ্যা, যা ড্রাইভারকে বাদ দেয় (সংজ্ঞা অনুসারে)।
  • vehicle_type : মানগুলি হল AUTO , TAXI , TRUCK , TWO_WHEELER , BICYCLE , অথবা PEDESTRIAN । যানবাহন অনুসন্ধানের জন্য যানবাহন ফিল্টার করতে ব্যবহার করা যেতে পারে। এটি ETA এবং রুট গণনাকেও প্রভাবিত করে। Fleet Engine নিম্নলিখিত যানবাহনের ধরণের গোষ্ঠীর উপর ভিত্তি করে ভ্রমণের মোডের সাথে সঙ্গতিপূর্ণ রুট এবং ভ্রমণ গণনা প্রদান করে:
    • AUTO , TAXI বা TRUCK : উদাহরণস্বরূপ হাইওয়ে।
    • TWO_WHEELER : উদাহরণস্বরূপ, যেসব রুটে দুই চাকার যানবাহন চলাচলের অনুমতি নেই, সেখানে এটি ফেরত পাঠাবে না।
    • BICYCLE : উদাহরণস্বরূপ, সাইকেল পাথ।
    • PEDESTRIAN : উদাহরণস্বরূপ, কেবল পথচারীদের জন্য সেতু এবং হাঁটার পথ।

অন্যান্য ক্ষেত্র

যানবাহন তৈরি করার সময় আপনি যে অন্যান্য ক্ষেত্রগুলি সেট করতে পারেন তার জন্য, যানবাহন ক্ষেত্রগুলি আপডেট করুন দেখুন।

যানবাহন তৈরির উদাহরণ

CreateVehicle থেকে যে মানটি ফেরত দেওয়া হয় তা হলো তৈরি করা Vehicle সত্তা।

জাভা

static final String PROJECT_ID = "project-id";

VehicleServiceBlockingStub vehicleService =
    VehicleService.newBlockingStub(channel);

String parent = "providers/" + PROJECT_ID;
Vehicle vehicle = Vehicle.newBuilder()
    .setVehicleState(VehicleState.OFFLINE)  // Initial state
    .addSupportedTripTypes(TripType.EXCLUSIVE)
    .setMaximumCapacity(4)
    .setVehicleType(VehicleType.newBuilder().setCategory(VehicleType.Category.AUTO))
    .addAttributes(VehicleAttribute.newBuilder()
        .setKey("on_trip").setValue("false"))  // Opaque to the Fleet Engine
    // Add .setBackToBackEnabled(true) to make this vehicle eligible for trip
    // matching while even if it is on a trip.  By default this is disabled.
    .build();

CreateVehicleRequest createVehicleRequest =
    CreateVehicleRequest.newBuilder()  // no need for the header
        .setParent(parent)
        .setVehicleId("vid-8241890")  // Vehicle ID assigned by Rideshare or Delivery Provider
        .setVehicle(vehicle)  // Initial state
        .build();

// In this case, the Vehicle is being created in the OFFLINE state and
// no initial position is being provided.  When the Driver App checks
// in with the Rideshare or Delivery Provider, the state can be set to ONLINE and
// the Driver App will update the Vehicle Location.

try {
  Vehicle createdVehicle =
      vehicleService.createVehicle(createVehicleRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
    case ALREADY_EXISTS:
      break;
    case PERMISSION_DENIED:
      break;
  }
  return;
}
// If no Exception, Vehicle created successfully.

বিশ্রাম

curl -X POST \
  "https://fleetengine.googleapis.com/v1/providers/project-id/vehicles?vehicleId=vid-8241890" \
  -H "Authorization: Bearer $JWT" \
  -H "Content-Type: application/json" \
  --data-binary @- << EOM
{
    "vehicleState": "OFFLINE",
    "supportedTripTypes": ["EXCLUSIVE"],
    "maximumCapacity": 4,
    "vehicleType": {"category": "AUTO"},
    "attributes": [{"key": "on_trip", "value": "false"}]
}
EOM

providers.vehicles.create রেফারেন্স দেখুন।

এরপর কি?