|
8 | 8 | import com.fasterxml.jackson.core.type.TypeReference;
|
9 | 9 | import com.fasterxml.jackson.databind.JsonMappingException;
|
10 | 10 | import com.fasterxml.jackson.databind.JsonNode;
|
| 11 | +import com.fasterxml.jackson.databind.ObjectMapper; |
11 | 12 | import com.google.common.base.MoreObjects;
|
12 | 13 | import com.google.common.collect.ImmutableList;
|
13 |
| -import com.yubico.u2f.data.messages.json.JsonSerializable; |
14 | 14 | import com.yubico.u2f.exceptions.U2fBadConfigurationException;
|
15 |
| -import com.yubico.u2f.exceptions.U2fBadInputException; |
| 15 | +import com.yubico.webauthn.util.WebAuthnCodecs; |
16 | 16 | import java.io.IOException;
|
17 | 17 | import java.util.List;
|
18 | 18 | import java.util.Map;
|
19 | 19 | import lombok.EqualsAndHashCode;
|
20 | 20 |
|
21 | 21 | @JsonIgnoreProperties(ignoreUnknown = true)
|
22 | 22 | @EqualsAndHashCode(of = { "data" }, callSuper = false)
|
23 |
| -public class MetadataObject extends JsonSerializable { |
| 23 | +public class MetadataObject { |
| 24 | + private static final ObjectMapper OBJECT_MAPPER = WebAuthnCodecs.json(); |
| 25 | + |
24 | 26 | private static final TypeReference<Map<String, String>> MAP_STRING_STRING_TYPE = new TypeReference<Map<String, String>>() {
|
25 | 27 | };
|
26 | 28 | private static final TypeReference LIST_STRING_TYPE = new TypeReference<List<String>>() {
|
@@ -55,7 +57,6 @@ public MetadataObject(JsonNode data) throws U2fBadConfigurationException {
|
55 | 57 | version = data.get("version").asLong();
|
56 | 58 | }
|
57 | 59 |
|
58 |
| - @Override |
59 | 60 | public String toJson() {
|
60 | 61 | return data.toString();
|
61 | 62 | }
|
@@ -100,8 +101,8 @@ public static List<MetadataObject> parseFromJson(String jsonData) throws U2fBadC
|
100 | 101 |
|
101 | 102 | public static MetadataObject fromJson(String json) throws U2fBadConfigurationException {
|
102 | 103 | try {
|
103 |
| - return fromJson(json, MetadataObject.class); |
104 |
| - } catch (U2fBadInputException e) { |
| 104 | + return OBJECT_MAPPER.readValue(json, MetadataObject.class); |
| 105 | + } catch (IOException e) { |
105 | 106 | throw new U2fBadConfigurationException("Malformed data", e);
|
106 | 107 | }
|
107 | 108 | }
|
|
0 commit comments