Skip to content

DATAREST-1383 causes top level properties with @JsonSetter to be missed. [DATAREST-1573] #1911

Open
@spring-projects-issues

Description

@spring-projects-issues

Joseph Valerio opened DATAREST-1573 and commented

We just upgraded to SpringBoot 2.3.2.

We are using spring datarest 3.3.2 with JPA against a RDBMS

We use a PATCH to update our user's passwords.  We have a setter on our User Object setPassword() annotated with @JsonSetter, but there is no corresponding persisted property.  This method is used to set the persisted encryptedPassword property on the user.  The following commit on DomainObjectReader causes this to no longer work:

c616c53

229:       if (!mappedProperties.hasPersistentPropertyForField(fieldName)) {				 
230:           i.remove();
231:           continue;
232:       }

The i.remove on line 230 removes the password property from consideration since it is not a PersistentProperty  

If this property is not removed, it will cause the setter to be invoked at line 285:

 

return mapper.readerForUpdating(target).readValue(root);

 

If we change the Method to a PUT this works correctly, but it should also work for patch.

If you are not following my explaination, I can create a test project to expose the issue on request


1 votes, 2 watchers

Metadata

Metadata

Assignees

Labels

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions