Commit 47e8a64
committed
fix(x509): handle hex.DecodeString error in FormatOID() instead of discarding
Malformed hex strings in certificate subject fields could previously
produce corrupt decoded output because the error from hex.DecodeString
was discarded with `decoded, _ := ...`. In a compliance ledger this
is a security concern: an attacker-controlled or accidentally truncated
certificate could yield bogus normalized OIDs in indexed fields.
After this fix, malformed entries are skipped and the original (unmodified)
subject value remains in the output, so consumers see the raw OID rather
than a silently-corrupted normalized one.
Adds regression tests to x/pki/x509/x509_test.go that exercise the bug:
- Test_FormatOID_HexDecodeError: 5 cases covering non-hex chars,
odd-length hex, embedded whitespace, mixed valid/invalid OIDs,
and the positive-path regression guard.
- Test_FormatOID_NoCorruptOutput: explicit assertion that the buggy
output pattern ("vid=0x" with empty/null bytes) cannot occur.
These tests fail with the pre-fix code and pass with the fix applied.
Per reviewer feedback: removed unrelated x/audit module changes from
this PR — they will be submitted separately if there's interest.
Signed-off-by: Srikanth Patchava <srpatcha@users.noreply.github.com>1 parent 94b3b50 commit 47e8a64
2 files changed
Lines changed: 87 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
153 | 153 | | |
154 | 154 | | |
155 | 155 | | |
156 | | - | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
157 | 160 | | |
158 | 161 | | |
159 | 162 | | |
| |||
234 | 237 | | |
235 | 238 | | |
236 | 239 | | |
237 | | - | |
| 240 | + | |
238 | 241 | | |
239 | 242 | | |
240 | 243 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
336 | 336 | | |
337 | 337 | | |
338 | 338 | | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
0 commit comments