Control: 6.5 Ensure That Cloud SQL Database Instances Do Not Implicitly Whitelist All Public IP Addresses
Description
Database Server should accept connections only from trusted Network(s)/IP(s) and restrict access from public IP addresses.
To minimize attack surface on a Database server instance, only trusted/known and required IP(s) should be white-listed to connect to it.
An authorized network should not have IPs/networks configured to 0.0.0.0/0 which will allow access to the instance from anywhere in the world. Note that authorized networks apply only to instances with public IPs.
Remediation
From Google Cloud Console
Go to the Cloud SQL Instances page in the Google Cloud Console by visiting https://console.cloud.google.com/sql/instances.
Click the instance name to open its
Instance detailspage.Under the
Configurationsection clickEdit configurations.Under
Configuration optionsexpand theConnectivitysection.Click the
deleteicon for the authorized network0.0.0.0/0.Click
Saveto update the instance.
From Google Cloud CLI
Update the authorized network list by dropping off any addresses.
gcloud sql instances patch <INSTANCE_NAME> --authorized-networks=IP_ADDR1,IP_ADDR2...
Prevention:
To prevent new SQL instances from being configured to accept incoming connections from any IP addresses, set up a Restrict Authorized Networks on Cloud SQL instances Organization Policy at: https://console.cloud.google.com/iam-admin/orgpolicies/sql-restrictAuthorizedNetworks.
Default Value
By default, authorized networks are not configured. Remote connection to Cloud SQL database instance is not possible unless authorized networks are configured.
Usage
Run the control in your terminal:
powerpipe control run gcp_compliance.control.cis_v400_6_5Snapshot and share results via Turbot Pipes:
powerpipe loginpowerpipe control run gcp_compliance.control.cis_v400_6_5 --shareSQL
This control uses a named query:
select self_link as resource, case when exists ( select 1 from jsonb_array_elements(ip_configuration -> 'authorizedNetworks') as authNet where authNet ->> 'value' = '0.0.0.0/0' or authNet ->> 'value' = '::/0' ) then 'alarm' else 'ok' end as status, case when exists ( select 1 from jsonb_array_elements(ip_configuration -> 'authorizedNetworks') as authNet where authNet ->> 'value' = '0.0.0.0/0' or authNet ->> 'value' = '::/0' ) then title || ' is open to the internet.' else title || ' is not open to the internet.' end as reason , location as location, project as projectfrom gcp_sql_database_instance;