gcloud-approved-external-lb: Unapproved External Load Balancers in Google Cloud Projects

日期: 2025-08-01 | 影响软件: gcloud approved external lb | POC: 已公开

漏洞描述

Ensure that your web applications are using only approved external load balancers to comply with your organization's security and industry requirements. Using unapproved load balancers could expose your applications to vulnerabilities. The approved load balancers must be defined in the conformity rule settings, in the Trend Cloud One™ – Conformity account console.

PoC代码[已公开]

id: gcloud-approved-external-lb

info:
  name: Unapproved External Load Balancers in Google Cloud Projects
  author: princechaddha
  severity: medium
  description: |
    Ensure that your web applications are using only approved external load balancers to comply with your organization's security and industry requirements. Using unapproved load balancers could expose your applications to vulnerabilities. The approved load balancers must be defined in the conformity rule settings, in the Trend Cloud One™ – Conformity account console.
  impact: |
    Using unapproved load balancers can expose web applications to potential security vulnerabilities.
  remediation: |
    Ensure all used external load balancers are approved in the Trend Cloud One™ – Conformity account console. Replace unapproved load balancers with approved ones.
  reference:
    - https://cloud.google.com/load-balancing/docs
  tags: cloud,devops,gcp,gcloud,google-cloud-load-balancing,gcp-cloud-config

flow: |
  code(1)
  for(let projectId of iterate(template.projectIds)){
    set("projectId", projectId)
    code(2)
    for(let urlMap of iterate(template.urlMaps)){
      set("urlMap", urlMap)
      code(3)
      for(let targetHttpProxy of iterate(template.targetHttpProxies)){
        set("targetHttpProxy", targetHttpProxy)
        code(4)
        for(let forwardingRule of iterate(template.forwardingRules)){
          code(5)
        }
      }
    }
  }

self-contained: true

code:
  - engine:
      - sh
      - bash
    source: |
      gcloud projects list --format="json(projectId)"

    extractors:
      - type: json
        name: projectIds
        internal: true
        json:
          - '.[].projectId'

  - engine:
      - sh
      - bash
    source: |
      gcloud compute url-maps list --project $projectId --format="json(name)"

    extractors:
      - type: json
        name: urlMaps
        internal: true
        json:
          - '.[].name'

  - engine:
      - sh
      - bash
    source: |
      gcloud compute target-http-proxies list --project $projectId --format="json(name,urlMap)"

    extractors:
      - type: json
        name: targetHttpProxies
        internal: true
        json:
          - '.[] | {name: .name, urlMap: .urlMap}'

  - engine:
      - sh
      - bash
    source: |
      gcloud compute forwarding-rules list --project $projectId --format="json(name,loadBalancingScheme,target)"

    matchers:
      - type: word
        words:
          - 'EXTERNAL_MANAGED'

    extractors:
      - type: dsl
        dsl:
          - '"Unapproved External Load Balancer in project: " + projectId + ", Load Balancer: " + name'
# digest: 490a0046304402202401bdf94f9f0a0cc821d3357a418a63ac6b9f0c3df3465abd39b2e77735334202200e58b2372d24827da28cb6609997e0b799b1ee123cf6fee492753da907c2b096:922c64590222798bb761d5b6d8e72950