From 63e7b21131ff9c8ea289d586f28931698ba80a7d Mon Sep 17 00:00:00 2001 From: prakanth <50439067+prakanth97@users.noreply.github.com> Date: Thu, 4 Jul 2024 17:33:52 +0530 Subject: [PATCH 1/5] [Automated] Update the native jar versions --- ballerina/Ballerina.toml | 6 +++--- ballerina/CompilerPlugin.toml | 2 +- ballerina/Dependencies.toml | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/ballerina/Ballerina.toml b/ballerina/Ballerina.toml index afd9674..f948987 100644 --- a/ballerina/Ballerina.toml +++ b/ballerina/Ballerina.toml @@ -1,7 +1,7 @@ [package] org = "ballerina" name = "data.xmldata" -version = "0.1.1" +version = "0.1.2" authors = ["Ballerina"] keywords = ["xml"] repository = "https://github.com/ballerina-platform/module-ballerina-data-xmldata" @@ -12,5 +12,5 @@ export = ["data.xmldata"] [[platform.java17.dependency]] groupId = "io.ballerina.lib" artifactId = "data-native" -version = "0.1.1" -path = "../native/build/libs/data.xmldata-native-0.1.1.jar" +version = "0.1.2" +path = "../native/build/libs/data.xmldata-native-0.1.2-SNAPSHOT.jar" diff --git a/ballerina/CompilerPlugin.toml b/ballerina/CompilerPlugin.toml index 2a0250b..0ee6f03 100644 --- a/ballerina/CompilerPlugin.toml +++ b/ballerina/CompilerPlugin.toml @@ -3,4 +3,4 @@ id = "constraint-compiler-plugin" class = "io.ballerina.lib.data.xmldata.compiler.XmldataCompilerPlugin" [[dependency]] -path = "../compiler-plugin/build/libs/data.xmldata-compiler-plugin-0.1.1.jar" +path = "../compiler-plugin/build/libs/data.xmldata-compiler-plugin-0.1.2-SNAPSHOT.jar" diff --git a/ballerina/Dependencies.toml b/ballerina/Dependencies.toml index 57bd1b1..bcfbdef 100644 --- a/ballerina/Dependencies.toml +++ b/ballerina/Dependencies.toml @@ -10,7 +10,7 @@ distribution-version = "2201.9.0" [[package]] org = "ballerina" name = "data.xmldata" -version = "0.1.1" +version = "0.1.2" dependencies = [ {org = "ballerina", name = "io"}, {org = "ballerina", name = "jballerina.java"}, From 532f953b5f351c23e2240573fa205914bc93650e Mon Sep 17 00:00:00 2001 From: prakanth <50439067+prakanth97@users.noreply.github.com> Date: Thu, 4 Jul 2024 18:04:25 +0530 Subject: [PATCH 2/5] Fix record to xml conversion missing namespace --- ballerina/tests/toXml_test.bal | 56 +++++++++++++++++++ .../lib/data/xmldata/utils/DataUtils.java | 29 +++++++++- 2 files changed, 82 insertions(+), 3 deletions(-) diff --git a/ballerina/tests/toXml_test.bal b/ballerina/tests/toXml_test.bal index 0950703..76e9338 100644 --- a/ballerina/tests/toXml_test.bal +++ b/ballerina/tests/toXml_test.bal @@ -1165,6 +1165,62 @@ isolated function testRecordWithNamespaceAnnotationToXml1() returns error? { test:assertEquals(result.toString(), expected, msg = "testComplexRecordToXml result incorrect"); } +type AddressR record {| + string city; + int code; +|}; + +type Wsa_ReplyTo record { + @Namespace {prefix: "wsa", uri: "example1.com"} + AddressR Address; +}; + +type Htng_ReplyTo record { + @Namespace {prefix: "htng", uri: "example2.com"} + AddressR Address; +}; + +@Name {value: "soap"} +type Soap record { + @Name {value: "ReplyTo"} + @Namespace {prefix: "wsa", uri: "example1.com"} + Wsa_ReplyTo wsaReplyTo; + @Name {value: "ReplyTo"} + @Namespace {prefix: "htng", uri: "example2.com"} + Htng_ReplyTo htngReplyTo; +}; + +@test:Config { + groups: ["toXml"] +} +isolated function testXmlToRecordWithNamespaceAttachedToFields() returns error? { + Soap val = { + htngReplyTo: { + Address: { + code: 40000, + city: "Colombo" + } + }, + wsaReplyTo: { + Address: { + code: 10000, + city: "Kandy" + } + } + }; + + xml xmlVal = check toXml(val); + string expected = "" + + "" + + "Kandy10000" + + "" + + "" + + "Colombo40000" + + "" + + ""; + test:assertEquals(xmlVal.toString(), expected); +} + @test:Config { groups: ["toXml"] } diff --git a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java index dfe0d70..e124c4e 100644 --- a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java +++ b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java @@ -459,14 +459,20 @@ private static BMap addFields(BMap input, Type processRecord(key, annotations, recordValue, value, fieldType); } else if (fieldType.getTag() == TypeTags.TYPE_REFERENCED_TYPE_TAG) { Type referredType = TypeUtils.getReferredType(fieldType); + BMap namespaceAnnotRecord = ValueCreator.createMapValue(Constants.JSON_MAP_TYPE); if (annotations.size() > 0) { + String fieldName = key; key = getKeyNameFromAnnotation(annotations, key); + QName qName = addFieldNamespaceAnnotation(fieldName, key, annotations, namespaceAnnotRecord); + String localPart = qName.getLocalPart(); + key = qName.getPrefix().isBlank() ? localPart : qName.getPrefix() + ":" + localPart; } BMap subRecordAnnotations = ((RecordType) referredType).getAnnotations(); key = getElementName(subRecordAnnotations, key); BMap annotationRecord = ValueCreator.createMapValue(Constants.JSON_MAP_TYPE); processSubRecordAnnotation(subRecordAnnotations, annotationRecord); BMap subRecordValue = addFields(((BMap) value), referredType); + addNamespaceToSubRecord(key, namespaceAnnotRecord, subRecordValue); if (annotationRecord.size() > 0) { subRecordValue.put(annotationRecord.getKeys()[0], annotationRecord.get(annotationRecord.getKeys()[0])); @@ -475,7 +481,7 @@ private static BMap addFields(BMap input, Type } else if (fieldType.getTag() == TypeTags.ARRAY_TAG) { processArray(fieldType, annotations, recordValue, entry); } else { - addPrimitiveValue(addFieldNamespaceAnnotation(key, annotations, recordValue), + addPrimitiveValue(addFieldNamespaceAnnotation(key, key, annotations, recordValue), annotations, recordValue, value); } } else { @@ -486,10 +492,27 @@ private static BMap addFields(BMap input, Type } @SuppressWarnings("unchecked") - private static QName addFieldNamespaceAnnotation(String key, BMap annotations, + private static void addNamespaceToSubRecord(String key, BMap namespaceAnnotRecord, + BMap subRecord) { + if (namespaceAnnotRecord.isEmpty()) { + return; + } + + Object value = namespaceAnnotRecord.get(StringUtils.fromString(key)); + if (value == null) { + return; + } + + for (Map.Entry nsAnnotEntry: ((BMap) value).entrySet()) { + subRecord.put(nsAnnotEntry.getKey(), nsAnnotEntry.getValue()); + } + } + + @SuppressWarnings("unchecked") + private static QName addFieldNamespaceAnnotation(String fieldName, String key, BMap annotations, BMap recordValue) { BString annotationKey = StringUtils.fromString(Constants.FIELD - + (key.replaceAll(Constants.NON_NUMERIC_STRING_REGEX, "\\\\$0"))); + + (fieldName.replaceAll(Constants.NON_NUMERIC_STRING_REGEX, "\\\\$0"))); boolean isAttributeField = isAttributeField(annotationKey, annotations); if (annotations.containsKey(annotationKey)) { BMap annotationValue = (BMap) annotations.get(annotationKey); From 60fad59d7dc18836f2f45cd40ed9a31a6636ab8d Mon Sep 17 00:00:00 2001 From: prakanth <50439067+prakanth97@users.noreply.github.com> Date: Thu, 4 Jul 2024 22:08:32 +0530 Subject: [PATCH 3/5] Fix incorrect xml when field name with underscore --- ballerina/tests/toXml_test.bal | 26 +++++++++++++++++++ .../lib/data/xmldata/utils/Constants.java | 2 +- .../lib/data/xmldata/utils/DataUtils.java | 8 +++--- 3 files changed, 31 insertions(+), 5 deletions(-) diff --git a/ballerina/tests/toXml_test.bal b/ballerina/tests/toXml_test.bal index 76e9338..374b734 100644 --- a/ballerina/tests/toXml_test.bal +++ b/ballerina/tests/toXml_test.bal @@ -1221,6 +1221,32 @@ isolated function testXmlToRecordWithNamespaceAttachedToFields() returns error? test:assertEquals(xmlVal.toString(), expected); } +type RequestorID record { + @Attribute + string ID; + @Attribute + string ID_Context; + @Attribute + string Type; +}; + +type Source record { + RequestorID RequestorID; +}; + +@test:Config { + groups: ["toXml"] +} +isolated function testUnderscoreInTheFieldName() returns error? { + Source s = { + RequestorID: { + ID: "1", + ID_Context: "2", + Type: "3"}}; + xml xmlVal = check toXml(s); + test:assertEquals(xmlVal.toString(), ""); +} + @test:Config { groups: ["toXml"] } diff --git a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java index 2e3e477..bbf227b 100644 --- a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java +++ b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java @@ -58,6 +58,6 @@ private Constants() {} public static final BString ATTRIBUTE_PREFIX = StringUtils.fromString("attributePrefix"); public static final BString TEXT_FIELD_NAME = StringUtils.fromString("textFieldName"); public static final BString ALLOW_DATA_PROJECTION = StringUtils.fromString("allowDataProjection"); - public static final String NON_NUMERIC_STRING_REGEX = "[^a-zA-Z\\d\s]"; + public static final String RECORD_FIELD_NAME_ESCAPE_CHAR_REGEX = "[^a-zA-Z\\d\s_]"; public static final String NS_ANNOT_NOT_DEFINED = "$$ns_annot_not_defined$$"; } diff --git a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java index e124c4e..1f3a4f6 100644 --- a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java +++ b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java @@ -512,7 +512,7 @@ private static void addNamespaceToSubRecord(String key, BMap na private static QName addFieldNamespaceAnnotation(String fieldName, String key, BMap annotations, BMap recordValue) { BString annotationKey = StringUtils.fromString(Constants.FIELD - + (fieldName.replaceAll(Constants.NON_NUMERIC_STRING_REGEX, "\\\\$0"))); + + (fieldName.replaceAll(Constants.RECORD_FIELD_NAME_ESCAPE_CHAR_REGEX, "\\\\$0"))); boolean isAttributeField = isAttributeField(annotationKey, annotations); if (annotations.containsKey(annotationKey)) { BMap annotationValue = (BMap) annotations.get(annotationKey); @@ -547,7 +547,7 @@ private static BMap getFieldNamespaceAndNameAnnotations(String BMap nsFieldAnnotation = ValueCreator.createMapValue(Constants.JSON_MAP_TYPE); BString annotationKey = StringUtils.fromString((Constants.FIELD - + (key.replaceAll(Constants.NON_NUMERIC_STRING_REGEX, "\\\\$0")))); + + (key.replaceAll(Constants.RECORD_FIELD_NAME_ESCAPE_CHAR_REGEX, "\\\\$0")))); if (!parentAnnotations.containsKey(annotationKey)) { return nsFieldAnnotation; } @@ -591,7 +591,7 @@ private static void addPrimitiveValue(QName qName, BMap annotat BString key = qName.getPrefix().isBlank() ? localPart : StringUtils.fromString(qName.getPrefix() + ":" + localPart); BString annotationKey = StringUtils.fromString(Constants.FIELD - + (localPart.getValue().replaceAll(Constants.NON_NUMERIC_STRING_REGEX, "\\\\$0"))); + + (localPart.getValue().replaceAll(Constants.RECORD_FIELD_NAME_ESCAPE_CHAR_REGEX, "\\\\$0"))); BMap currentValue; if (record.containsKey(key)) { currentValue = (BMap) record.get(key); @@ -648,7 +648,7 @@ private static void processArray(Type childType, BMap annotatio @SuppressWarnings("unchecked") private static String getKeyNameFromAnnotation(BMap annotations, String keyName) { BString annotationKey = StringUtils.fromString(Constants.FIELD - + (keyName.replaceAll(Constants.NON_NUMERIC_STRING_REGEX, "\\\\$0"))); + + (keyName.replaceAll(Constants.RECORD_FIELD_NAME_ESCAPE_CHAR_REGEX, "\\\\$0"))); if (annotations.containsKey(annotationKey)) { BMap annotationValue = (BMap) annotations.get(annotationKey); return processFieldAnnotation(annotationValue, keyName); From 0f46dd1adad1875fe337070e0b9e95b614a9301a Mon Sep 17 00:00:00 2001 From: prakanth <50439067+prakanth97@users.noreply.github.com> Date: Thu, 4 Jul 2024 23:29:00 +0530 Subject: [PATCH 4/5] Handle namespace attached to the field and type --- ballerina/tests/toXml_test.bal | 88 +++++++++++++++---- .../lib/data/xmldata/utils/DataUtils.java | 17 +++- 2 files changed, 87 insertions(+), 18 deletions(-) diff --git a/ballerina/tests/toXml_test.bal b/ballerina/tests/toXml_test.bal index 374b734..689260c 100644 --- a/ballerina/tests/toXml_test.bal +++ b/ballerina/tests/toXml_test.bal @@ -15,6 +15,7 @@ // under the License. import ballerina/test; +import ballerina/io; @test:Config { groups: ["toXml"] @@ -1165,36 +1166,36 @@ isolated function testRecordWithNamespaceAnnotationToXml1() returns error? { test:assertEquals(result.toString(), expected, msg = "testComplexRecordToXml result incorrect"); } -type AddressR record {| +type AddressR1 record {| string city; int code; |}; -type Wsa_ReplyTo record { +type Wsa_ReplyTo1 record { @Namespace {prefix: "wsa", uri: "example1.com"} - AddressR Address; + AddressR1 Address; }; -type Htng_ReplyTo record { - @Namespace {prefix: "htng", uri: "example2.com"} - AddressR Address; +type Htng_ReplyTo1 record { + @Namespace {prefix: "wsa", uri: "example1.com"} + AddressR1 Address; }; @Name {value: "soap"} -type Soap record { +type Soap1 record { @Name {value: "ReplyTo"} @Namespace {prefix: "wsa", uri: "example1.com"} - Wsa_ReplyTo wsaReplyTo; + Wsa_ReplyTo1 wsaReplyTo; @Name {value: "ReplyTo"} @Namespace {prefix: "htng", uri: "example2.com"} - Htng_ReplyTo htngReplyTo; + Htng_ReplyTo1 htngReplyTo; }; @test:Config { groups: ["toXml"] } isolated function testXmlToRecordWithNamespaceAttachedToFields() returns error? { - Soap val = { + Soap1 val = { htngReplyTo: { Address: { code: 40000, @@ -1213,14 +1214,71 @@ isolated function testXmlToRecordWithNamespaceAttachedToFields() returns error? string expected = "" + "" + "Kandy10000" + - "" + - "" + - "Colombo40000" + - "" + - ""; + "" + + "Colombo40000" + + ""; + io:println(xmlVal); test:assertEquals(xmlVal.toString(), expected); } +@Namespace {prefix: "wsa", uri: "example1.com"} +type AddressR2 record {| + string city; + int code; +|}; + +@Namespace {prefix: "wsa", uri: "example1.com"} +type Wsa_ReplyTo2 record { + @Namespace {prefix: "wsa", uri: "example1.com"} + AddressR2 Address; +}; + +@Namespace {prefix: "htng", uri: "example2.com"} +type Htng_ReplyTo2 record { + @Namespace {prefix: "wsa", uri: "example1.com"} + AddressR2 Address; +}; + +@Name {value: "soap"} +type Soap2 record { + @Name {value: "ReplyTo"} + @Namespace {prefix: "wsa", uri: "example1.com"} + Wsa_ReplyTo2 wsaReplyTo; + @Name {value: "ReplyTo"} + @Namespace {prefix: "htng", uri: "example2.com"} + Htng_ReplyTo2 htngReplyTo; +}; + +@test:Config { + groups: ["toXml"] +} +isolated function testXmlToRecordWithNamespaceAttachedToFieldsAndTypes() returns error? { + Soap2 val = { + htngReplyTo: { + Address: { + code: 40000, + city: "Colombo" + } + }, + wsaReplyTo: { + Address: { + code: 10000, + city: "Kandy" + } + } + }; + + xml xmlVal = check toXml(val); + string expected = "" + + "" + + "Kandy10000" + + "" + + "Colombo40000" + + ""; + io:println(xmlVal); + test:assertEquals(xmlVal.toString(), expected); +} + type RequestorID record { @Attribute string ID; diff --git a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java index 1f3a4f6..95e7e27 100644 --- a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java +++ b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java @@ -460,17 +460,25 @@ private static BMap addFields(BMap input, Type } else if (fieldType.getTag() == TypeTags.TYPE_REFERENCED_TYPE_TAG) { Type referredType = TypeUtils.getReferredType(fieldType); BMap namespaceAnnotRecord = ValueCreator.createMapValue(Constants.JSON_MAP_TYPE); + boolean doesNamespaceDefinedInField = false; if (annotations.size() > 0) { String fieldName = key; key = getKeyNameFromAnnotation(annotations, key); QName qName = addFieldNamespaceAnnotation(fieldName, key, annotations, namespaceAnnotRecord); + if (!qName.getNamespaceURI().equals("")) { + doesNamespaceDefinedInField = true; + } String localPart = qName.getLocalPart(); key = qName.getPrefix().isBlank() ? localPart : qName.getPrefix() + ":" + localPart; } - BMap subRecordAnnotations = ((RecordType) referredType).getAnnotations(); - key = getElementName(subRecordAnnotations, key); + BMap annotationRecord = ValueCreator.createMapValue(Constants.JSON_MAP_TYPE); - processSubRecordAnnotation(subRecordAnnotations, annotationRecord); + if (!doesNamespaceDefinedInField) { + BMap subRecordAnnotations = ((RecordType) referredType).getAnnotations(); + key = getElementName(subRecordAnnotations, key); + processSubRecordAnnotation(subRecordAnnotations, annotationRecord); + } + BMap subRecordValue = addFields(((BMap) value), referredType); addNamespaceToSubRecord(key, namespaceAnnotRecord, subRecordValue); if (annotationRecord.size() > 0) { @@ -744,6 +752,9 @@ private static String getElementName(BMap annotation, String ke key = prefix.getValue().concat(Constants.COLON).concat(key); } } + } + + for (BString value : keys) { if (value.getValue().endsWith(Constants.NAME)) { key = processNameAnnotation(annotation, key, value, hasNamespaceAnnotation); } From b281d17237ca45f6f2e263aa2a8f56b07101df1f Mon Sep 17 00:00:00 2001 From: prakanth <50439067+prakanth97@users.noreply.github.com> Date: Fri, 5 Jul 2024 00:10:34 +0530 Subject: [PATCH 5/5] Fix annotation lookup logic --- ballerina/tests/toXml_test.bal | 33 ++++++++++++-- .../lib/data/xmldata/utils/Constants.java | 1 + .../lib/data/xmldata/utils/DataUtils.java | 44 ++++++++++++------- 3 files changed, 57 insertions(+), 21 deletions(-) diff --git a/ballerina/tests/toXml_test.bal b/ballerina/tests/toXml_test.bal index 689260c..e48ee94 100644 --- a/ballerina/tests/toXml_test.bal +++ b/ballerina/tests/toXml_test.bal @@ -15,7 +15,6 @@ // under the License. import ballerina/test; -import ballerina/io; @test:Config { groups: ["toXml"] @@ -1192,7 +1191,7 @@ type Soap1 record { }; @test:Config { - groups: ["toXml"] + groups: ["toXml", "testFail"] } isolated function testXmlToRecordWithNamespaceAttachedToFields() returns error? { Soap1 val = { @@ -1217,7 +1216,6 @@ isolated function testXmlToRecordWithNamespaceAttachedToFields() returns error? "" + "Colombo40000" + ""; - io:println(xmlVal); test:assertEquals(xmlVal.toString(), expected); } @@ -1275,7 +1273,6 @@ isolated function testXmlToRecordWithNamespaceAttachedToFieldsAndTypes() returns "" + "Colombo40000" + ""; - io:println(xmlVal); test:assertEquals(xmlVal.toString(), expected); } @@ -1305,6 +1302,34 @@ isolated function testUnderscoreInTheFieldName() returns error? { test:assertEquals(xmlVal.toString(), ""); } +@Namespace { + uri: "example.com" +} +type File record {| + @Namespace { + uri: "example.com" + } + string fileName; + @Namespace { + uri: "example.com" + } + string fileNamespace; +|}; + +@test:Config { + groups: ["toXml"] +} +isolated function testToRecordFieldNameEndsWithNameOrNamespace() returns error? { + File file = { + fileName: "test.bal", + fileNamespace: "wso2.com" + }; + + xml result = check toXml(file); + string expected = "test.balwso2.com"; + test:assertEquals(result.toString(), expected); +} + @test:Config { groups: ["toXml"] } diff --git a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java index bbf227b..04830ac 100644 --- a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java +++ b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/Constants.java @@ -42,6 +42,7 @@ private Constants() {} public static final ArrayType JSON_ARRAY_TYPE = TypeCreator.createArrayType(PredefinedTypes.TYPE_JSON); public static final String FIELD = "$field$."; public static final String NAMESPACE = "Namespace"; + public static final String MODULE_NAME = "ballerina/data.xmldata"; public static final BString URI = StringUtils.fromString("uri"); public static final BString PREFIX = StringUtils.fromString("prefix"); public static final String ATTRIBUTE = "Attribute"; diff --git a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java index 95e7e27..f9c3b95 100644 --- a/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java +++ b/native/src/main/java/io/ballerina/lib/data/xmldata/utils/DataUtils.java @@ -66,8 +66,7 @@ public static QualifiedName validateAndGetXmlNameFromRecordAnnotation(RecordType BMap annotations = recordType.getAnnotations(); String localName = recordName; for (BString annotationsKey : annotations.getKeys()) { - String key = annotationsKey.getValue(); - if (!key.contains(Constants.FIELD) && key.endsWith(Constants.NAME)) { + if (isNameAnnotationKey(annotationsKey.getValue())) { String name = ((BMap) annotations.get(annotationsKey)).get(Constants.VALUE).toString(); String localPart = elementName.getLocalPart(); if (!name.equals(localPart)) { @@ -81,7 +80,7 @@ public static QualifiedName validateAndGetXmlNameFromRecordAnnotation(RecordType // Handle the namespace annotation. for (BString annotationsKey : annotations.getKeys()) { String key = annotationsKey.getValue(); - if (!key.contains(Constants.FIELD) && key.endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(key)) { Map namespaceAnnotation = ((Map) annotations.get(StringUtils.fromString(key))); BString uri = (BString) namespaceAnnotation.get(Constants.URI); @@ -106,8 +105,7 @@ private static ArrayList getNamespace(RecordType recordType) { BMap annotations = recordType.getAnnotations(); ArrayList namespace = new ArrayList<>(); for (BString annotationsKey : annotations.getKeys()) { - String key = annotationsKey.getValue(); - if (!key.contains(Constants.FIELD) && key.endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(annotationsKey.getValue())) { BMap namespaceAnnotation = (BMap) annotations.get(annotationsKey); namespace.add(namespaceAnnotation.containsKey(Constants.PREFIX) ? ((BString) namespaceAnnotation.get(Constants.PREFIX)).getValue() : ""); @@ -184,7 +182,7 @@ public static Map getAllAttributesInRecordType(RecordType @SuppressWarnings("unchecked") public static QualifiedName getFieldNameFromRecord(Map fieldAnnotation, String fieldName) { for (BString key : fieldAnnotation.keySet()) { - if (key.getValue().endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(key.getValue())) { Map namespaceAnnotation = ((Map) fieldAnnotation.get(key)); BString uri = (BString) namespaceAnnotation.get(Constants.URI); BString prefix = (BString) namespaceAnnotation.get(Constants.PREFIX); @@ -198,7 +196,7 @@ public static QualifiedName getFieldNameFromRecord(Map fieldAnn @SuppressWarnings("unchecked") private static String getModifiedName(Map fieldAnnotation, String attributeName) { for (BString key : fieldAnnotation.keySet()) { - if (key.getValue().endsWith(Constants.NAME)) { + if (isNameAnnotationKey(key.getValue())) { return ((Map) fieldAnnotation.get(key)).get(Constants.VALUE).toString(); } } @@ -525,7 +523,7 @@ private static QName addFieldNamespaceAnnotation(String fieldName, String key, B if (annotations.containsKey(annotationKey)) { BMap annotationValue = (BMap) annotations.get(annotationKey); for (BString fieldKey : annotationValue.getKeys()) { - if (fieldKey.toString().endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(fieldKey.getValue())) { return processFieldNamespaceAnnotation(annotationValue, key, fieldKey, recordValue, isAttributeField); } @@ -542,7 +540,7 @@ public static boolean isAttributeField(BString annotationKey, BMap annotationValue = (BMap) annotations.get(annotationKey); for (BString fieldKey : annotationValue.getKeys()) { - if (fieldKey.toString().endsWith(Constants.ATTRIBUTE)) { + if (isAttributeAnnotationKey(fieldKey.getValue())) { return true; } } @@ -563,7 +561,7 @@ private static BMap getFieldNamespaceAndNameAnnotations(String BMap annotationValue = (BMap) parentAnnotations.get(annotationKey); for (BString fieldKey : annotationValue.getKeys()) { String keyName = fieldKey.getValue(); - if (keyName.endsWith(Constants.NAMESPACE) || keyName.endsWith(Constants.NAME)) { + if (isNamespaceAnnotationKey(keyName) || isNameAnnotationKey(keyName)) { nsFieldAnnotation.put(fieldKey, annotationValue.get(fieldKey)); break; } @@ -694,7 +692,7 @@ private static BMap processParentAnnotation(Type type, BMap annotation, String key) { for (BString value : annotation.getKeys()) { String stringValue = value.getValue(); - if (stringValue.endsWith(Constants.NAME)) { + if (isNameAnnotationKey(stringValue)) { BMap names = (BMap) annotation.get(value); String name = names.get(StringUtils.fromString(VALUE)).toString(); if (key.contains(Constants.COLON)) { @@ -705,7 +703,7 @@ private static String processFieldAnnotation(BMap annotation, S key = name; } } - if (stringValue.endsWith(Constants.ATTRIBUTE)) { + if (isAttributeAnnotationKey(stringValue)) { key = ATTRIBUTE_PREFIX.concat(key); } } @@ -718,10 +716,10 @@ private static BString processAnnotation(BMap annotation, Strin for (BString value : annotation.getKeys()) { if (!value.getValue().contains(Constants.FIELD)) { String stringValue = value.getValue(); - if (stringValue.endsWith(Constants.NAME)) { + if (isNameAnnotationKey(stringValue)) { key = processNameAnnotation(annotation, key, value, hasNamespaceAnnotation); } - if (stringValue.endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(stringValue)) { hasNamespaceAnnotation = true; key = processNamespaceAnnotation(annotation, key, value, namespaces); } @@ -733,7 +731,7 @@ private static BString processAnnotation(BMap annotation, Strin private static void processSubRecordAnnotation(BMap annotation, BMap subRecord) { BString[] keys = annotation.getKeys(); for (BString value : keys) { - if (value.getValue().endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(value.getValue())) { processNamespaceAnnotation(annotation, "", value, subRecord); } } @@ -744,7 +742,7 @@ private static String getElementName(BMap annotation, String ke BString[] keys = annotation.getKeys(); boolean hasNamespaceAnnotation = false; for (BString value : keys) { - if (value.getValue().endsWith(Constants.NAMESPACE)) { + if (isNamespaceAnnotationKey(value.getValue())) { hasNamespaceAnnotation = true; BMap namespaceAnnotation = (BMap) annotation.get(value); BString prefix = (BString) namespaceAnnotation.get(Constants.PREFIX); @@ -755,7 +753,7 @@ private static String getElementName(BMap annotation, String ke } for (BString value : keys) { - if (value.getValue().endsWith(Constants.NAME)) { + if (isNameAnnotationKey(value.getValue())) { key = processNameAnnotation(annotation, key, value, hasNamespaceAnnotation); } } @@ -816,6 +814,18 @@ private static String addAttributeToRecord(BString prefix, BString uri, String k return prefix.getValue().concat(Constants.COLON).concat(key); } + private static boolean isNamespaceAnnotationKey(String key) { + return key.startsWith(Constants.MODULE_NAME) && key.endsWith(Constants.NAMESPACE); + } + + private static boolean isNameAnnotationKey(String key) { + return key.startsWith(Constants.MODULE_NAME) && key.endsWith(Constants.NAME); + } + + private static boolean isAttributeAnnotationKey(String key) { + return key.startsWith(Constants.MODULE_NAME) && key.endsWith(Constants.ATTRIBUTE); + } + /** * Holds data required for the traversing. *