Json |
{
"properties": {
"displayName": "Resource logs in Virtual Machine Scale Sets should be enabled",
"policyType": "BuiltIn",
"mode": "Indexed",
"description": "It is recommended to enable Logs so that activity trail can be recreated when investigations are required in the event of an incident or a compromise.",
"metadata": {
"version": "2.0.1",
"category": "Compute"
},
"parameters": {
"effect": {
"type": "String",
"metadata": {
"displayName": "Effect",
"description": "Enable or disable the execution of the policy"
},
"allowedValues": [
"AuditIfNotExists",
"Disabled"
],
"defaultValue": "AuditIfNotExists"
},
"includeAKSClusters": {
"type": "Boolean",
"metadata": {
"displayName": "Include AKS Clusters",
"description": "Whether to include AKS Clusters to resource logs extension - True or False"
},
"defaultValue": false
}
},
"policyRule": {
"if": {
"anyOf": [
{
"allOf": [
{
"field": "type",
"equals": "Microsoft.Compute/virtualMachineScaleSets"
},
{
"value": "[parameters('includeAKSClusters')]",
"equals": true
}
]
},
{
"allOf": [
{
"field": "type",
"equals": "Microsoft.Compute/virtualMachineScaleSets"
},
{
"value": "[parameters('includeAKSClusters')]",
"equals": false
},
{
"field": "Microsoft.Compute/imagePublisher",
"notEquals": "microsoft-aks"
},
{
"field": "Microsoft.Compute/imageOffer",
"notEquals": "aks"
},
{
"field": "Microsoft.Compute/imageSKU",
"notLike": "aks*"
}
]
}
]
},
"then": {
"effect": "[parameters('effect')]",
"details": {
"type": "Microsoft.Compute/virtualMachineScaleSets/extensions",
"existenceCondition": {
"anyOf": [
{
"allOf": [
{
"field": "Microsoft.Compute/virtualMachineScaleSets/extensions/type",
"equals": "IaaSDiagnostics"
},
{
"field": "Microsoft.Compute/virtualMachineScaleSets/extensions/publisher",
"equals": "Microsoft.Azure.Diagnostics"
}
]
},
{
"allOf": [
{
"field": "Microsoft.Compute/virtualMachineScaleSets/extensions/type",
"equals": "LinuxDiagnostic"
},
{
"field": "Microsoft.Compute/virtualMachineScaleSets/extensions/publisher",
"in": [
"Microsoft.OSTCExtensions",
"Microsoft.Azure.Diagnostics"
]
}
]
}
]
}
}
}
}
},
"id": "/providers/Microsoft.Authorization/policyDefinitions/7c1b1214-f927-48bf-8882-84f0af6588b1",
"type": "Microsoft.Authorization/policyDefinitions",
"name": "7c1b1214-f927-48bf-8882-84f0af6588b1"
}
|