nuclei-templates/cloud/azure/cosmosdb/azure-cosmosdb-default-netw...

59 lines
2.2 KiB
YAML

id: azure-cosmosdb-default-network-access-unrestricted
info:
name: Azure Cosmos DB Default Network Access Unrestricted
author: princechaddha
severity: medium
description: |
Ensure that your Azure Cosmos DB accounts are configured to deny access to traffic from all networks, including the public Internet. By restricting the public access to your Azure Cosmos DB accounts, you add an additional layer of security to the account resources, as the default action is to accept requests from any source. To limit access to trusted networks and/or IP addresses only, you must update the firewall and the virtual network configuration for your Cosmos DB accounts.
impact: |
Not restricting default network access can expose Azure Cosmos DB accounts to potential unauthorized access and security vulnerabilities from the public Internet.
remediation: |
Update the firewall settings and enable Virtual Network filtering on your Azure Cosmos DB accounts to restrict access to trusted networks and IP addresses only.
reference:
- https://docs.microsoft.com/en-us/azure/cosmos-db/how-to-configure-firewall-vnet
tags: cloud,devops,azure,microsoft,cosmosdb,azure-cloud-config
flow: |
code(1);
for (let CosmosDBData of iterate(template.cosmosDBAccounts)) {
set("id", CosmosDBData);
code(2);
}
self-contained: true
code:
- engine:
- sh
- bash
source: |
az cosmosdb list --query '[*].id' --output json
extractors:
- type: json
name: cosmosDBAccounts
internal: true
json:
- '.[]'
- engine:
- sh
- bash
source: |
az cosmosdb show --ids $id --query '{"ipRules":ipRules,"isVirtualNetworkFilterEnabled":isVirtualNetworkFilterEnabled}' --output json
matchers-condition: and
matchers:
- type: word
words:
- '"isVirtualNetworkFilterEnabled": false'
- type: word
words:
- '"ipRules": []'
- '"ipRules": null'
extractors:
- type: dsl
dsl:
- 'id + " is unrestricted with default network access"'
# digest: 4a0a00473045022006b1d80bb61d8cf42efe59a7608b919ca1629e977819de232bc9267154215b59022100ea01fef4138cb97d594c770c6b72669cdb0b4bafec4b04d0cd0816470d640fa4:922c64590222798bb761d5b6d8e72950