From c35ad79f3939eebf531f477d62755221789bca12 Mon Sep 17 00:00:00 2001 From: Dan Timoney Date: Wed, 28 Jun 2023 11:38:33 -0400 Subject: Update features for Argon release MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Update ccsdk/features for use with OpenDaylight Argon release Issue-ID: CCSDK-3916 Signed-off-by: Dan Timoney Change-Id: Ie28aa66f6c3a9c0c6002e05d8f714613dbe460cf Signed-off-by: Michael Dürre --- .../mapper/serialize/BaseIdentityDeserializer.java | 19 +++++++++++++------ .../sdnr/wt/yang/mapper/serialize/EnumSerializer.java | 7 ++++--- 2 files changed, 17 insertions(+), 9 deletions(-) (limited to 'sdnr/wt/common-yang/utils/src/main/java') diff --git a/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/BaseIdentityDeserializer.java b/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/BaseIdentityDeserializer.java index 1c4226322..9e72e5652 100644 --- a/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/BaseIdentityDeserializer.java +++ b/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/BaseIdentityDeserializer.java @@ -25,14 +25,10 @@ import com.fasterxml.jackson.core.JsonParser; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.DeserializationContext; import com.fasterxml.jackson.databind.JsonDeserializer; - +import com.google.common.reflect.ClassPath; import java.io.IOException; -import java.lang.reflect.Type; import java.util.List; import java.util.stream.Collectors; - -import com.google.common.reflect.ClassPath; -import org.onap.ccsdk.features.sdnr.wt.yang.mapper.YangToolsMapper; import org.onap.ccsdk.features.sdnr.wt.yang.mapper.YangToolsMapperHelper; import org.opendaylight.yangtools.yang.binding.BaseIdentity; import org.slf4j.Logger; @@ -63,13 +59,24 @@ public class BaseIdentityDeserializer extends JsonDeserializer { int lastDot = clazzToSearch.lastIndexOf("."); if (lastDot > -1) { simpleName = clazzToSearch.substring(lastDot + 1); + String finalSimpleName; + if(simpleName.endsWith("Identity")){ + finalSimpleName = simpleName.substring(0, simpleName.length()-8); + } + else{ + finalSimpleName=simpleName; + } clazz = getTypesInNamespace(clazzToSearch.substring(0, lastDot)).stream() - .filter(e -> e.getSimpleName().equals(simpleName)).findFirst().orElse(null); + .filter(e -> e.getSimpleName().equals(finalSimpleName)).findFirst().orElse(null); if (clazz != null) return (T) YangToolsMapperHelper.getIdentityValueFromClass(clazz); } else { simpleName = clazzToSearch.substring(0, 1).toUpperCase() + clazzToSearch.substring(1); + if(simpleName.endsWith("Identity")){ + simpleName = simpleName.substring(0, simpleName.length()-8); + } } + try { clazz = (Class) YangToolsMapperHelper.findClass(simpleName); if (clazz != null) diff --git a/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/EnumSerializer.java b/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/EnumSerializer.java index 8959e913a..ea07c5d05 100644 --- a/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/EnumSerializer.java +++ b/sdnr/wt/common-yang/utils/src/main/java/org/onap/ccsdk/features/sdnr/wt/yang/mapper/serialize/EnumSerializer.java @@ -25,7 +25,8 @@ import com.fasterxml.jackson.core.JsonGenerator; import com.fasterxml.jackson.databind.JsonSerializer; import com.fasterxml.jackson.databind.SerializerProvider; import java.io.IOException; -import org.opendaylight.yangtools.yang.binding.Enumeration; +import org.opendaylight.yangtools.yang.binding.EnumTypeObject; + @SuppressWarnings("rawtypes") public class EnumSerializer extends JsonSerializer { @@ -33,8 +34,8 @@ public class EnumSerializer extends JsonSerializer { @Override public void serialize(Enum value, JsonGenerator gen, SerializerProvider serializers) throws IOException { //sadly a seperate serializer for class Enumeration doesn't work, so we have to catch it here - if(value instanceof Enumeration) { - gen.writeString(((Enumeration)value).getName()); + if(value instanceof EnumTypeObject) { + gen.writeString(((EnumTypeObject)value).getName()); } else { gen.writeString(value.name()); -- cgit 1.2.3-korg