Accesso sensibile al contesto con regole per il traffico in entrata

Le configurazioni delle regole in entrata di accesso sensibile al contesto consentono l'accesso alle risorse in base ad attributi client come origine della rete (indirizzo IP o rete VPC), tipo di identità (account di servizio o utente), identità e dati del dispositivo. L'accesso è definito dalle regole in entrata.

Per una panoramica delle regole in entrata e in uscita, consulta Regole in entrata e in uscita.

Per istruzioni su come applicare i criteri delle regole in entrata e in uscita, consulta Configurare i criteri per il traffico in entrata e in uscita.

Esempi di configurazione di casi d'uso di accesso sensibile al contesto

Questa sezione contiene i seguenti esempi di accesso sensibile al contesto:

  1. Consenti agli utenti umani di accedere a BigQuery da internet e solo ad account di servizio specifici di un intervallo IP specificato
  2. Consenti ai dipendenti di eseguire query su BigQuery da dispositivi attendibili su internet e da un account di servizio specifico per caricare privatamente i dati in un bucket Cloud Storage (dati di origine)

Consenti agli utenti umani di accedere a BigQuery da internet e solo ad account di servizio specifici da un intervallo IP specificato

In entrata da utenti e reti riconosciuti

Supponi di aver definito il seguente perimetro, trovato elencandolo nell'elenco con gcloud:

name: accessPolicies/222/servicePerimeters/Example
status:
  resources:
  - projects/111
  restrictedServices:
  - bigquery.googleapis.com
  - storage.googleapis.com
  vpcAccessibleServices:
    enableRestriction: true
    allowedServices:
    - RESTRICTED_SERVICES
title: Example

Supponiamo inoltre che sia stato definito un livello di accesso denominato CorpDatacenters. I CorpDatacenters, in questo esempio, sono un intervallo autorizzato di IP di data center aziendali a cui accedono gli account di servizio autorizzati.

Di seguito è riportato il criterio direzionale per consentire a tutti gli utenti e a un insieme specifico di account di servizio, limitato a un determinato insieme di IP (definiti da un livello di accesso):

echo """
- ingressFrom:
    identities:
    - serviceAccount:my-sa@my-project.iam.gserviceaccount.com
    sources:
    - accessLevel: accessPolicies/222/accessLevels/CorpDatacenters
  ingressTo:
    operations:
    - serviceName: bigquery.googleapis.com
      methodSelectors:
      - method: \"*\"
    resources:
    - \"*\"
- ingressFrom:
    identityType: ANY_USER_ACCOUNT
    sources:
    - accessLevel: \"*\"
  ingressTo:
    operations:
    - serviceName: bigquery.googleapis.com
      methodSelectors:
      - method: \"*\"
    resources:
    - \"*\"
""" > ingress.yaml

Applica le regole in entrata eseguendo questo comando:

gcloud access-context-manager perimeters update Example --set-ingress-policies=ingress.yaml

Consenti ai dipendenti di eseguire query su BigQuery e caricare privatamente i dati in un bucket Cloud Storage

In entrata da dispositivi e reti riconosciuti

Supponi di aver definito il seguente perimetro, trovato elencandolo nell'elenco con gcloud:

name: accessPolicies/222/servicePerimeters/Example
status:
  resources:
  - projects/111
  restrictedServices:
  - bigquery.googleapis.com
  - storage.googleapis.com
  vpcAccessibleServices:
    enableRestriction: true
    allowedServices:
    - RESTRICTED_SERVICES
title: Example

Ecco il criterio direzionale per consentire agli utenti di accedere alle viste BigQuery da dispositivi attendibili (utilizzando un livello di accesso) e da un account di servizio specifico privato per accedere a Cloud Storage da una rete VPC autorizzata:

echo """
- ingressFrom:
    identities:
    - serviceAccount:my-sa@my-project.iam.gserviceaccount.com
    sources:
    - resource: projects/111
  ingressTo:
    operations:
    - serviceName: storage.googleapis.com
      methodSelectors:
      - method: google.storage.Write
      - method: google.storage.objects.create
    resources:
    - \"*\"

- ingressFrom:
    identityType: ANY_SERVICE_ACCOUNT
    sources:
      - resource: //compute.googleapis.com/projects/my-network-project/global/networks/top-tier-vpc-network
  ingressTo:
    operations:
    - serviceName: storage.googleapis.com
      methodSelectors:
      - method: google.storage.Write
      - method: google.storage.objects.create
    resources:
    - \"*\"

- ingressFrom:
    identityType: ANY_USER_ACCOUNT
    sources:
    - accessLevel: accessPolicies/222/accessLevels/TrustedDevices
  ingressTo:
    operations:
    - serviceName: bigquery.googleapis.com
      methodSelectors:
      - permission: bigquery.tables.getData
    resources:
    - \"*\"
""" > ingress.yaml

Applica le regole in entrata eseguendo questo comando:

gcloud access-context-manager perimeters update Example --set-ingress-policies=ingress.yaml

Per informazioni sulle limitazioni delle reti VPC quando utilizzi le reti VPC nei perimetri di servizio, consulta Limitazioni delle reti VPC.