-
Notifications
You must be signed in to change notification settings - Fork 91
/
Copy pathear_default_policy.rego
118 lines (100 loc) · 4.08 KB
/
ear_default_policy.rego
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package policy
import rego.v1
# This policy validates multiple TEE platforms
# The policy is meant to capture the TCB requirements
# for confidential containers.
# This policy is used to generate an EAR Appraisal.
# Specifically it generates an AR4SI result.
# More informatino on AR4SI can be found at
# <https://datatracker.ietf.org/doc/draft-ietf-rats-ar4si/>
# For the `executables` trust claim, the value 33 stands for
# "Runtime memory includes executables, scripts, files, and/or
# objects which are not recognized."
default executables := 33
# For the `hardware` trust claim, the value 97 stands for
# "A Verifier does not recognize an Attester's hardware or
# firmware, but it should be recognized."
default hardware := 97
# For the `configuration` trust claim the value 36 stands for
# "Elements of the configuration relevant to security are
# unavailable to the Verifier."
default configuration := 36
##### Sample
# For the `executables` trust claim, the value 3 stands for
# "Only a recognized genuine set of approved executables have
# been loaded during the boot process."
executables := 3 if {
# The sample attester does not report any launch digest.
# This is an example of how a real platform might validate executables.
input.sample.launch_digest in data.reference.launch_digest
}
# For the `hardware` trust claim, the value 2 stands for
# "An Attester has passed its hardware and/or firmware
# verifications needed to demonstrate that these are genuine/
# supported.
hardware := 2 if {
input.sample.svn in data.reference.svn
}
##### SNP
executables := 3 if {
# In the future, we might calculate this measurement here various components
input.snp.launch_measurement in data.reference.snp_launch_measurement
}
hardware := 2 if {
# Check the reported TCB to validate the ASP FW
input.snp.reported_tcb_bootloader in data.reference.snp_bootloader
input.snp.reported_tcb_microcode in data.reference.snp_microcode
input.snp.reported_tcb_snp in data.reference.snp_snp_svn
input.snp.reported_tcb_tee in data.reference.snp_tee_svn
}
# For the 'configuration' trust claim 2 stands for
# "The configuration is a known and approved config."
#
# For this, we compare all the configuration fields.
configuration := 2 if {
input.snp.policy_debug_allowed == 0
input.snp.policy_migrate_ma == 0
input.snp.platform_smt_enabled in data.reference.snp_smt_enabled
input.snp.platform_tsme_enabled in data.reference.snp_tsme_enabled
input.snp.policy_abi_major in data.reference.snp_guest_abi_major
input.snp.policy_abi_minor in data.reference.snp_guest_abi_minor
input.snp.policy_single_socket in data.reference.snp_single_socket
input.snp.policy_smt_allowed in data.reference.snp_smt_allowed
}
# For the `configuration` trust claim 3 stands for
# "The configuration includes or exposes no known
# vulnerabilities."
#
# In this check, we do not specifically check every
# configuration value, but we make sure that some key
# configurations (like debug_allowed) are set correctly.
else := 3 if {
input.snp.policy_debug_allowed == 0
input.snp.policy_migrate_ma == 0
}
##### TDX
executables := 3 if {
# Check the kernel, initrd, and cmdline (including dmverity parameters) measurements
# TODO: add individual CCEL measurements from input.tdx.ccel instead
input.tdx.quote.body.rtmr_1 in data.reference.rtmr_1
input.tdx.quote.body.rtmr_2 in data.reference.rtmr_2
}
hardware := 2 if {
# Check the quote is a TDX quote signed by Intel SGX Quoting Enclave
input.tdx.quote.header.tee_type == "81000000"
input.tdx.quote.header.vendor_id == "939a7233f79c4ca9940a0db3957f0607"
# Check TDX Module version and its hash. Also check OVMF code hash.
input.tdx.quote.body.mr_seam in data.reference.mr_seam
input.tdx.quote.body.tcb_svn in data.reference.tcb_svn
input.tdx.quote.body.mr_td in data.reference.mr_td
}
configuration := 2 if {
# Check the TD has the expected attributes (e.g., debug not enabled)
# and features.
# TODO: split td_attribute bits to their own claims
input.tdx.quote.body.td_attributes in data.reference.td_attributes
input.tdx.quote.body.xfam in data.reference.xfam
}
##### AZ SNP TODO
##### AZ TDX TODO
##### SE TODO