Это руководство поможет вам убедиться в завершении настройки авторизации Fleet Engine и в возможности создания пробного транспортного средства. В этом руководстве используется утилита командной строки gcloud для проверки подписания токенов авторизации и создания транспортного средства.
Для завершения этого процесса выполните следующие действия:
- Замените поля ниже данными, которые вы создали в процессе настройки:
| Поле | Заменить на |
|---|---|
| PROJECT_ID | Идентификатор вашего облачного проекта. |
| SERVICE_ACCOUNT_EMAIL_ADDRESS | Адрес электронной почты учетной записи службы, созданной вами с ролью администратора. Подробнее см. в разделе «Роли учетных записей служб мобильности» . |
VEHICLE_ID ИЛИ DELIVERY_VEHICLE_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.Подробности см. в разделах «Предоставление необходимых разрешений» и «Руководство по командной строке
gcloudв документации Google Cloud.Используйте
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" }