π§ Azure Non-RBAC Key Vault stores Keys without expiration date - prod.logic.yaml π’
- Contextual name: π§ prod.logic.yaml π’
- ID:
/ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml
- Located in: π Azure Non-RBAC Key Vault stores Keys without expiration date π’
Flagsβ
- π’ Logic test success
- π’ Logic with extracts
- π’ Logic with test data
Input Typeβ
Type | API Name | Extracts | Extract Files | Logic Files | |
---|---|---|---|---|---|
π | π Azure Key Vault | CA10__CaAzureKeyVault__c | 3 | 1 | 8 |
Usesβ
- π Azure Key Vault - object.extracts.yaml
- π Azure Key Vault Key - object.extracts.yaml
- π§ͺ test-data.json
Test Results π’β
Generated at: 2025-04-24T23:45:23.296101988Z Open
Result | Id | Condition Index | Condition Text | Runtime Error |
---|---|---|---|---|
π’ | test1 | βοΈ 99 | βοΈ isDisappeared(CA10__disappearanceTime__c) | βοΈ null |
π’ | test2 | βοΈ 199 | βοΈ extract('CA10__rbacAuthorization__c') == 'Enabled' | βοΈ null |
π’ | test3 | βοΈ 299 | βοΈ CA10__Azure_Key_Vault_Keys__r.has(INCOMPLIANT) | βοΈ null |
π’ | test4 | βοΈ 399 | βοΈ CA10__Azure_Key_Vault_Keys__r.has(COMPLIANT) | βοΈ null |
π’ | test5 | βοΈ 499 | βοΈ CA10__Azure_Key_Vault_Keys__r.has(INAPPLICABLE) | βοΈ null |
π’ | test6 | βοΈ 500 | βοΈ otherwise | βοΈ null |
Generationβ
File | MD5 | |
---|---|---|
Open | /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/policy.yaml | F1F600D6113EFD2A75ABE2709F2B486D |
Open | /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml | EDBCB1D5172B31ED965E7C471D2127AD |
Open | /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/test-data.json | 459DA43CD4A02BF66DC846A418580595 |
Open | /types/CA10__CaAzureKeyVault__c/object.extracts.yaml | 6C8158AF4E8A90E532020A68611A20C7 |
Open | /types/CA10__CaAzureKeyVaultKey__c/object.extracts.yaml | 06CA2E249D85942230AC96CBEE906A4E |
Generate FULL scriptβ
java -jar repo-manager.jar policies generate FULL /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml
Generate DEBUG scriptβ
java -jar repo-manager.jar policies generate DEBUG /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml
Generate CAPTURE_TEST_DATA scriptβ
java -jar repo-manager.jar policies generate CAPTURE_TEST_DATA /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml
Generate TESTS scriptβ
java -jar repo-manager.jar policies generate TESTS /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml
Execute testsβ
java -jar repo-manager.jar policies test /ce/ca/azure/key-vault/non-rbac-key-vault-keys-expiration-date/prod.logic.yaml
Contentβ
---
inputType: "CA10__CaAzureKeyVault__c"
importExtracts:
- file: "/types/CA10__CaAzureKeyVault__c/object.extracts.yaml"
testData:
- file: "test-data.json"
conditions:
- status: "INAPPLICABLE"
currentStateMessage: "This is an RBAC Key Vault."
check:
IS_EQUAL:
left:
EXTRACT: "CA10__rbacAuthorization__c"
right:
TEXT: "Enabled"
- status: "INCOMPLIANT"
currentStateMessage: "The Key Vault has Keys without expiration date."
remediationMessage: "Consider setting the Keys' expiration date."
check:
RELATED_LIST_HAS:
relationshipName: CA10__Azure_Key_Vault_Keys__r
status: "INCOMPLIANT"
- status: "COMPLIANT"
currentStateMessage: "The Key Vault Keys' expiration date is set for all enabled Keys."
check:
RELATED_LIST_HAS:
relationshipName: CA10__Azure_Key_Vault_Keys__r
status: "COMPLIANT"
- status: "INAPPLICABLE"
currentStateMessage: "The Key Vault only has disabled Keys."
check:
RELATED_LIST_HAS:
relationshipName: CA10__Azure_Key_Vault_Keys__r
status: "INAPPLICABLE"
otherwise:
status: "UNDETERMINED"
currentStateMessage: "The Key Vault doesn't have Keys or Cloudaware doesn't have access to view Keys."
relatedLists:
- relationshipName: CA10__Azure_Key_Vault_Keys__r
importExtracts:
- file: "/types/CA10__CaAzureKeyVaultKey__c/object.extracts.yaml"
conditions:
- status: "INAPPLICABLE"
currentStateMessage: "The Key is disabled."
check:
NOT_EQUAL:
left:
EXTRACT: "CA10__enabledStatus__c"
right:
TEXT: "Enabled"
- status: "INCOMPLIANT"
currentStateMessage: "The Key expiration date is not set."
remediationMessage: "Consider setting the Key expiration date."
check:
IS_EMPTY:
arg:
EXTRACT: "CA10__expirationDate__c"
- status: "COMPLIANT"
currentStateMessage: "The Key expiration date is set."
check:
NOT_EMPTY:
arg:
EXTRACT: "CA10__expirationDate__c"
otherwise:
status: "UNDETERMINED"
currentStateMessage: "Unexpected values in the fields."