Bu belgede, görev oluşturma ve kullanma konusunda bilgi sahibi olduğunuz varsayılır. Aşağıda, gönderim görevlerinin nasıl tamamlanacağıyla ilgili belirli örnekler verilmiştir:
Görevi kapatma: Bir kargo görevini kapattığınızda görevin durumu
CLOSED
olarak değişir ve bu görevin artık etkin olmadığı belirtilir.Görevin sonucunu ayarlama: Bir görev kapatıldıktan sonra sonucunu
SUCCEEDED
veyaFAILED
olarak ayarlayarak görevi tamamlarsınız. Bu, yolculuk paylaşımında teslimat sonucunu göstermek ve Fleet Engine hizmeti için doğru faturalandırma sağlamak amacıyla bir görevi tamamlama sürecinin önemli bir parçasıdır.
Görevi kapatma
Bir görevi aşağıdaki şekillerde kapatabilirsiniz:
- Aracın durdurma durumunu güncelleyin. Aracın durdurulmasını kaldırdığınızda durdurmayla ilişkili tüm görevler kapatılır. Ayrıntılar için Güncellemeyi durdurma durumuna bakın.
- Görevi araç durakları listesinden kaldırın. Bu işlem, durakla ilgili görev listesini güncelleme ancak tamamlanan görevi listeden çıkarma anlamına gelir. Görevleri güncelleme bölümündeki "Görev sırasını güncelleme" başlıklı makaleyi inceleyin.
- Görev durumunu
CLOSED
olarak ayarlayın. Bu işlem yalnızca araçlara atanmamış görevlerde yapılabilir. Bu bölümde bu yaklaşım gösterilmektedir.
Kapattığınız görevleri yeniden açamazsınız.
Bir görevin kapatılması, görevin başarılı veya başarısız olduğunu göstermez. Bu, görevin artık devam ediyor olarak kabul edilmediğini gösterir. Bir görevin gerçek sonucunu belirtmek ve bu sonucun filo takibi ile yolculuk paylaşımı amacıyla gösterilmesini sağlamak için görevin gerçek sonucunu belirtmeniz gerekir. Aşağıdaki Görevin sonucunu ayarlama bölümünü inceleyin.
Görevleri kapatmak için görev alanları
Bu bölümde, bir görevi kapatırken ayarlanması gereken alanlar açıklanmaktadır. Filo motoru, güncelleme için öğedeki diğer tüm alanları yoksayar.
Zorunlu alan | Değer |
---|---|
state |
State.CLOSED |
Görevi doğrudan kapatma
Aşağıdaki örneklerde, atanmamış bir görevin gRPC'de veya UpdateTask
için HTTP REST istek çağrısı kullanılarak nasıl kapalı duruma ayarlanacağı gösterilmektedir.
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>, görevin benzersiz tanımlayıcısıdır.
- İstek başlığında, Authorization alanı ve Bearer <token> değeri bulunmalıdır. Burada <token>, Hizmet hesabı rolleri ve JSON Web jetonları bölümünde açıklanan yönergelere göre sunucunuz tarafından verilir.
- İstek metnine bir
Task
öğesi eklemeniz gerekir.
Örnek curl
komutu:
# 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
Görevin sonucunu ayarlama
Bir görevin gerçek sonucunu belirtmek için kapalı görevlerin sonucunu SUCCEEDED
veya FAILED
olarak ayarlarsınız. Bir görevin sonucunu belirlemeden önce görevi kapatmanız gerekir. Fleet Engine yalnızca SUCCEEDED
durumundaki teslimat görevleri için ücret alır.
Görev sonucu ayrıntıları
Görevler, görev sonucu hakkında ek ayrıntılar da sağlar. Bunları doğrudan ayarlayabilirsiniz ve Fleet Engine, ayarlarınıza uyar:
- Görev sonucu konumu: Fleet Engine, görev sonucu konumunu bilinen son araç konumuyla otomatik olarak doldurur. Dilerseniz bunun yerine bu bilgiyi sağlayabilirsiniz.
- Görev sonucu zamanı: Fleet Engine bu alanı doldurmaz ancak bu alanı ayarlayabilirsiniz.
task_outcome_location
ve task_outcome_time
değerlerini ayarlamak için aşağıdaki yaklaşımlardan herhangi birini kullanabilirsiniz:
- Bunları, görev sonucunu belirleyen aynı istekte güncelleyin.
- Görev sonucunu belirledikten sonra güncelleyebilirsiniz.
- Ayarladıktan sonra tekrar değiştirebilirsiniz.
Fleet Engine, görev sonuçlarıyla ilgili aşağıdaki güncellemeleri engeller:
- Bir görev sonucu
SUCCEEDED
veyaFAILED
olarak ayarlandıktan sonra değiştirilemez. - Sonucu belirlenmemiş görevler için görev sonucu konumu veya sonucu zamanı ayarlayamazsınız.
Sonucu ayarlamak için görev alanları
Bu bölümde, görev sonucu ayarlanırken belirlenmesi gereken zorunlu ve isteğe bağlı alanlar açıklanmaktadır. Fleet Engine, güncelleme için öğedeki diğer alanları yoksayar.
Zorunlu alan | Değer |
---|---|
taskOutcome |
Outcome.SUCCEEDED veya Outcome.FAILED |
İsteğe bağlı alan | Değer |
---|---|
taskOutcomeLocation |
Görevin tamamlandığı konum. Ayarlanmazsa Fleet Engine, bunu varsayılan olarak son araç konumuna ayarlar. |
taskOutcomeTime |
Görevin tamamlandığı zaman damgası. |
Görev sonucu örnekleri
Aşağıdaki örnekte, Java gRPC kitaplığı ve bir HTTP REST çağrısı kullanılarak UpdateTask
ile görev sonucunun SUCCEEDED
olarak ayarlanması ve görevin tamamlandığı konumun nasıl ayarlanacağı gösterilmektedir.
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>, görevin benzersiz tanımlayıcısıdır.
- İstek başlığında, Authorization alanı ve Bearer <token> değeri bulunmalıdır. Burada <token>, Hizmet hesabı rolleri ve JSON Web jetonları bölümünde açıklanan yönergelere göre sunucunuz tarafından verilir.
- İstek metni bir
Task
öğesi içermelidir.
# 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