Class ProductAssetEndpoint.ProductAssetUpdate
- Enclosing class:
- ProductAssetEndpoint
ProductAsset.
 
 It is important to note that the combined usage of @Nullable and Optional
 for the fields is entirely intentional.. Since there is no way to distinguish between a
 value not being supplied and being updated to null, this mechanism is
 necessary.
 
 If the request JSON does not have a particular field's key, the field in this DTO will
 deserialize to null. If the request JSON does have the field's key but the
 value is null, the field in this DTO will deserialize to Optional.empty().
 
 An earlier, alternate implementation relied on a single Map<String, Object>
 "updateFields" property to achieve the same distinction between unsupplied and null, but this
 approach had the flaw of not being able to take advantage of Jackson's automatic type-safe
 deserialization. With the current approach, Jackson can understand the declared types and
 automatically verify and convert the fields to the appropriate types.
 
 Another important note is that the use of @Data and @Setter with
 AccessLevel#PRIVATE is intentional. This is required for getting the behavior we
 want from Jackson on deserialization, while still maintaining @Value-like
 immutability. If we were to use @Value, Jackson would always set unsupplied keys to
 Optional.empty(). However, when we use @Data, it seems that Jackson simply
 does not call the setters for the fields with unsupplied keys, which leaves them null (giving
 us our desired behavior).
- 
Constructor SummaryConstructors
- 
Method Summary