Enforce encrypted Storage connections#
Security · Storage Account · Rule · 2020_06 · Important
Storage accounts should only accept encrypted connections.
Description#
Azure Storage Accounts can be configured to allow unencrypted connections. Unencrypted communication could allow disclosure of information to an un-trusted party. Storage Accounts can be configured to require encrypted connections.
To do this set the Secure transfer required option. When secure transfer required is enabled, attempts to connect to storage using HTTP or unencrypted SMB connections are rejected.
Storage Accounts that are deployed with a newer API version will have this option enabled by default. However, this does not prevent the option from being disabled.
Recommendation#
Storage accounts should only accept secure traffic. Consider only accepting encrypted connections by setting the Secure transfer required option. Also consider using Azure Policy to audit or enforce this configuration.
Examples#
Configure with Azure template#
To deploy Storage Accounts that pass this rule:
- For API versions older then 2019-04-01, set the
properties.supportsHttpsTrafficOnly
property totrue
. - For API versions 2019-04-01 and newer:
- Omit the
properties.supportsHttpsTrafficOnly
property OR - Explicitly set the
properties.supportsHttpsTrafficOnly
property totrue
.
- Omit the
For example:
{
"type": "Microsoft.Storage/storageAccounts",
"apiVersion": "2023-01-01",
"name": "[parameters('name')]",
"location": "[parameters('location')]",
"sku": {
"name": "Standard_GRS"
},
"kind": "StorageV2",
"properties": {
"allowBlobPublicAccess": false,
"supportsHttpsTrafficOnly": true,
"minimumTlsVersion": "TLS1_2",
"accessTier": "Hot",
"allowSharedKeyAccess": false,
"networkAcls": {
"defaultAction": "Deny"
}
}
}
Configure with Bicep#
To deploy Storage Accounts that pass this rule:
- For API versions older then 2019-04-01, set the
properties.supportsHttpsTrafficOnly
property totrue
. - For API versions 2019-04-01 and newer:
- Omit the
properties.supportsHttpsTrafficOnly
property OR - Explicitly set the
properties.supportsHttpsTrafficOnly
property totrue
.
- Omit the
For example:
resource storageAccount 'Microsoft.Storage/storageAccounts@2023-01-01' = {
name: name
location: location
sku: {
name: 'Standard_GRS'
}
kind: 'StorageV2'
properties: {
allowBlobPublicAccess: false
supportsHttpsTrafficOnly: true
minimumTlsVersion: 'TLS1_2'
accessTier: 'Hot'
allowSharedKeyAccess: false
networkAcls: {
defaultAction: 'Deny'
}
}
}
Configure with Azure Verified Modules
A pre-built module is avilable on the Azure Bicep public registry. To reference the module, please use the following syntax:
Configure with Azure Policy#
To address this issue at runtime use the following policies:
- Secure transfer to storage accounts should be enabled
/providers/Microsoft.Authorization/policyDefinitions/404c3081-a854-4457-ae30-26a93ef643f9
- Configure secure transfer of data on a storage account
/providers/Microsoft.Authorization/policyDefinitions/f81e3117-0093-4b17-8a60-82363134f0eb
Links#
- SE:07 Encryption
- Require secure transfer in Azure Storage
- DP-3: Encrypt sensitive data in transit
- Sample policy for ensuring https traffic
- Azure deployment reference