Este documento pressupõe que você sabe como criar e usar tarefas. Ele fornece exemplos específicos de como concluir tarefas de envio da seguinte forma:
- Fechar uma tarefa: ao fechar uma tarefa de envio, o estado dela muda para - CLOSEDe indica que ela não está mais ativa.
- Defina o resultado da tarefa: depois que uma tarefa é encerrada, finalize-a definindo o resultado como - SUCCEEDEDou- FAILED. Essa é uma parte importante da conclusão de uma tarefa para mostrar o resultado da entrega no compartilhamento de trajeto e garantir o faturamento correto do serviço Fleet Engine.
Fechar uma tarefa
É possível fechar uma tarefa das seguintes maneiras:
- Atualize o status de parada do veículo. Você remove a parada do veículo, o que fecha todas as tarefas associadas a ela. Consulte Atualizar o status de interrupção para mais detalhes.
- Remova a tarefa da lista de paradas do veículo. Isso envolve atualizar a lista de tarefas para a parada, mas com a tarefa concluída não fazendo mais parte da lista. Consulte "Atualizar a ordem das tarefas" em Atualizar tarefas.
- Defina o estado da tarefa como CLOSED. Isso só pode ser feito em tarefas não atribuídas a veículos. Esta seção mostra essa abordagem.
Depois de fechar uma tarefa, não é possível reabri-la.
O encerramento de uma tarefa não indica sucesso ou falha. Isso indica que a tarefa não é mais considerada em andamento. Para indicar o resultado real de uma tarefa e mostrar isso para fins de rastreamento de frota e compartilhamento de trajeto, é necessário indicar o resultado real de uma tarefa. Consulte Definir o resultado da tarefa abaixo.
Campos de tarefa para fechar tarefas
Esta seção documenta os campos obrigatórios a serem definidos ao fechar uma tarefa. O Fleet Engine ignora todos os outros campos na entidade para a atualização.
| Campo obrigatório | Valor | 
|---|---|
| state | State.CLOSED | 
Fechar uma tarefa diretamente
Os exemplos a seguir mostram como definir uma tarefa não atribuída como concluída,
em gRPC ou usando uma chamada de solicitação HTTP REST para 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> é um identificador exclusivo da tarefa.
- O cabeçalho da solicitação precisa conter um campo Authorization com o valor Bearer <token>, em que <token> é emitido pelo seu servidor de acordo com as diretrizes descritas em Funções da conta de serviço e Tokens da Web JSON.
- Inclua uma entidade Taskno corpo da solicitação.
Comando curl de exemplo:
 # 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")"
 }
 EOMDefinir o resultado da tarefa
Para indicar o resultado real de uma tarefa, defina o resultado das tarefas concluídas como SUCCEEDED ou FAILED. Uma tarefa precisa ser concluída antes que você defina o
resultado dela. O Fleet Engine só cobra por tarefas de entrega com o estado SUCCEEDED.
Detalhes do resultado da tarefa
As tarefas também fornecem mais detalhes sobre o resultado. Você pode definir essas configurações diretamente, e o Fleet Engine as respeita:
- Local do resultado da tarefa: o Fleet Engine preenche automaticamente o local do resultado da tarefa com a última localização conhecida do veículo. Se preferir, você pode fornecer isso.
- Horário do resultado da tarefa: o Fleet Engine não preenche esse campo, mas ele está disponível para você definir.
Você pode usar qualquer uma das seguintes abordagens para definir task_outcome_location
e task_outcome_time:
- Atualize-os na mesma solicitação que define o resultado da tarefa.
- Atualize depois, depois de definir o resultado da tarefa.
- Modifique-os novamente depois de definidos.
O Fleet Engine impede as seguintes atualizações relacionadas aos resultados das tarefas:
- Não é possível modificar o resultado de uma tarefa depois que ele é definido como SUCCEEDEDouFAILED.
- Não é possível definir um local ou horário de resultado para tarefas sem um resultado definido.
Campos de tarefa para definir o resultado
Esta seção documenta os campos obrigatórios e opcionais a serem definidos ao definir um resultado de tarefa. O Fleet Engine ignora outros campos na entidade para a atualização.
| Campo obrigatório | Valor | 
|---|---|
| taskOutcome | Outcome.SUCCEEDEDouOutcome.FAILED | 
| Campo opcional | Valor | 
|---|---|
| taskOutcomeLocation | O local em que a tarefa foi concluída. Se não for definido, o Fleet Engine vai usar o último local do veículo. | 
| taskOutcomeTime | O carimbo de data/hora em que a tarefa foi concluída. | 
Exemplos de resultados de tarefas
O exemplo a seguir mostra como usar a biblioteca gRPC Java e uma chamada HTTP
REST para UpdateTask para definir um resultado de tarefa como SUCCEEDED e definir o
local em que a tarefa foi concluída.
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> é um identificador exclusivo da tarefa.
- O cabeçalho da solicitação precisa conter um campo Authorization com o valor Bearer <token>, em que <token> é emitido pelo seu servidor de acordo com as diretrizes descritas em Funções da conta de serviço e Tokens da Web JSON.
- O corpo da solicitação precisa conter uma entidade 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