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

Это руководство поможет вам убедиться в завершении настройки авторизации 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"
        }
        

Что дальше?