last sync: 2021-Sep-22 19:36:51 UTC

Azure Policy definition

Secrets should have the specified maximum validity period

Name Secrets should have the specified maximum validity period
Azure Portal
Id 342e8053-e12e-4c44-be01-c3c2f318400f
Version 1.0.1
details on versioning
Category Key Vault
Microsoft docs
Description Manage your organizational compliance requirements by specifying the maximum amount of time in days that a secret can be valid within your key vault.
Mode Microsoft.KeyVault.Data
Type BuiltIn
Preview FALSE
Deprecated FALSE
Effect Default: Audit
Allowed: (Audit, Deny, Disabled)
Used RBAC Role none
History
Date/Time (UTC ymd) (i) Change type Change detail
2021-08-30 14:27:30 change Patch, old suffix: preview (1.0.0-preview > 1.0.1)
2020-10-16 12:27:50 add 342e8053-e12e-4c44-be01-c3c2f318400f
Used in Initiatives none
JSON Changes

JSON
{
  "displayName": "Secrets should have the specified maximum validity period",
  "policyType": "BuiltIn",
  "mode": "Microsoft.KeyVault.Data",
  "description": "Manage your organizational compliance requirements by specifying the maximum amount of time in days that a secret can be valid within your key vault.",
  "metadata": {
    "version": "1.0.1",
    "category": "Key Vault"
  },
  "parameters": {
    "maximumValidityInDays": {
      "type": "Integer",
      "metadata": {
        "displayName": "The maximum validity period in days",
        "description": "Specify the maximum number of days a secret can be valid for. Secrets should be ephemeral. Using a secret with a long validity period is not recommended."
      }
    },
    "effect": {
      "type": "String",
      "metadata": {
        "displayName": "Effect",
        "description": "'Audit' allows a non-compliant resource to be created, but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off the policy."
      },
      "allowedValues": [
        "Audit",
        "Deny",
        "Disabled"
      ],
      "defaultValue": "Audit"
    }
  },
  "policyRule": {
    "if": {
      "allOf": [
        {
          "field": "type",
          "equals": "Microsoft.KeyVault.Data/vaults/secrets"
        },
        {
          "anyOf": [
            {
              "field": "Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn",
              "exists": false
            },
            {
              "field": "Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn",
              "greater": "[addDays(field('Microsoft.KeyVault.Data/vaults/secrets/attributes.createdOn'), parameters('maximumValidityInDays'))]"
            }
          ]
        }
      ]
    },
    "then": {
      "effect": "[parameters('effect')]"
    }
  }
}