Commit 6620670
committed
feat: 2-arg Access errors on header_enabled=true configurations
Per design decision 2026-05-17, the two-argument Access(value, name) is
for header_enabled=false configurations only — it treats the input as
raw headerless ciphertext. For headered configurations, the header
itself identifies the configuration, so Access(value) is the right call.
Previously Access(value, name) silently stripped the header on the
explicit path, which made the API ambiguous (callers couldn't tell
whether the value they passed had a header or not). Now it throws
ArgumentException so callers can fix the call site instead of seeing
garbage decrypts.
Implementation: Access(value, name) now checks HeaderEnabled and
throws before dispatching. AccessByHeader strips the header itself
and passes raw ciphertext to AccessFpe, which no longer takes an
explicitConfiguration flag and always assumes its input is headerless.
The strip therefore happens exactly once and only on the header path.
Added TwoArgAccessOnHeaderedConfigRaises; README clarifies that the
two-arg form is only valid for header_enabled=false configurations.
36 tests pass.1 parent 7418155 commit 6620670
3 files changed
Lines changed: 33 additions & 8 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
44 | 50 | | |
45 | 51 | | |
46 | 52 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
76 | 76 | | |
77 | 77 | | |
78 | 78 | | |
79 | | - | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
80 | 83 | | |
81 | 84 | | |
82 | 85 | | |
| |||
90 | 93 | | |
91 | 94 | | |
92 | 95 | | |
93 | | - | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
94 | 99 | | |
95 | 100 | | |
96 | 101 | | |
| |||
127 | 132 | | |
128 | 133 | | |
129 | 134 | | |
130 | | - | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
131 | 139 | | |
132 | 140 | | |
133 | 141 | | |
134 | 142 | | |
135 | 143 | | |
136 | 144 | | |
137 | 145 | | |
138 | | - | |
139 | | - | |
140 | | - | |
141 | | - | |
142 | | - | |
| 146 | + | |
143 | 147 | | |
144 | 148 | | |
145 | 149 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
134 | 134 | | |
135 | 135 | | |
136 | 136 | | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
137 | 152 | | |
138 | 153 | | |
0 commit comments