Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support @JsonAnySetter on method with single Map parameter #4889

Open
cowtowncoder opened this issue Jan 7, 2025 Discussed in #4888 · 5 comments
Open

Support @JsonAnySetter on method with single Map parameter #4889

cowtowncoder opened this issue Jan 7, 2025 Discussed in #4888 · 5 comments

Comments

@cowtowncoder
Copy link
Member

Discussed in #4888

Originally posted by chrylis January 7, 2025
Currently, @JsonAnySetter can be used on a physical field of type Map, but unlike @JsonProperty, it will be silently dropped if used on a method of arity other than two (POJOPropertiesCollector#_addMethods). I would like to be able to use @JsonAnySetter on a method representing a virtual property, like this:

@Slf4j
class WebhookDto {
  @JsonAnySetter
  void setUnmappedProperties(Map<String, Object> unmapped) {
    log.warn("unmapped properties on webhook: {}", unmapped)
  }
}
```</div>
@alixpeigue
Copy link

Hi, is it still available ? I'd like to tackle it as part of a software engineering course, we'll be multiple people working on it but I'll serve as intermediary not to burden you with that.

@cowtowncoder
Copy link
Member Author

@JooHyukKim What do you think about this wrt feasibility/need? You have been working most on any-getter/any-setter support.

@alixpeigue Yes, should be free: if someone was working on it, they'd be expected to add a note here.

@JooHyukKim
Copy link
Member

@cowtowncoder
Hmmm this usage seems more like workaround, honestly. Adding custom handling for un-expected property isn't what @JsonAnySetter is for I think?

@alixpeigue
Speaking of "need" along with "priority", we have couple of other JsonAnySetter related issues, if you trying to work on somethiing.

@cowtowncoder
Copy link
Member Author

@JooHyukKim I think use of @JsonAnySetter for properties for which there is no Field or Setter (hence, "unmapped") is pretty much the main use case?

@JooHyukKim
Copy link
Member

JooHyukKim commented Mar 10, 2025

@JooHyukKim I think use of @JsonAnySetter for properties for which there is no Field or Setter (hence, "unmapped") is pretty much the main use case?

Yeah, we can see it that way makes sense.
My idea was we might be better off creating hook to trigger when facing unknown properties. That way we dont even need JsonAnySetter or limit our selves to a builder like

'''Java
JsonMapper.builder().onUnknwonProperty(logger::error).build()
'''

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants