本指南可協助您確認 Fleet Engine 授權設定已完成,且您可以建立試用車輛。本指南使用 gcloud
指令列公用程式測試授權權杖簽署和車輛建立作業。
如要完成這項程序,請按照下列步驟操作:
- 請將下列欄位替換為您在設定時建立的資料:
欄位 | 替換成 |
---|---|
PROJECT_ID | 您的 Cloud 專案 ID。 |
SERVICE_ACCOUNT_EMAIL_ADDRESS | 您建立的服務帳戶電子郵件地址,該帳戶具有「管理員」角色。詳情請參閱「行動服務帳戶角色」。 |
VEHICLE_ID 或 DELIVERY_VEHICLE_ID |
車輛的隨機 ID。ID 長度上限為 64 個半形字元。 |
使用
gcloud
公用程式登入 Google Cloud 帳戶,並在工作站上設定有效專案:gcloud auth login gcloud config set project PROJECT_ID
建立車輛建立作業的 JSON Web Token (JWT) 斷言:
隨選行程
cat > claim.jwt << EOM { "iss": "SERVICE_ACCOUNT_EMAIL_ADDRESS", "sub": "SERVICE_ACCOUNT_EMAIL_ADDRESS", "aud": "https://fleetengine.googleapis.com/", "iat": $(date +%s), "exp": $((`date +%s` + 3600)), "authorization": { "vehicleid": "VEHICLE_ID" } } EOM
排定的工作
cat > claim.jwt << EOM { "iss": "SERVICE_ACCOUNT_EMAIL_ADDRESS", "sub": "SERVICE_ACCOUNT_EMAIL_ADDRESS", "aud": "https://fleetengine.googleapis.com/", "iat": $(date +%s), "exp": $((`date +%s` + 3600)), "authorization": { "deliveryvehicleid": "DELIVERY_VEHICLE_ID" } } EOM
使用
gcloud
簽署此 JWT,並授予適當的 IAM 權限。:gcloud iam service-accounts sign-jwt claim.jwt output.jwt \ --iam-account=SERVICE_ACCOUNT_EMAIL_ADDRESS
已簽署的 JWT 會儲存在
output.jwt
中。詳情請參閱 Google Cloud 說明文件中的「提供必要權限」和「
gcloud
指令列指南」。使用
curl
在 Fleet Engine 中建立測試車輛:隨選行程
curl -X POST "https://fleetengine.googleapis.com/v1/providers/PROJECT_ID/vehicles?vehicleId=VEHICLE_ID" \ -H "Content-type: application/json" \ -H "Authorization: Bearer $(cat output.jwt)" \ --data-binary @- << EOM { "name": "providers/PROJECT_ID/vehicles/VEHICLE_ID" } EOM { "vehicleState": "OFFLINE", "supportedTripTypes": ["EXCLUSIVE"], "maximumCapacity": 4, "vehicleType": {"category": "AUTO"}, "attributes": [{"key": "on_trip", "value": "false"}] }
這個指令應會將車輛名稱列印為輸出內容。如果看到下列文字,表示設定成功。
{ "name": "providers/PROJECT_ID/vehicles/VEHICLE_ID" }
排定的工作
curl -X POST "https://fleetengine.googleapis.com/v1/providers/PROJECT_ID/deliveryVehicles?deliveryVehicleId=DELIVERY_VEHICLE_ID" \ -H "Content-type: application/json" \ -H "Authorization: Bearer $(cat output.jwt)" \ --data-binary @- << EOM { "name": "providers/PROJECT_ID/deliveryVehicles/DELIVERY_VEHICLE_ID" } EOM
這個指令應會將運送車輛的名稱列印為輸出內容。如果看到下列文字,表示設定成功。
{ "name": "providers/PROJECT_ID/deliveryVehicles/DELIVERY_VEHICLE_ID" }