From a51405c843a437ebf7e443bd656465c8e5463cfc Mon Sep 17 00:00:00 2001 From: Luca Frosini Date: Fri, 15 Oct 2021 17:27:45 +0200 Subject: [PATCH] Added more possibilities --- .../query/json/JsonQueryERElement.java | 13 +++++++++++++ .../query/json/JsonQueryIsRelatedTo.java | 11 +++++++++-- .../query/json/JsonQueryResource.java | 14 ++++++++++++++ .../resourceregistry/query/query.json | 10 +++++++++- 4 files changed, 45 insertions(+), 3 deletions(-) diff --git a/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryERElement.java b/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryERElement.java index 380fc06..abf1ba7 100644 --- a/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryERElement.java +++ b/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryERElement.java @@ -6,6 +6,7 @@ import org.gcube.com.fasterxml.jackson.databind.JsonNode; import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.Direction; import org.gcube.informationsystem.base.reference.Element; +import org.gcube.informationsystem.model.reference.entities.Resource; import org.gcube.informationsystem.model.reference.relations.Relation; import org.gcube.informationsystem.resourceregistry.api.exceptions.query.InvalidQueryException; import org.gcube.informationsystem.resourceregistry.api.exceptions.schema.SchemaNotFoundException; @@ -71,6 +72,18 @@ public abstract class JsonQueryERElement { continue; } + if(fieldName.compareTo(Relation.SOURCE_PROPERTY)==0) { + continue; + } + + if(fieldName.compareTo(Resource.CONSISTS_OF_PROPERTY)==0) { + continue; + } + + if(fieldName.compareTo(Resource.IS_RELATED_TO_PROPERTY)==0) { + continue; + } + if(first) { first = false; }else { diff --git a/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryIsRelatedTo.java b/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryIsRelatedTo.java index f106964..88fc98e 100644 --- a/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryIsRelatedTo.java +++ b/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryIsRelatedTo.java @@ -31,10 +31,13 @@ public class JsonQueryIsRelatedTo extends JsonQueryERElement{ int size = jsonNode.size(); if(size > 2) { - buffer.append("SELECT FROM ( "); + buffer.append("SELECT FROM "); if(entryPoint) { buffer.append(type); + }else { + buffer.append(" ( "); // Open ( SELECT } + }else { if(entryPoint) { buffer.append("SELECT FROM "); @@ -57,7 +60,11 @@ public class JsonQueryIsRelatedTo extends JsonQueryERElement{ // Size 2 means that only '@class' and 'target'/'source' properties are present if(size > 2) { - stringBuffer.append(") WHERE "); // Close ) SELECT + if(!entryPoint) { + stringBuffer.append(" )"); // Close ) SELECT + } + stringBuffer.append(" WHERE "); + stringBuffer = addWhereConstraint(jsonNode, buffer, null); } diff --git a/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryResource.java b/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryResource.java index 227f19c..b0f60e5 100644 --- a/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryResource.java +++ b/src/main/java/org/gcube/informationsystem/resourceregistry/query/json/JsonQueryResource.java @@ -4,6 +4,7 @@ import org.gcube.com.fasterxml.jackson.databind.JsonNode; import org.gcube.com.fasterxml.jackson.databind.node.ArrayNode; import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.Direction; +import org.gcube.informationsystem.base.reference.IdentifiableElement; import org.gcube.informationsystem.model.reference.entities.Resource; import org.gcube.informationsystem.resourceregistry.api.exceptions.query.InvalidQueryException; import org.gcube.informationsystem.resourceregistry.api.exceptions.schema.SchemaNotFoundException; @@ -68,6 +69,9 @@ public class JsonQueryResource extends JsonQueryERElement { stringBuffer = new StringBuffer(); stringBuffer.append("SELECT FROM "); stringBuffer.append(type); + if(jsonNode.has(IdentifiableElement.HEADER_PROPERTY)) { + + } } // else { // StringBuffer newBuffer = new StringBuffer(); @@ -82,6 +86,16 @@ public class JsonQueryResource extends JsonQueryERElement { // } } + + if(jsonNode.has(IdentifiableElement.HEADER_PROPERTY)) { + StringBuffer newBuffer = new StringBuffer(); + newBuffer.append("SELECT FROM ( "); + newBuffer.append(stringBuffer); + newBuffer.append(") WHERE "); + addWhereConstraint(jsonNode, newBuffer, null); + stringBuffer = newBuffer; + } + return stringBuffer; } diff --git a/src/test/java/org/gcube/informationsystem/resourceregistry/query/query.json b/src/test/java/org/gcube/informationsystem/resourceregistry/query/query.json index 44f5464..3d65608 100644 --- a/src/test/java/org/gcube/informationsystem/resourceregistry/query/query.json +++ b/src/test/java/org/gcube/informationsystem/resourceregistry/query/query.json @@ -1,6 +1,8 @@ { - "@class": "EService", + "header": { + "uuid": "0255b7ec-e3da-4071-b456-9a2907ece1db" + }, "consistsOf": [ { "@class": "ConsistsOf", @@ -31,8 +33,14 @@ "isRelatedTo" : [ { "@class": "Activates", + "header": { + "uuid": "d3f58e52-5346-47bc-b736-9d77a0b554ce" + }, "source": { "@class": "HostingNode", + "header": { + "uuid" : "5fbc1a56-d450-4f0f-85c1-9b1684581717" + }, "consistsOf": [ { "@class": "ConsistsOf",