Skip to content

Commit

Permalink
* Fix #2088
Browse files Browse the repository at this point in the history
* Minor improvement to error handling wrt exception propagating via Creator (esp. for NPEs and other no-message exception types)
  • Loading branch information
cowtowncoder committed Aug 29, 2018
1 parent dd7258a commit 555cbeb
Show file tree
Hide file tree
Showing 4 changed files with 58 additions and 4 deletions.
3 changes: 3 additions & 0 deletions release-notes/VERSION-2.x
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ Project: jackson-databind
#2079: NPE when visiting StaticListSerializerBase
(reported by WorldSEnder@github)
#2082: `FactoryBasedEnumDeserializer` should be cachable
#2088: `@JsonUnwrapped` fields are skipped when using `PropertyBasedCreator` if
they appear after the last creator property
(reported, fix contributed by 6bangs@github)
#2096: `TreeTraversingParser` does not take base64 variant into account
(reported by tangiel@github)
#2097: Block more classes from polymorphic deserialization (CVE-2018-14718
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1589,15 +1589,21 @@ public JsonMappingException weirdNativeValueException(Object value, Class<?> ins
* to indicate problem with physically constructing instance of
* specified class (missing constructor, exception from constructor)
*<p>
* Note that most of the time this method should NOT be called; instead,
* Note that most of the time this method should NOT be called directly; instead,
* {@link #handleInstantiationProblem} should be called which will call this method
* if necessary.
*/
public JsonMappingException instantiationException(Class<?> instClass, Throwable cause) {
// Most likely problem with Creator definition, right?
JavaType type = constructType(instClass);
final JavaType type = constructType(instClass);
String excMsg;
if (cause == null) {
excMsg = "N/A";
} else if ((excMsg = cause.getMessage()) == null) {
excMsg = ClassUtil.nameOf(cause.getClass());
}
String msg = String.format("Cannot construct instance of %s, problem: %s",
ClassUtil.nameOf(instClass), cause.getMessage());
ClassUtil.nameOf(instClass), excMsg);
InvalidDefinitionException e = InvalidDefinitionException.from(_parser, msg, type);
e.initCause(cause);
return e;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -767,10 +767,17 @@ protected Object deserializeUsingPropertyBasedWithUnwrapped(JsonParser p, Deseri
p.setCurrentValue(bean);
// if so, need to copy all remaining tokens into buffer
while (t == JsonToken.FIELD_NAME) {
p.nextToken(); // to skip name
// NOTE: do NOT skip name as it needs to be copied; `copyCurrentStructure` does that
tokens.copyCurrentStructure(p);
t = p.nextToken();
}
// 28-Aug-2018, tatu: Let's add sanity check here, easier to catch off-by-some
// problems if we maintain invariants
if (t != JsonToken.END_OBJECT) {
ctxt.reportWrongTokenException(this, JsonToken.END_OBJECT,
"Attempted to unwrap '%s' value",
handledType().getName());
}
tokens.writeEndObject();
if (bean.getClass() != _beanType.getRawClass()) {
// !!! 08-Jul-2011, tatu: Could probably support; but for now
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,34 @@ static class Address {
public String country;
}

// [databind#2088]
static class Issue2088Bean {
int x;
int y;

@JsonUnwrapped
Issue2088UnwrappedBean w;

public Issue2088Bean(@JsonProperty("x") int x, @JsonProperty("y") int y) {
this.x = x;
this.y = y;
}

public void setW(Issue2088UnwrappedBean w) {
this.w = w;
}
}

static class Issue2088UnwrappedBean {
int a;
int b;

public Issue2088UnwrappedBean(@JsonProperty("a") int a, @JsonProperty("b") int b) {
this.a = a;
this.b = b;
}
}

/*
/**********************************************************
/* Tests, serialization
Expand Down Expand Up @@ -216,4 +244,14 @@ public void testCaseInsensitiveUnwrap() throws Exception
Person p = mapper.readValue("{ }", Person.class);
assertNotNull(p);
}

// [databind#2088]: accidental skipping of values
public void testIssue2088UnwrappedFieldsAfterLastCreatorProp() throws Exception
{
Issue2088Bean bean = MAPPER.readValue("{\"x\":1,\"a\":2,\"y\":3,\"b\":4}", Issue2088Bean.class);
assertEquals(1, bean.x);
assertEquals(2, bean.w.a);
assertEquals(3, bean.y);
assertEquals(4, bean.w.b);
}
}

0 comments on commit 555cbeb

Please sign in to comment.