এই নথিটি নিম্নলিখিতগুলির সাথে পরিচিতি অনুমান করে:
- চালানের কাজ তৈরি করুন
- নির্ধারিত কার্যগুলির ভূমিকা, যা কার্য, স্টপ এবং যানবাহনের মধ্যে সম্পর্ককে বিশদভাবে কভার করে৷
ফ্লিট ইঞ্জিন এসেনশিয়াল- এ নির্ধারিত কাজগুলিতে যেমন বলা হয়েছে, আপনি টাস্কগুলি তৈরি করেন এবং গাড়ির থামার সাথে যুক্ত করেন টাস্ক এবং সেই অবস্থানের মধ্যে বাস্তব-বিশ্বের সম্পর্ককে মডেল করার উপায় হিসাবে যেখানে যানবাহন থামবে যাতে ড্রাইভারটি সম্পূর্ণ করতে পারে টাস্ক
সেখান থেকে, আপনি ফ্লিট ইঞ্জিনে আপডেট পাঠিয়ে তাদের জীবনচক্র জুড়ে কাজের অগ্রগতি পরিচালনা করেন যাতে এটি টাস্ক যাত্রায় রাউটিং এবং স্ট্যাটাস আপডেটগুলি সর্বোত্তমভাবে সম্পাদন করতে পারে। আপনি এটি করার একটি মূল উপায় হল গাড়ির কাছে আসার, পৌঁছানো এবং স্টপ ছেড়ে যাওয়ার সময় গাড়ির স্টপ আপডেট করা। এটি ফ্লিট অপারেটর এবং শেষ ব্যবহারকারী উভয়ের জন্য কাজের অগ্রগতি সম্পর্কে প্রতিবেদন এবং বিশ্লেষণ সক্ষম করে। এই স্ট্যাটাস আপডেটগুলি নিম্নরূপ:
- পথে : যানবাহনের যাত্রাপথের তালিকায় স্টপটি পরবর্তীতে রয়েছে তা নির্দেশ করতে
VehicleStop
এর জন্যSTATE
enumENROUTE
ব্যবহার করে। টাস্কের দৃষ্টিকোণ থেকে, এর অর্থ হল স্টপের সাথে যুক্ত যে কোনও কাজ সম্পূর্ণ করার তালিকার পরে রয়েছে। - পৌঁছেছে :
VehicleStop
জন্যSTATE
enumARRIVED
ব্যবহার করে যে গাড়িটি স্টপে এসেছে। টাস্কের দৃষ্টিকোণ থেকে, এর অর্থ হল স্টপের সাথে যুক্ত যে কোনও কাজ সক্রিয়ভাবে কাজ করা হচ্ছে। - সম্পূর্ণ : আপনি গাড়ির স্টপের তালিকা থেকে এটিকে সরিয়ে একটি স্টপ সম্পূর্ণ হিসাবে চিহ্নিত করেন। আপনি যখন এটি করেন, ফ্লিট ইঞ্জিন স্বয়ংক্রিয়ভাবে সমস্ত সংশ্লিষ্ট কাজ বন্ধ হিসাবে চিহ্নিত করে। কাজগুলি বন্ধ করার বিষয়ে আরও বিশদ বিবরণের জন্য, কাজগুলি চূড়ান্ত করুন দেখুন।
এই নথিটি বর্ণনা করে কিভাবে সার্ভার-সাইড পন্থা ব্যবহার করে স্টপ স্ট্যাটাস আপডেট করে। আপনি আপনার ড্রাইভার অ্যাপ থেকে এটি করতে পারেন যদি আপনি ড্রাইভারকে একটি বিশ্বস্ত ডিভাইস ব্যবহার করে কাজগুলি পরিচালনা করার ক্ষমতা প্রদান করেন। শুধুমাত্র একটি পদ্ধতি ব্যবহার করুন যাতে আপনি জাতিগত পরিস্থিতি এড়াতে পারেন এবং সত্যের একক উৎস বজায় রাখতে পারেন।
গাড়ি থামার পথে
গাড়িটি পরবর্তী স্টপে নেভিগেশন শুরু করলে আপনার সিস্টেমের ফ্লিট ইঞ্জিনকে জানানো উচিত। এটি ETA এবং রুট গণনা উন্নত করে।
স্টপ আপডেটের জন্য প্রয়োজনীয় ক্ষেত্র
ফ্লিট ইঞ্জিন বিজ্ঞপ্তির জন্য সত্তার অন্যান্য সমস্ত ক্ষেত্র উপেক্ষা করে।
মাঠ | মান |
---|---|
remainingVehicleJourneySegments | অবশিষ্ট যানবাহন স্টপগুলির তালিকা তাদের রাজ্যগুলিকে State.NEW হিসাবে চিহ্নিত করে৷ |
পথের উদাহরণ থামাতে
নিম্নলিখিত উদাহরণগুলি দেখায় যে কীভাবে ফ্লিট ইঞ্জিনকে অবহিত করা যায় যে একটি যানবাহন তার পরবর্তী স্টপে যাওয়ার পথে, হয় জাভা gRPC লাইব্রেরি ব্যবহার করে বা UpdateDeliveryVehicle
এ একটি HTTP REST কল ব্যবহার করে। অন্য সমস্ত স্টপ নতুন হিসাবে চিহ্নিত করা হয়েছে।
gRPC
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String VEHICLE_ID = "vehicle-8241890";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Vehicle settings
DeliveryVehicle deliveryVehicle = DeliveryVehicle.newBuilder()
// Next stop marked as ENROUTE
.addRemainingVehicleJourneySegments(VehicleJourneySegment.newBuilder() // 1st stop
.setStop(VehicleStop.newBuilder()
.setPlannedLocation(LocationInfo.newBuilder()
.setPoint(LatLng.newBuilder()
.setLatitude(37.7749)
.setLongitude(122.4194)))
.addTasks(TaskInfo.newBuilder().setTaskId(TASK1_ID))
.setState(VehicleStop.State.ENROUTE)))
// All other stops marked as NEW
.addRemainingVehicleJourneySegments(VehicleJourneySegment.newBuilder() // 2nd stop
.setStop(VehicleStop.newBuilder()
.setPlannedLocation(LocationInfo.newBuilder()
.setPoint(LatLng.newBuilder()
.setLatitude(37.3382)
.setLongitude(121.8863)))
.addTasks(TaskInfo.newBuilder().setTaskId(TASK2_ID))
.setState(VehicleStop.State.NEW)))
.build();
// DeliveryVehicle request
UpdateDeliveryVehicleRequest updateDeliveryVehicleRequest =
UpdateDeliveryVehicleRequest.newBuilder() // No need for the header
.setName(vehicleName)
.setDeliveryVehicle(deliveryVehicle)
.setUpdateMask(FieldMask.newBuilder().addPaths("remaining_vehicle_journey_segments"))
.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;
}
বিশ্রাম
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles/<id>?updateMask=remainingVehicleJourneySegments`
- <id> টাস্কের জন্য একটি অনন্য শনাক্তকারী।
- অনুরোধের শিরোনামে অবশ্যই Bearer <token> মান সহ একটি ক্ষেত্র অনুমোদন থাকতে হবে, যেখানে পরিষেবা অ্যাকাউন্টের ভূমিকা এবং JSON ওয়েব টোকেনে বর্ণিত নির্দেশিকা অনুসারে আপনার সার্ভার দ্বারা <token> জারি করা হয়।
- অনুরোধের অংশে অবশ্যই একটি
DeliveryVehicle
সত্তা থাকতে হবে:
curl
কমান্ডের উদাহরণ:
# 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
{
"remainingVehicleJourneySegments": [
{
"stop": {
"state": "ENROUTE",
"plannedLocation": {
"point": {
"latitude": 37.7749,
"longitude": -122.084061
}
},
"tasks": [
{
"taskId": "${TASK1_ID}"
}
]
}
},
{
"stop": {
"state": "NEW",
"plannedLocation": {
"point": {
"latitude": 37.3382,
"longitude": 121.8863
}
},
"tasks": [
{
"taskId": "${TASK2_ID}"
}
]
}
}
]
}
EOM
স্টপেজে আসে যানবাহন
ফ্লিট ইঞ্জিনকে অবশ্যই অবহিত করতে হবে যখন কোনো গাড়ি স্টপেজে আসে।
স্টপ আপডেটের জন্য প্রয়োজনীয় ক্ষেত্র
ফ্লিট ইঞ্জিন বিজ্ঞপ্তির জন্য সত্তার অন্যান্য সমস্ত ক্ষেত্র উপেক্ষা করে।
মাঠ | মান |
---|---|
remainingVehicleJourneySegments | অবশিষ্ট যানবাহন স্টপগুলির তালিকা তাদের রাজ্যগুলিকে State.NEW হিসাবে চিহ্নিত করে৷ |
স্টপ উদাহরণ এ পৌঁছেছে
নিম্নলিখিত উদাহরণগুলি দেখায় যে কীভাবে ফ্লিট ইঞ্জিনকে জানানো যায় যে কোনও যানবাহন স্টপে এসেছে, হয় Java gRPC লাইব্রেরি বা UpdateDeliveryVehicle
এ একটি HTTP REST কল ব্যবহার করে। অন্যান্য সমস্ত স্টপ নতুন হিসাবে চিহ্নিত করা হয়েছে৷
gRPC
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 deliveryVehicle = DeliveryVehicle.newBuilder()
// Marking the arrival at stop.
.addRemainingVehicleJourneySegments(VehicleJourneySegment.newBuilder()
.setStop(VehicleStop.newBuilder()
.setPlannedLocation(LocationInfo.newBuilder()
.setPoint(LatLng.newBuilder()
.setLatitude(37.7749)
.setLongitude(122.4194)))
.addTasks(TaskInfo.newBuilder().setTaskId(TASK1_ID))
.setState(VehicleStop.State.ARRIVED)))
// All other remaining stops marked as NEW.
.addRemainingVehicleJourneySegments(VehicleJourneySegment.newBuilder() // 2nd stop
.setStop(VehicleStop.newBuilder()
.setPlannedLocation(LocationInfo.newBuilder()
.setPoint(LatLng.newBuilder()
.setLatitude(37.3382)
.setLongitude(121.8863)))
.addTasks(TaskInfo.newBuilder().setTaskId(TASK2_ID))
.setState(VehicleStop.State.NEW))) // Remaining stops must be NEW.
.build();
// DeliveryVehicle request
UpdateDeliveryVehicleRequest updateDeliveryVehicleRequest =
UpdateDeliveryVehicleRequest.newBuilder() // No need for the header
.setName(vehicleName)
.setDeliveryVehicle(deliveryVehicle)
.setUpdateMask(FieldMask.newBuilder()
.addPaths("remaining_vehicle_journey_segments"))
.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;
}
বিশ্রাম
`PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles/<id>?updateMask=remainingVehicleJourneySegments`
- <id> টাস্কের জন্য একটি অনন্য শনাক্তকারী।
- অনুরোধের শিরোনামে অবশ্যই Bearer <token> মান সহ একটি ক্ষেত্র অনুমোদন থাকতে হবে, যেখানে পরিষেবা অ্যাকাউন্টের ভূমিকা এবং JSON ওয়েব টোকেনে বর্ণিত নির্দেশিকা অনুসারে আপনার সার্ভার দ্বারা <token> জারি করা হয়।
- অনুরোধের অংশে অবশ্যই একটি
DeliveryVehicle
সত্তা থাকতে হবে:
curl
কমান্ডের উদাহরণ:
# 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
{
"remainingVehicleJourneySegments": [
{
"stop": {
"state": "ARRIVED",
"plannedLocation": {
"point": {
"latitude": 37.7749,
"longitude": -122.084061
}
},
"tasks": [
{
"taskId": "${TASK1_ID}"
}
]
}
},
{
"stop": {
"state": "NEW",
"plannedLocation": {
"point": {
"latitude": 37.3382,
"longitude": 121.8863
}
},
"tasks": [
{
"taskId": "${TASK2_ID}"
}
]
}
}
]
}
EOM
যানবাহন একটি স্টপ সম্পূর্ণ
ফ্লিট ইঞ্জিনকে অবশ্যই অবহিত করতে হবে যখন একটি গাড়ি স্টপ শেষ করে। এর ফলে স্টপের সাথে যুক্ত সমস্ত কাজ বন্ধ অবস্থায় সেট করা হয়।
স্টপ আপডেটের জন্য প্রয়োজনীয় ক্ষেত্র
ফ্লিট ইঞ্জিন বিজ্ঞপ্তির জন্য সত্তার অন্যান্য সমস্ত ক্ষেত্র উপেক্ষা করে।
মাঠ | মান |
---|---|
remainingVehicleJourneySegments | অবশিষ্ট যানবাহন স্টপগুলির তালিকা তাদের রাজ্যগুলিকে State.NEW হিসাবে চিহ্নিত করে৷ তালিকার প্রথম স্টপে অবশ্যই এর স্টেটকে State.ENROUTE হিসেবে চিহ্নিত করতে হবে। |
একটি স্টপ উদাহরণ সম্পূর্ণ করে
নিম্নলিখিত উদাহরণগুলি দেখায় যে কীভাবে ফ্লিট ইঞ্জিনকে জানানো যায় যে কোনও যানবাহন স্টপে এসেছে, হয় Java gRPC লাইব্রেরি বা UpdateDeliveryVehicle
এ একটি HTTP REST কল ব্যবহার করে। অন্যান্য সমস্ত স্টপ নতুন হিসাবে চিহ্নিত করা হয়েছে৷
gRPC
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 deliveryVehicle = DeliveryVehicle.newBuilder()
// This stop has been completed and is commented out to indicate it
// should be removed from the list of vehicle journey segments.
// .addRemainingVehicleJourneySegments(VehicleJourneySegment.newBuilder()
// .setStop(VehicleStop.newBuilder()
// .setPlannedLocation(LocationInfo.newBuilder()
// .setPoint(LatLng.newBuilder()
// .setLatitude(37.7749)
// .setLongitude(122.4194)))
// .addTasks(TaskInfo.newBuilder().setTaskId(TASK1_ID))
// .setState(VehicleStop.State.ARRIVED)))
// All other remaining stops marked as NEW.
// The next stop could be marked as ENROUTE if the vehicle has begun
// its journey to the next stop.
.addRemainingVehicleJourneySegments(VehicleJourneySegment.newBuilder() // Next stop
.setStop(VehicleStop.newBuilder()
.setPlannedLocation(LocationInfo.newBuilder()
.setPoint(LatLng.newBuilder()
.setLatitude(37.3382)
.setLongitude(121.8863)))
.addTasks(TaskInfo.newBuilder().setTaskId(TASK2_ID))
.setState(VehicleStop.State.NEW)))
.build();
// DeliveryVehicle request
UpdateDeliveryVehicleRequest updateDeliveryVehicleRequest =
UpdateDeliveryVehicleRequest.newBuilder() // no need for the header
.setName(vehicleName)
.setDeliveryVehicle(deliveryVehicle)
.setUpdateMask(FieldMask.newBuilder()
.addPaths("remaining_vehicle_journey_segments"))
.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;
}
বিশ্রাম
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles/<id>?updateMask=remaining_vehicle_journey_segments`
- <id> টাস্কের জন্য একটি অনন্য শনাক্তকারী।
- অনুরোধের শিরোনামে অবশ্যই Bearer <token> মান সহ একটি ক্ষেত্র অনুমোদন থাকতে হবে, যেখানে পরিষেবা অ্যাকাউন্টের ভূমিকা এবং JSON ওয়েব টোকেনে বর্ণিত নির্দেশিকা অনুসারে আপনার সার্ভার দ্বারা <token> জারি করা হয়।
- অনুরোধের অংশে অবশ্যই একটি
DeliveryVehicle
সত্তা থাকতে হবে:
curl
কমান্ডের উদাহরণ:
# 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
{
"remainingVehicleJourneySegments": [
{
"stop": {
"state": "NEW",
"plannedLocation": {
"point": {
"latitude": 37.3382,
"longitude": 121.8863
}
},
"tasks": [
{
"taskId": "${TASK2_ID}"
}
]
}
}
]
}
EOM