Commit 8b6d423
authored
PSS: Improve interoperability with optional auto salt length detection during verification (#546)
This PR adds an optional method to automatically detect the salt length
during RSA-PSS signature verification.
Should Fix: #361 and similar situations.
### Problem
The crate currently requires a fixed salt length for PSS verification.
This prevents verification of signatures where the salt length is not
known beforehand, a situation not uncommon in interoperability contexts.
This capability was previously available but was removed in PR #294.
### Solution
This change re-introduces salt length auto-detection as an explicit,
opt-in feature. A new constructor,
`VerifyingKey::new_with_auto_salt_len`, creates a verifier that performs
this detection during verification.
* The change is opt-in and does not affect default behavior.
* It improves interoperability by handling signatures with variable /
unknown salt lengths.
* The salt detection logic is implemented in constant(-ish) time to
resist timing attacks.
### Commit Structure
This PR consists of three commits:
1. **test:** Adds a failing unit test to demonstrate the issue.
2. **feat:** Implements `new_with_auto_salt_len` and re-introduces the
previous detection logic.
3. **fix:** Updates the detection logic to be less prone to timing
attacks.
Because salt length auto-detection is OpenSSL's default, it's likely
that many systems were built without a mechanism to enforce or
communicate a fixed salt length. Without this PR, it was impossible to
reliably use this crate in my current project, and I suspect others face
the same blocker. I've lost quite a bit of time dealing with seemingly
random signature verification failures until I realized the crux of the
problem.1 parent 77b5bc5 commit 8b6d423
File tree
5 files changed
+113
-20
lines changed- src
- algorithms
- pss
5 files changed
+113
-20
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
14 | | - | |
| 14 | + | |
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
| |||
170 | 170 | | |
171 | 171 | | |
172 | 172 | | |
173 | | - | |
| 173 | + | |
174 | 174 | | |
175 | 175 | | |
176 | 176 | | |
| |||
182 | 182 | | |
183 | 183 | | |
184 | 184 | | |
185 | | - | |
186 | 185 | | |
187 | | - | |
188 | | - | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
189 | 191 | | |
190 | 192 | | |
191 | 193 | | |
| |||
227 | 229 | | |
228 | 230 | | |
229 | 231 | | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
230 | 270 | | |
231 | 271 | | |
232 | 272 | | |
233 | | - | |
| 273 | + | |
234 | 274 | | |
235 | 275 | | |
236 | 276 | | |
| |||
252 | 292 | | |
253 | 293 | | |
254 | 294 | | |
255 | | - | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
256 | 299 | | |
257 | 300 | | |
258 | 301 | | |
| |||
281 | 324 | | |
282 | 325 | | |
283 | 326 | | |
284 | | - | |
| 327 | + | |
285 | 328 | | |
286 | 329 | | |
287 | 330 | | |
| |||
307 | 350 | | |
308 | 351 | | |
309 | 352 | | |
310 | | - | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
311 | 357 | | |
312 | 358 | | |
313 | 359 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
51 | 51 | | |
52 | 52 | | |
53 | 53 | | |
54 | | - | |
| 54 | + | |
| 55 | + | |
55 | 56 | | |
56 | 57 | | |
57 | 58 | | |
| |||
66 | 67 | | |
67 | 68 | | |
68 | 69 | | |
69 | | - | |
| 70 | + | |
70 | 71 | | |
71 | 72 | | |
72 | 73 | | |
| |||
84 | 85 | | |
85 | 86 | | |
86 | 87 | | |
87 | | - | |
| 88 | + | |
88 | 89 | | |
89 | 90 | | |
90 | 91 | | |
| |||
101 | 102 | | |
102 | 103 | | |
103 | 104 | | |
104 | | - | |
| 105 | + | |
105 | 106 | | |
106 | 107 | | |
107 | 108 | | |
| |||
134 | 135 | | |
135 | 136 | | |
136 | 137 | | |
137 | | - | |
| 138 | + | |
138 | 139 | | |
139 | 140 | | |
140 | 141 | | |
| |||
149 | 150 | | |
150 | 151 | | |
151 | 152 | | |
152 | | - | |
| 153 | + | |
153 | 154 | | |
154 | 155 | | |
155 | 156 | | |
| |||
261 | 262 | | |
262 | 263 | | |
263 | 264 | | |
| 265 | + | |
264 | 266 | | |
265 | 267 | | |
266 | 268 | | |
| |||
622 | 624 | | |
623 | 625 | | |
624 | 626 | | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
| 630 | + | |
| 631 | + | |
| 632 | + | |
| 633 | + | |
| 634 | + | |
| 635 | + | |
| 636 | + | |
| 637 | + | |
| 638 | + | |
| 639 | + | |
| 640 | + | |
| 641 | + | |
| 642 | + | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
625 | 662 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
219 | 219 | | |
220 | 220 | | |
221 | 221 | | |
222 | | - | |
| 222 | + | |
223 | 223 | | |
224 | 224 | | |
225 | 225 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
251 | 251 | | |
252 | 252 | | |
253 | 253 | | |
254 | | - | |
| 254 | + | |
255 | 255 | | |
256 | 256 | | |
257 | 257 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
27 | 27 | | |
28 | 28 | | |
29 | 29 | | |
30 | | - | |
| 30 | + | |
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
| |||
45 | 45 | | |
46 | 46 | | |
47 | 47 | | |
48 | | - | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
49 | 59 | | |
50 | 60 | | |
51 | 61 | | |
52 | 62 | | |
53 | 63 | | |
54 | | - | |
| 64 | + | |
55 | 65 | | |
56 | 66 | | |
57 | 67 | | |
| |||
0 commit comments