Проверьте настройки

Это руководство поможет вам проверить, что настройка авторизации Fleet Engine завершена, и вы можете создать пробный автомобиль. В этом руководстве используется утилита командной строки gcloud для проверки подписи токена авторизации и создания автомобиля.

Чтобы завершить этот процесс, выполните следующие действия:

  1. Замените поля ниже данными, которые вы создали в ходе настройки:
Поле Заменить на
PROJECT_ID Идентификатор вашего облачного проекта.
SERVICE_ACCOUNT_EMAIL_ADDRESS Адрес электронной почты учётной записи сервиса, созданной вами с ролью администратора. Подробнее см. в разделе «Роли учётных записей сервиса мобильности» .

VEHICLE_ID

ИЛИ

DELIVERY_VEHICLE_ID

Случайный идентификатор транспортного средства. Идентификатор может содержать не более 64 символов.
  1. Используйте утилиту gcloud для входа в учетную запись Google Cloud и установки активного проекта на вашей рабочей станции:

    gcloud auth login
    gcloud config set project PROJECT_ID
    
  2. Создайте заявку 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
        
  3. Используйте 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.

  4. Используйте 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"
        }
        

Что дальше?