完成工作

本文假設您已瞭解如何建立及使用工作。並提供以下具體範例,說明如何完成出貨工作:

  • 關閉工作:關閉出貨工作後,狀態會變更為 CLOSED,表示該工作已失效。

  • 設定工作結果:工作關閉後,您可以將工作結果設為 SUCCEEDEDFAILED 以完成工作。這是完成工作的重要環節,可在分享歷程中顯示提交結果,並確保 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

設定工作結果

如要表示工作的實際結果,請將已關閉工作的結果設為 SUCCEEDEDFAILED。您必須先關閉工作,才能設定其結果。Fleet Engine 只會針對狀態為 SUCCEEDED 的提交工作收費。

工作結果詳細資料

工作也會提供工作結果的其他詳細資料。您可以直接進行設定,Fleet Engine 會遵循您的設定:

  • 工作結果位置:Fleet Engine 會自動在工作結果位置填入最後已知車輛位置。您可以自行提供這項資訊。
  • 工作結果時間:Fleet Engine 不會填入這個欄位,但您可以自行設定。

您可以使用下列任一方法設定 task_outcome_locationtask_outcome_time

  • 在設定工作結果的相同要求中進行更新
  • 設定工作結果後,稍後再更新
  • 設定完成後,請再次修改

Fleet Engine 會防止下列與工作結果相關的更新:

  • 工作結果一旦設為 SUCCEEDEDFAILED,即無法修改
  • 在沒有設定結果的情況下,您無法為工作設定工作結果位置或結果時間

設定結果的工作欄位

本節說明設定工作結果時,需要設定的必填欄位和選填欄位。Fleet Engine 會忽略實體中的其他欄位以進行更新。

必填欄位
taskOutcome Outcome.SUCCEEDEDOutcome.FAILED

選填欄位
taskOutcomeLocation 工作完成的位置。如未設定,Fleet Engine 會預設為最後的車輛位置。
taskOutcomeTime 工作完成時的時間戳記。

任務結果範例

以下範例說明如何使用 Java gRPC 程式庫以及對 UpdateTask 的 HTTP REST 呼叫,將工作結果設定為 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

  • &lt;id&gt; 是工作的專屬 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

後續步驟