Commit 4f2a96f
authored
Support distinct null and absent payload properties (#3646)
To support PATCH-style API semantics, we need to be able to distinguish between
a payload property being absent from the incoming JSON (in which case the existing
value should be left as is) and the property being present with a value of `null`
(in which case the client is asking us to remove the existing value).
Jackson supports using the Java `Optional` class to distinguish those two cases,
but it's a little cumbersome out of the box; add an extension method to simplify
using it for PATCH-style operations.
The distinction between "not required" and "can be null" needs to be reflected
in the OpenAPI schema as well. We could do it by adding `@Schema(nullable = true)`
to payload properties, but that'll add a lot of noise, so instead add logic to
automatically mark all `Optional` payload properties as allowing null values.1 parent e4fbbff commit 4f2a96f
File tree
2 files changed
+47
-0
lines changed- src/main/kotlin/com/terraformation/backend
- api
- util
2 files changed
+47
-0
lines changedLines changed: 10 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
18 | 18 | | |
19 | 19 | | |
20 | 20 | | |
| 21 | + | |
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
24 | 25 | | |
| 26 | + | |
25 | 27 | | |
26 | 28 | | |
27 | 29 | | |
28 | 30 | | |
| 31 | + | |
29 | 32 | | |
30 | 33 | | |
31 | 34 | | |
| |||
157 | 160 | | |
158 | 161 | | |
159 | 162 | | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
160 | 170 | | |
161 | 171 | | |
162 | 172 | | |
| |||
Lines changed: 37 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| 16 | + | |
16 | 17 | | |
17 | 18 | | |
18 | 19 | | |
| |||
248 | 249 | | |
249 | 250 | | |
250 | 251 | | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
0 commit comments