From 09908b36caffc1e5cb75267abce4e75197ad6da3 Mon Sep 17 00:00:00 2001 From: Alvaro Vega Date: Thu, 3 Oct 2024 10:01:09 +0200 Subject: [PATCH 1/3] fix createInstanceFromJson for PolyLine Polygon and Multipoint --- .../backends/arcgis/model/MultiPoint.java | 2 +- .../backends/arcgis/model/PolyLine.java | 2 +- .../cygnus/backends/arcgis/model/Polygon.java | 2 +- .../cygnus/backends/arcgis/FeatureTest.java | 12 +- .../backends/arcgis/FeatureTestFactory.java | 116 +++++++++++++++++- 5 files changed, 125 insertions(+), 9 deletions(-) diff --git a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java index 7cbc7fa9d..c118787da 100644 --- a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java +++ b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java @@ -131,7 +131,7 @@ public JsonObject toJSON() { */ public static Geometry createInstanceFromJson(JsonObject json) throws ArcgisException { try { - return new MultiPoint(json.get(POINTS_TAG).getAsString()); + return new MultiPoint(json.getAsString()); } catch (Exception e) { LOGGER.error(e.getClass().getSimpleName() + " error " + e.getMessage() + " parsing MultiPoint from json " + json); throw new ArcgisException("Unable to parse MultiPoint from json " + json + " due to " + e.getMessage()); diff --git a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java index 02346edeb..b5487f3af 100644 --- a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java +++ b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java @@ -131,7 +131,7 @@ public JsonObject toJSON() { */ public static Geometry createInstanceFromJson(JsonObject json) throws ArcgisException { try { - return new PolyLine(json.get(PATHS_TAG).getAsString()); + return new PolyLine(json.getAsString()); } catch (Exception e) { LOGGER.error(e.getClass().getSimpleName() + " error " + e.getMessage() + " parsing PolyLine from json " + json); throw new ArcgisException("Unable to parse PolyLine from json " + json + " due to " + e.getMessage()); diff --git a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java index e936ef5a2..d351d547a 100644 --- a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java +++ b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java @@ -131,7 +131,7 @@ public JsonObject toJSON() { */ public static Geometry createInstanceFromJson(JsonObject json) throws ArcgisException { try { - return new Polygon(json.get(RINGS_TAG).getAsString()); + return new Polygon(json.getAsString()); } catch (Exception e) { LOGGER.error(e.getClass().getSimpleName() + " error " + e.getMessage() + " parsing Polygon from json " + json); throw new ArcgisException("Unable to parse Polygon from json " + json + " due to " + e.getMessage()); diff --git a/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTest.java b/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTest.java index 529212cfe..7da1b2011 100644 --- a/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTest.java +++ b/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTest.java @@ -43,7 +43,6 @@ import java.util.List; import java.util.Arrays; import java.util.ArrayList; -import com.google.gson.JsonObject; import com.google.gson.Gson; import com.google.gson.reflect.TypeToken; import java.lang.reflect.Type; @@ -177,17 +176,17 @@ public void getPolyFeatureTest() { String paths = "{ \"paths\": [ [ [-97.06138, 32.837], [-97.06133, 33.836], [-98.2, 34.834], [-97, 40] ] ] }"; PolyLine polyline = new PolyLine(paths); System.out.println("POLYLINE: " + polyline.toString()); - } catch (Exception e) { System.out.println("Exception"); System.out.println(e.getClass().getSimpleName() + " " + e.getMessage()); } Feature polyline = FeatureTestFactory.getNewPolyLineFeature("Mi PolyLine", 33); System.out.println("feature with polyline - " + polyline.toJson()); + Feature polyline2 = FeatureTestFactory.getNewPolyLineFeature2("Mi PolyLine2", 33); + System.out.println("feature with polyline2 - " + polyline2.toJson()); assertTrue("ok.", true); } - /** * */ @@ -198,13 +197,14 @@ public void getPolygonTest() { String rings = "{ \"rings\": [ [ [-97.06138,32.837,35.1,4.8], [-97.06133,32.836,35.2,4.1], [-97.06124,32.834,35.3,4.2], [-97.06138,32.837,35.1,4.8] ], [ [-97.06326,32.759,35.4], [-97.06298,32.755,35.5], [-97.06153,32.749,35.6], [-97.06326,32.759,35.4] ] ] }"; Polygon poly = new Polygon(rings); System.out.println("POLYGON: " + poly.toString()); - } catch (Exception e) { System.out.println("Exception"); System.out.println(e.getClass().getSimpleName() + " " + e.getMessage()); } Feature polygon = FeatureTestFactory.getNewPolygonFeature("Mi Polygon", 33); System.out.println("feature with polygon - " + polygon.toJson()); + Feature polygon2 = FeatureTestFactory.getNewPolygonFeature("Mi Polygon2", 33); + System.out.println("feature with polygon2 - " + polygon2.toJson()); assertTrue("ok.", true); } @@ -225,7 +225,9 @@ public void getMultiPointTest() { } Feature multipoint = FeatureTestFactory.getNewMultiPointFeature("Mi MultiPoint", 33); System.out.println("feature with multipoint - " + multipoint.toJson()); + Feature multipoint2 = FeatureTestFactory.getNewMultiPointFeature("Mi MultiPoint2", 33); + System.out.println("feature with multipoint2 - " + multipoint2.toJson()); assertTrue("ok.", true); - } + } } diff --git a/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTestFactory.java b/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTestFactory.java index c4aa9feab..7579bc6b6 100644 --- a/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTestFactory.java +++ b/cygnus-common/src/test/java/com/telefonica/iot/cygnus/backends/arcgis/FeatureTestFactory.java @@ -143,6 +143,40 @@ public static Feature getNewPolyLineFeature(String description, Integer external return feature; } + public static Feature getNewPolyLineFeature2(String description, Integer externalId) { + Map attributes = new LinkedHashMap(); + attributes.put("IDEXTERNO", externalId); + attributes.put("DESCRIPCION", description); + attributes.put("RAZONSOCIAL", "Razon social"); + attributes.put("NUMEROPOSTAL", null); + attributes.put("TIPOOCUPACION", 0); + attributes.put("FINI", new Date()); + attributes.put("UNIDADMEDIDA", null); + attributes.put("EXCSABDOM", 0); + attributes.put("EXCFESTIVOS", 0); + attributes.put("PRESENCIAPOLICIAL", 0); + attributes.put("REVISADO", 0); + attributes.put("IDACTIVIDAD", 0); + attributes.put("ACTIVIDAD", "actividad"); + attributes.put("IDCLASE", 0); + attributes.put("CLASE", "clase"); + attributes.put("IDESTADO", 0); + attributes.put("ESTADO", "estado"); + attributes.put("CALLE", "calle"); + attributes.put("FFIN", new GregorianCalendar()); + attributes.put("CANTIDADOCUPADA", null); + String jsonString = "{ \"paths\": [ [ [-97.06138, 32.837], [-97.06133, 33.836], [-98.2, 34.834], [-97, 40] ] ] }"; + Feature feature = null; + try { + feature = Feature.createInstanceFromJson(jsonString); + feature.setAttributes(attributes); + } catch (Exception e) { + System.out.println("Exception"); + System.out.println(e.getClass().getSimpleName() + " " + e.getMessage()); + } + return feature; + } + /** * * @param description @@ -177,6 +211,46 @@ public static Feature getNewPolygonFeature(String description, Integer externalI return feature; } + /** + * + * @param description + * @param externalId + * @return + */ + public static Feature getNewPolygonFeature2(String description, Integer externalId) { + Map attributes = new LinkedHashMap(); + attributes.put("IDEXTERNO", externalId); + attributes.put("DESCRIPCION", description); + attributes.put("RAZONSOCIAL", "Razon social"); + attributes.put("NUMEROPOSTAL", null); + attributes.put("TIPOOCUPACION", 0); + attributes.put("FINI", new Date()); + attributes.put("UNIDADMEDIDA", null); + attributes.put("EXCSABDOM", 0); + attributes.put("EXCFESTIVOS", 0); + attributes.put("PRESENCIAPOLICIAL", 0); + attributes.put("REVISADO", 0); + attributes.put("IDACTIVIDAD", 0); + attributes.put("ACTIVIDAD", "actividad"); + attributes.put("IDCLASE", 0); + attributes.put("CLASE", "clase"); + attributes.put("IDESTADO", 0); + attributes.put("ESTADO", "estado"); + attributes.put("CALLE", "calle"); + attributes.put("FFIN", new GregorianCalendar()); + attributes.put("CANTIDADOCUPADA", null); + String jsonString = "{ \"rings\": [ [ [-97.06138,32.837,35.1,4.8], [-97.06133,32.836,35.2,4.1], [-97.06124,32.834,35.3,4.2], [-97.06138,32.837,35.1,4.8] ], [ [-97.06326,32.759,35.4], [-97.06298,32.755,35.5], [-97.06153,32.749,35.6], [-97.06326,32.759,35.4] ] ] }"; + Feature feature = null; + try { + feature = Feature.createInstanceFromJson(jsonString); + feature.setAttributes(attributes); + } catch (Exception e) { + System.out.println("Exception"); + System.out.println(e.getClass().getSimpleName() + " " + e.getMessage()); + } + return feature; + } + /** * * @param description @@ -209,7 +283,47 @@ public static Feature getNewMultiPointFeature(String description, Integer extern Feature feature = Feature.createMultiPointFeature(jsonString); feature.setAttributes(attributes); return feature; - } + } + + /** + * + * @param description + * @param externalId + * @return + */ + public static Feature getNewMultiPointFeature2(String description, Integer externalId) { + Map attributes = new LinkedHashMap(); + attributes.put("IDEXTERNO", externalId); + attributes.put("DESCRIPCION", description); + attributes.put("RAZONSOCIAL", "Razon social"); + attributes.put("NUMEROPOSTAL", null); + attributes.put("TIPOOCUPACION", 0); + attributes.put("FINI", new Date()); + attributes.put("UNIDADMEDIDA", null); + attributes.put("EXCSABDOM", 0); + attributes.put("EXCFESTIVOS", 0); + attributes.put("PRESENCIAPOLICIAL", 0); + attributes.put("REVISADO", 0); + attributes.put("IDACTIVIDAD", 0); + attributes.put("ACTIVIDAD", "actividad"); + attributes.put("IDCLASE", 0); + attributes.put("CLASE", "clase"); + attributes.put("IDESTADO", 0); + attributes.put("ESTADO", "estado"); + attributes.put("CALLE", "calle"); + attributes.put("FFIN", new GregorianCalendar()); + attributes.put("CANTIDADOCUPADA", null); + String jsonString = "{ \"points\": [ [-97.06138, 32.837], [-97.06133, 33.836], [-98.2, 34.834], [-97, 40] ] }"; + Feature feature = null; + try { + feature = Feature.createInstanceFromJson(jsonString); + feature.setAttributes(attributes); + } catch (Exception e) { + System.out.println("Exception"); + System.out.println(e.getClass().getSimpleName() + " " + e.getMessage()); + } + return feature; + } /** * From 9a28617602fc63f8048a08a7e33518dca2bedd53 Mon Sep 17 00:00:00 2001 From: Alvaro Vega Date: Thu, 3 Oct 2024 10:12:31 +0200 Subject: [PATCH 2/3] update CNR --- CHANGES_NEXT_RELEASE | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGES_NEXT_RELEASE b/CHANGES_NEXT_RELEASE index 062ec4b8f..2d414b294 100644 --- a/CHANGES_NEXT_RELEASE +++ b/CHANGES_NEXT_RELEASE @@ -1,2 +1,3 @@ +- [cygnus-ngsi][arcgis] Fix json parse for instance of PolyLine, Polygon and Multipoint (#2423) - [cygnus-ngsi][arcgis] Check feature table is connected before use it (#2405) - [cygnus-ngsi][arcgis] Set feature table to not connected after a connection error (#2405) From bf5ba4120a6286b27dca54f9872224343fb21dd1 Mon Sep 17 00:00:00 2001 From: Alvaro Vega Date: Thu, 3 Oct 2024 12:17:39 +0200 Subject: [PATCH 3/3] replace getAsString to toString --- .../telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java | 2 +- .../telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java | 2 +- .../telefonica/iot/cygnus/backends/arcgis/model/Polygon.java | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java index c118787da..df73084d8 100644 --- a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java +++ b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/MultiPoint.java @@ -131,7 +131,7 @@ public JsonObject toJSON() { */ public static Geometry createInstanceFromJson(JsonObject json) throws ArcgisException { try { - return new MultiPoint(json.getAsString()); + return new MultiPoint(json.toString()); } catch (Exception e) { LOGGER.error(e.getClass().getSimpleName() + " error " + e.getMessage() + " parsing MultiPoint from json " + json); throw new ArcgisException("Unable to parse MultiPoint from json " + json + " due to " + e.getMessage()); diff --git a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java index b5487f3af..c10f8b3b5 100644 --- a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java +++ b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/PolyLine.java @@ -131,7 +131,7 @@ public JsonObject toJSON() { */ public static Geometry createInstanceFromJson(JsonObject json) throws ArcgisException { try { - return new PolyLine(json.getAsString()); + return new PolyLine(json.toString()); } catch (Exception e) { LOGGER.error(e.getClass().getSimpleName() + " error " + e.getMessage() + " parsing PolyLine from json " + json); throw new ArcgisException("Unable to parse PolyLine from json " + json + " due to " + e.getMessage()); diff --git a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java index d351d547a..f3d2c1bae 100644 --- a/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java +++ b/cygnus-common/src/main/java/com/telefonica/iot/cygnus/backends/arcgis/model/Polygon.java @@ -131,7 +131,7 @@ public JsonObject toJSON() { */ public static Geometry createInstanceFromJson(JsonObject json) throws ArcgisException { try { - return new Polygon(json.getAsString()); + return new Polygon(json.toString()); } catch (Exception e) { LOGGER.error(e.getClass().getSimpleName() + " error " + e.getMessage() + " parsing Polygon from json " + json); throw new ArcgisException("Unable to parse Polygon from json " + json + " due to " + e.getMessage());