google-cloud-platform - GCP API网关返回403,表示托管服务 "is not enabled for the project"

标签 google-cloud-platform openapi google-iam google-api-gateway

尝试访问公共(public)云运行服务,但不确定为什么我不断收到此错误消息 ({"message":"PERMISSION_DENIED:API basic-express-api-1yy1jgrw4nwy2.apigateway.chrome-courage-336400。使用查询字符串中的 API key 访问网关默认主机名路径时,项目未启用 cloud.goog。","code":403})。该配置有一个服务帐户,其角色能够调用云运行服务。所有必需的 API 也已启用。这是link到我的整个代码库,但下面是我的 API Gateway 特定的 terraform 配置。

resource "google_api_gateway_api" "basic_express" {
  depends_on = [google_project_service.api_gateway, google_project_service.service_management, google_project_service.service_control]
  provider   = google-beta
  api_id     = "basic-express-api"
}

resource "google_api_gateway_api_config" "basic_express" {
  depends_on    = [google_project_service.api_gateway, google_project_service.service_management, google_project_service.service_control, google_api_gateway_api.basic_express]
  provider      = google-beta
  api           = google_api_gateway_api.basic_express.api_id
  api_config_id = "basic-express-cfg"
  openapi_documents {
    document {
      path     = "api-configs/openapi-spec-basic-express.yaml"
      contents = filebase64("api-configs/openapi-spec-basic-express.yaml")
    }
  }
  lifecycle {
    create_before_destroy = true
  }
  gateway_config {
    backend_config {
      google_service_account = google_service_account.apig_gateway_basic_express_sa.email
    }
    # https://cloud.google.com/api-gateway/docs/configure-dev-env?&_ga=2.177696806.-2072560867.1640626239#configuring_a_service_account
    # when I added this terraform said that the resource already exists, so I had to tear down all infrastructure and re-provision - also did not make a difference, still getting a 404 error when trying to hit the gateway default hostname endpoint - this resource might be immutable...
  }
}

resource "google_api_gateway_gateway" "basic_express" {
  depends_on = [google_project_service.api_gateway, google_project_service.service_management, google_project_service.service_control, google_api_gateway_api_config.basic_express, google_api_gateway_api.basic_express]
  provider   = google-beta
  api_config = google_api_gateway_api_config.basic_express.id
  gateway_id = "basic-express-gw"
  region     = var.region
}

resource "google_service_account" "apig_gateway_basic_express_sa" {
  account_id = "apig-gateway-basic-express-sa"
  depends_on = [google_project_service.iam]
}
# "Identity to be used by gateway"

resource "google_project_iam_binding" "project" {
  project = var.project_id
  role    = "roles/run.invoker"
  members = [
    "serviceAccount:${google_service_account.apig_gateway_basic_express_sa.email}"
  ]
}
# https://cloud.google.com/api-gateway/docs/configure-dev-env?&_ga=2.177696806.-2072560867.1640626239#configuring_a_service_account

最佳答案

尝试:

PROJECT=[[YOUR-PROJECT]]
SERVICE="basic-express-api-1yy1jgrw4nwy2.apigateway.chrome-courage-336400.cloud.goog"

gcloud services enable ${SERVICE} \
--project=${PROJECT}

关于google-cloud-platform - GCP API网关返回403,表示托管服务 "is not enabled for the project",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70523278/

相关文章:

python - 如何在 Google Cloud Run 中生成 Blob 签名 url?

java - 无法验证服务帐户 - Google Cloud

json - 根据给定的 OpenApi/Swagger 规范验证请求有效负载和响应

maven - 使用 Maven 插件的 OpenAPI 自定义生成器失败并出现 ClassNotFoundException

json - 如何在没有数组的情况下拥有多个无限对象 - Open API/Swagger

kubernetes - 等待集群初始化超时,节点自动升级失败/或运行出错

google-cloud-platform - 未找到 GOOGLE_APPLICATION_CREDENTIALS?

bash - 使用 shell/bash 脚本终止谷歌云计算引擎实例

google-cloud-platform - BigQuery UNNEST 包括空行?

google-cloud-platform - 使用用户帐户凭据访问私有(private) Cloud Run/Cloud Functions