本文假設您已瞭解如何建立及使用工作。以下提供如何完成運送工作任務的具體範例:
關閉工作:關閉出貨工作會將其狀態變更為
CLOSED
,並表示該工作已不再處於活動狀態。設定工作結果:工作關閉後,您可以將結果設為
SUCCEEDED
或FAILED
來完成工作。這是完成工作的重要步驟,可在旅程分享中顯示運送結果,並確保 Fleet Engine 服務的帳單正確無誤。
關閉工作
你可以透過下列方式關閉工作:
- 更新車輛的停靠站狀態。您從車輛中移除停靠站,系統就會關閉與停靠站相關聯的所有工作。詳情請參閱「更新停靠站狀態」。
- 將工作從車輛停靠站清單中移除。這包括更新停靠站的工作清單,但已關閉的工作不再是清單的一部分。請參閱「更新工作」中的「更新工作順序」。
- 將工作狀態設為
CLOSED
。這項操作只能用於未指派給車輛的工作。本節將說明這項做法。
關閉工作後,可能無法重新開啟。
關閉工作並不代表工作成功或失敗。這表示系統不再將該工作視為進行中。為了顯示任務的實際結果,並用於車隊追蹤和行程分享,您必須指出任務的實際結果。請參閱下方的設定工作結果。
關閉工作用的任務欄位
本節說明關閉工作時必須設定的欄位。車隊引擎會忽略實體中的所有其他欄位。
必填欄位 | 值 |
---|---|
state |
State.CLOSED |
直接關閉工作
以下範例說明如何在 gRPC 中或使用 HTTP REST 要求呼叫 UpdateTask
來將未指派的工作設為已關閉狀態。
gRPC
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String TASK_ID = "task-8241890";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Task settings
String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;
Task task = Task.newBuilder()
.setName(taskName)
.setState(Task.State.CLOSED) // You can only directly CLOSE a
.build(); // task that is NOT assigned to a vehicle.
// Task request
UpdateTaskRequest updateTaskRequest =
UpdateTaskRequest.newBuilder() // No need for the header
.setTask(task)
.setUpdateMask(FieldMask.newBuilder().addPaths("state"))
.build();
try {
Task updatedTask = deliveryService.updateTask(updateTaskRequest);
} 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>/tasks/<id>?updateMask=state
- <id> 是工作的專屬 ID。
- 要求標頭必須包含「Authorization」欄位,其值為「Bearer <token>」,其中 <token> 是由伺服器根據「服務帳戶角色」和「JSON Web 權杖」中的指南所發出。
- 您必須在要求主體中加入
Task
實體
curl
指令範例:
# Set JWT, PROJECT_ID, and TASK_ID in the local environment
curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/tasks/${TASK_ID}?updateMask=state,taskOutcome,taskOutcomeTime" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}" \
--data-binary @- << EOM
{
"state": "CLOSED",
"taskOutcome": "SUCCEEDED",
"taskOutcomeTime": "$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
}
EOM
設定工作結果
如要指出工作實際的結果,請將已關閉的工作的結果設為 SUCCEEDED
或 FAILED
。您必須先關閉工作,才能設定結果。Fleet Engine 只會針對狀態為 SUCCEEDED
的運送工作收費。
工作結果詳細資料
工作也會提供工作結果的其他詳細資料。您可以直接設定這些項目,Fleet Engine 會遵循您的設定:
- 工作結果位置:Fleet Engine 會自動使用車輛的最後已知位置填入工作結果位置。您可以視需要提供這項資訊。
- 工作結果時間:Fleet Engine 不會填入這個欄位,但您可以自行設定。
您可以使用下列任一方法設定 task_outcome_location
和 task_outcome_time
:
- 在設定工作結果的同一項要求中更新。
- 設定工作結果後,稍後再更新。
- 設定完成後,請再次修改。
Fleet Engine 會防止下列與工作結果相關的更新:
- 一旦將任務結果設為
SUCCEEDED
或FAILED
,就無法再修改。 - 如果工作未設定結果,就無法設定工作結果地點或結果時間。
設定結果的工作欄位
本節說明設定工作結果時,需要設定的必填和選填欄位。Fleet Engine 會忽略實體中的其他欄位。
必填欄位 | 值 |
---|---|
taskOutcome |
Outcome.SUCCEEDED 或 Outcome.FAILED |
選填欄位 | 值 |
---|---|
taskOutcomeLocation |
完成工作的地點。如果未設定,Fleet Engine 會將此值預設為上次的車輛位置。 |
taskOutcomeTime |
工作完成時間的時間戳記。 |
任務結果範例
以下範例說明如何使用 Java gRPC 程式庫和 HTTP REST 呼叫 UpdateTask
,將工作結果設為 SUCCEEDED
,並設定工作完成的位置。
gRPC
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String TASK_ID = "task-8241890";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Task settings
String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;
Task task = Task.newBuilder()
.setName(taskName)
.setTaskOutcome(TaskOutcome.SUCCEEDED)
.setTaskOutcomeTime(now())
.setTaskOutcomeLocation( // Grand Indonesia East Mall
LocationInfo.newBuilder().setPoint(
LatLng.newBuilder().setLatitude(-6.195139).setLongitude(106.820826)))
.build();
// Task request
UpdateTaskRequest updateTaskRequest =
UpdateTaskRequest.newBuilder() // No need for the header
.setTask(task)
.setUpdateMask(FieldMask.newBuilder().addPaths("task_outcome", "task_outcome_time", "task_outcome_location"))
.build();
try {
Task updatedTask = deliveryService.updateTask(updateTaskRequest);
} 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>/tasks/<id>?updateMask=taskOutcome,taskOutcomeTime,taskOutcomeLocation
- <id> 是工作的專屬 ID。
- 要求標頭必須包含「Authorization」欄位,其值為「Bearer <token>」,其中 <token> 是由伺服器根據「服務帳戶角色」和「JSON Web 權杖」一文中的指南所發出。
- 要求主體必須包含
Task
實體。
# Set JWT, PROJECT_ID, and TASK_ID in the local environment
curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/tasks/${TASK_ID}?updateMask=taskOutcome,taskOutcomeTime,taskOutcomeLocation" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}" \
--data-binary @- << EOM
{
"taskOutcome": "SUCCEEDED",
"taskOutcomeTime": "$(date -u +"%Y-%m-%dT%H:%M:%SZ")",
"taskOutcomeLocation": {
"point": {
"latitude": -6.195139,
"longitude": 106.820826
}
}
}
EOM