Commit 2215a4e
windows: re-verify NCRYPT_UI_POLICY before every sign and decrypt (#62)
* windows: re-verify NCRYPT_UI_POLICY before every sign and decrypt
The UI policy (NCRYPT_UI_PROTECT_KEY_FLAG) is set on CNG keys once,
at key-creation time, via set_ui_policy. If an attacker with write
access to the user's CNG key store pre-plants a key under the same
name but without the UI_PROTECT_KEY_FLAG, the app would open and
sign with that key — and because Windows Hello only fires when the
flag is set, the prompt never comes up and the intended
user-presence gate is bypassed. The flag is the only CNG-side
defense; nothing else makes the hardware require biometrics.
Add ui_policy::verify_ui_policy_matches that reads the key's actual
NCRYPT_UI_POLICY via NCryptGetProperty and compares
UI_PROTECT_KEY_FLAG against the metadata's AccessPolicy. Called from
both TpmSigner::sign and TpmEncryptor::decrypt right after
open_key. A policy mismatch returns Error::KeyOperation and the
sign/decrypt is aborted before any TPM operation happens.
Threat-model section on NCRYPT UI policy rewritten to describe the
new runtime check.
* Fix Windows types in verify_ui_policy_matches
Three type-mismatch errors caught by Windows CI:
- NCRYPT_UI_POLICY.dwFlags is u32, not NCRYPT_FLAGS (set_ui_policy
was already using u32 correctly; only the new function got it
wrong).
- NCryptGetProperty's dwflags parameter is OBJECT_SECURITY_INFORMATION,
not NCRYPT_FLAGS. Pass OBJECT_SECURITY_INFORMATION(0) for no-flags.
- NCRYPT_UI_PROTECT_KEY_FLAG is a bare u32 constant, not a
newtype-wrapped flag. Bitwise-AND it directly; no .0 accessor.
Add Win32_Security to the windows crate feature list because
OBJECT_SECURITY_INFORMATION lives in Win32::Security, not in the
already-enabled Win32_Security_Cryptography.
* Rewrite UI-policy check as bool comparison to silence match_same_arms
---------
Co-authored-by: Jay Gowdy <jay@gowdy.me>1 parent 7c22610 commit 2215a4e
File tree
5 files changed
+113
-2
lines changed- crates/enclaveapp-windows/src
5 files changed
+113
-2
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
63 | 63 | | |
64 | 64 | | |
65 | 65 | | |
66 | | - | |
| 66 | + | |
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
79 | 79 | | |
80 | 80 | | |
81 | 81 | | |
82 | | - | |
| 82 | + | |
83 | 83 | | |
84 | 84 | | |
85 | 85 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
202 | 202 | | |
203 | 203 | | |
204 | 204 | | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
205 | 217 | | |
206 | 218 | | |
207 | 219 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
124 | 124 | | |
125 | 125 | | |
126 | 126 | | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
127 | 142 | | |
128 | 143 | | |
129 | 144 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
13 | 14 | | |
14 | 15 | | |
15 | 16 | | |
| |||
54 | 55 | | |
55 | 56 | | |
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 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
0 commit comments