Control: 4.5.2 Ensure That Private Endpoints Are Used Where Possible
Description
Private endpoints limit network traffic to approved sources.
For sensitive data, private endpoints allow granular control of which services can communicate with Cosmos DB and ensure that this network traffic is private. You set this up on a case by case basis for each service you wish to be connected.
Remediation
From Azure Portal
- Open the portal menu.
 - Select the Azure Cosmos DB blade.
 - Select the Azure Cosmos DB account.
 - Select 
Networking. - Select 
Private access. - Click 
+ Private Endpoint. - Provide a Name.
 - Click 
Next. - From the Resource type drop down, select 
Microsoft.AzureCosmosDB/databaseAccounts. - From the Resource drop down, select the Cosmos DB account.
 - Click 
Next. - Provide appropriate Virtual Network details.
 - Click 
Next. - Provide appropriate DNS details.
 - Click 
Next. - Optionally provide Tags.
 - Click 
Next:Review + create. - Click 
Create. 
Default Value
By default Cosmos DB does not have private endpoints enabled and its traffic is public to the network.
Usage
Run the control in your terminal:
powerpipe control run azure_compliance.control.cis_v200_4_5_2Snapshot and share results via Turbot Pipes:
powerpipe loginpowerpipe control run azure_compliance.control.cis_v200_4_5_2 --shareSQL
This control uses a named query:
with cosmosdb_private_connection as (  select    distinct a.id  from    azure_cosmosdb_account as a,    jsonb_array_elements(private_endpoint_connections) as connection  where    connection -> 'properties' -> 'privateLinkServiceConnectionState' ->> 'status' = 'Approved')select  a.id as resource,  case    when c.id is null then 'alarm'    else 'ok'  end as status,  case    when c.id is null then a.name || ' not uses private link.'    else a.name || ' uses private link.'  end as reason    , a.resource_group as resource_group  , sub.display_name as subscriptionfrom  azure_cosmosdb_account as a  left join cosmosdb_private_connection as c on c.id = a.id  left join azure_subscription as sub on sub.subscription_id = a.subscription_id;