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