ProfiledDocument definition
This commit is contained in:
parent
1a45e44c7f
commit
70289ec603
|
@ -1,5 +1,8 @@
|
||||||
This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
# Changelog for org.gcube.application.cms.cms-test-commons
|
# Changelog for org.gcube.application.cms.cms-test-commons
|
||||||
|
## [v1.0.1-SNAPSHOT] - 2021-09-11
|
||||||
|
- Introduced profiled documents
|
||||||
|
|
||||||
## [v1.0.0] - 2021-09-11
|
## [v1.0.0] - 2021-09-11
|
||||||
- First release
|
- First release
|
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>cms-test-commons</artifactId>
|
<artifactId>cms-test-commons</artifactId>
|
||||||
<version>1.0.0</version>
|
<version>1.0.1-SNAPSHOT</version>
|
||||||
<name>CMS Test Commons</name>
|
<name>CMS Test Commons</name>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,33 +1,20 @@
|
||||||
package org.gcube.application.cms.tests.model;
|
package org.gcube.application.cms.tests.model.concessioni;
|
||||||
|
|
||||||
import org.gcube.application.geoportal.common.utils.Files;
|
import org.gcube.application.geoportal.common.utils.Files;
|
||||||
import sun.misc.IOUtils;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URISyntaxException;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.net.URLDecoder;
|
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
|
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.util.Enumeration;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.jar.JarEntry;
|
|
||||||
import java.util.jar.JarFile;
|
|
||||||
import java.util.stream.Stream;
|
|
||||||
|
|
||||||
public class TestFilters {
|
public class TestConcessioniFilters {
|
||||||
|
|
||||||
public static final HashMap<String,String> filters=new HashMap<>();
|
public static final HashMap<String,String> filters=new HashMap<>();
|
||||||
|
|
||||||
static{
|
static{
|
||||||
|
|
||||||
for(File f:new File(TestModel.getBaseFolder(),"filters").listFiles()){
|
for(File f:new File(TestConcessioniModel.getBaseFolder(),"filters").listFiles()){
|
||||||
try {
|
try {
|
||||||
filters.put(f.getName(), Files.readFileAsString(f.getAbsolutePath(), Charset.defaultCharset()));
|
filters.put(f.getName(), Files.readFileAsString(f.getAbsolutePath(), Charset.defaultCharset()));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
|
@ -1,4 +1,4 @@
|
||||||
package org.gcube.application.cms.tests.model;
|
package org.gcube.application.cms.tests.model.concessioni;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
|
@ -8,7 +8,7 @@ import java.util.Arrays;
|
||||||
import org.bson.types.ObjectId;
|
import org.bson.types.ObjectId;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.*;
|
import org.gcube.application.geoportal.common.model.legacy.*;
|
||||||
|
|
||||||
public class TestModel {
|
public class TestConcessioniModel {
|
||||||
|
|
||||||
public static File getBaseFolder(){
|
public static File getBaseFolder(){
|
||||||
File toReturn =new File("../test-data/concessioni");
|
File toReturn =new File("../test-data/concessioni");
|
|
@ -1,21 +1,19 @@
|
||||||
package org.gcube.application.cms.tests.model;
|
package org.gcube.application.cms.tests.model.concessioni;
|
||||||
|
|
||||||
import org.gcube.application.geoportal.common.utils.Files;
|
import org.gcube.application.geoportal.common.utils.Files;
|
||||||
import sun.misc.IOUtils;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
public class TestQueries {
|
public class TestConcessioniQueries {
|
||||||
|
|
||||||
public static final HashMap<String,String> queries =new HashMap<>();
|
public static final HashMap<String,String> queries =new HashMap<>();
|
||||||
|
|
||||||
static{
|
static{
|
||||||
|
|
||||||
for(File f:new File(TestModel.getBaseFolder(),"queries").listFiles()){
|
for(File f:new File(TestConcessioniModel.getBaseFolder(),"queries").listFiles()){
|
||||||
try {
|
try {
|
||||||
queries.put(f.getName(), Files.readFileAsString(f.getAbsolutePath(), Charset.defaultCharset()));
|
queries.put(f.getName(), Files.readFileAsString(f.getAbsolutePath(), Charset.defaultCharset()));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
|
@ -0,0 +1,6 @@
|
||||||
|
package org.gcube.application.cms.commons.model;
|
||||||
|
|
||||||
|
public class Serialization {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
package org.gcube.application.cms.commons.model.concessioni;
|
package org.gcube.application.cms.commons.model.concessioni;
|
||||||
|
|
||||||
import org.gcube.application.cms.tests.model.TestFilters;
|
import org.gcube.application.cms.tests.model.concessioni.TestConcessioniFilters;
|
||||||
import org.gcube.application.cms.tests.model.TestModel;
|
import org.gcube.application.cms.tests.model.concessioni.TestConcessioniModel;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -11,14 +11,14 @@ public class Models {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void checkFilters(){
|
public void checkFilters(){
|
||||||
assertTrue(TestFilters.filters.size()>0);
|
assertTrue(TestConcessioniFilters.filters.size()>0);
|
||||||
TestFilters.filters.keySet().forEach(f -> {
|
TestConcessioniFilters.filters.keySet().forEach(f -> {
|
||||||
System.out.println(f);});
|
System.out.println(f);});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void checkConcessione(){
|
public void checkConcessione(){
|
||||||
Concessione c= TestModel.prepareConcessione(3,5);
|
Concessione c= TestConcessioniModel.prepareConcessione(3,5);
|
||||||
assertTrue(c.getPianteFineScavo().size()==3);
|
assertTrue(c.getPianteFineScavo().size()==3);
|
||||||
assertTrue(c.getImmaginiRappresentative().size()==5);
|
assertTrue(c.getImmaginiRappresentative().size()==5);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ package org.gcube.application.cms.commons.model.concessioni;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
import org.gcube.application.cms.tests.model.TestModel;
|
import org.gcube.application.cms.tests.model.concessioni.TestConcessioniModel;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.Concessione.Paths;
|
import org.gcube.application.geoportal.common.model.legacy.Concessione.Paths;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.LayerConcessione;
|
import org.gcube.application.geoportal.common.model.legacy.LayerConcessione;
|
||||||
|
@ -17,8 +17,8 @@ public class PathsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void embeddedPaths() {
|
public void embeddedPaths() {
|
||||||
Concessione c= TestModel.prepareConcessione();
|
Concessione c= TestConcessioniModel.prepareConcessione();
|
||||||
c=TestModel.setIds(c);
|
c= TestConcessioniModel.setIds(c);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -3,11 +3,10 @@ package org.gcube.application.cms.commons.model.concessioni;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.gcube.application.cms.tests.model.TestModel;
|
import org.gcube.application.cms.tests.model.concessioni.TestConcessioniModel;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.AccessPolicy;
|
import org.gcube.application.geoportal.common.model.legacy.AccessPolicy;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
||||||
import org.gcube.application.geoportal.common.model.profile.Profile;
|
import org.gcube.application.geoportal.common.model.profile.Profile;
|
||||||
import org.gcube.application.geoportal.common.utils.Files;
|
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -38,7 +37,7 @@ public class SerializationTest {
|
||||||
@Test
|
@Test
|
||||||
public void readProfile() throws JsonProcessingException, IOException {
|
public void readProfile() throws JsonProcessingException, IOException {
|
||||||
|
|
||||||
Profile concessione=mapper.readerFor(Profile.class).readValue(new File(TestModel.getBaseFolder(),"ProfileConcessioni.json"));
|
Profile concessione=mapper.readerFor(Profile.class).readValue(new File(TestConcessioniModel.getBaseFolder(),"ProfileConcessioni.json"));
|
||||||
|
|
||||||
System.out.println("Profile is "+mapper.writeValueAsString(concessione));
|
System.out.println("Profile is "+mapper.writeValueAsString(concessione));
|
||||||
|
|
||||||
|
@ -48,7 +47,7 @@ public class SerializationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void readConcessione() throws JsonProcessingException, IOException {
|
public void readConcessione() throws JsonProcessingException, IOException {
|
||||||
Concessione concessione=mapper.readerFor(Concessione.class).readValue(new File(TestModel.getBaseFolder(),"Concessione.json"));
|
Concessione concessione=mapper.readerFor(Concessione.class).readValue(new File(TestConcessioniModel.getBaseFolder(),"Concessione.json"));
|
||||||
System.out.println("Concessione is "+concessione.toString());
|
System.out.println("Concessione is "+concessione.toString());
|
||||||
|
|
||||||
concessione.getRelazioneScavo().setPolicy(AccessPolicy.EMBARGOED);
|
concessione.getRelazioneScavo().setPolicy(AccessPolicy.EMBARGOED);
|
||||||
|
@ -61,7 +60,7 @@ public class SerializationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void generic() throws JsonProcessingException, IOException {
|
public void generic() throws JsonProcessingException, IOException {
|
||||||
Concessione conc= TestModel.prepareConcessione();
|
Concessione conc= TestConcessioniModel.prepareConcessione();
|
||||||
conc.validate();
|
conc.validate();
|
||||||
full(conc);
|
full(conc);
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,7 @@ import java.util.Collections;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.concurrent.atomic.AtomicLong;
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
|
import org.bson.Document;
|
||||||
import org.gcube.application.cms.tests.model.TestFilters;
|
import org.gcube.application.cms.tests.model.TestFilters;
|
||||||
import org.gcube.application.cms.tests.model.TestModel;
|
import org.gcube.application.cms.tests.model.TestModel;
|
||||||
import org.gcube.application.cms.tests.model.TestQueries;
|
import org.gcube.application.cms.tests.model.TestQueries;
|
||||||
|
@ -20,6 +21,7 @@ import org.gcube.application.geoportal.common.model.legacy.*;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.Concessione.Paths;
|
import org.gcube.application.geoportal.common.model.legacy.Concessione.Paths;
|
||||||
import org.gcube.application.geoportal.common.model.legacy.report.ValidationReport.ValidationStatus;
|
import org.gcube.application.geoportal.common.model.legacy.report.ValidationReport.ValidationStatus;
|
||||||
import org.gcube.application.geoportal.common.model.rest.AddSectionToConcessioneRequest;
|
import org.gcube.application.geoportal.common.model.rest.AddSectionToConcessioneRequest;
|
||||||
|
import org.gcube.application.geoportal.common.model.rest.QueryRequest;
|
||||||
import org.gcube.application.geoportal.common.rest.MongoConcessioni;
|
import org.gcube.application.geoportal.common.rest.MongoConcessioni;
|
||||||
import org.gcube.application.geoportal.common.utils.FileSets;
|
import org.gcube.application.geoportal.common.utils.FileSets;
|
||||||
import org.gcube.application.geoportal.common.utils.Files;
|
import org.gcube.application.geoportal.common.utils.Files;
|
||||||
|
@ -45,11 +47,18 @@ public class StatelessClientTests extends BasicVreTests{
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void query() throws Exception {
|
public void query() throws Exception {
|
||||||
|
QueryRequest req=new QueryRequest();
|
||||||
|
req.setFilter(Document.parse("{ \"nome\" : { \"$eq\" : \"mock\" } }"));
|
||||||
|
|
||||||
|
System.out.println("FRA "+ count(client.query(req)));
|
||||||
|
|
||||||
// No Transformation
|
// No Transformation
|
||||||
System.out.print("First Registered \t");
|
System.out.print("First Registered \t");
|
||||||
Iterator<Concessione> queriedDocuments=client.query(
|
Iterator<Concessione> queriedDocuments=client.query(
|
||||||
|
|
|
@ -5,6 +5,9 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
|
||||||
# [v1.0.8-SNAPSHOT] - 2021-11-10
|
# [v1.0.8-SNAPSHOT] - 2021-11-10
|
||||||
- Fixes [#22369](https://support.d4science.org/issues/22369)
|
- Fixes [#22369](https://support.d4science.org/issues/22369)
|
||||||
- Fixes [#22338](https://support.d4science.org/issues/22338)
|
- Fixes [#22338](https://support.d4science.org/issues/22338)
|
||||||
|
- Profiled Documents
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# [v1.0.7] - 2021-09-20
|
# [v1.0.7] - 2021-09-20
|
||||||
- Refactored repositories
|
- Refactored repositories
|
||||||
|
|
|
@ -4,7 +4,6 @@ import lombok.*;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
|
|
|
@ -6,7 +6,6 @@ import java.time.LocalDateTime;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
|
|
|
@ -19,6 +19,8 @@ package org.gcube.application.geoportal.common.model.document;
|
||||||
* under the License.
|
* under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import lombok.*;
|
||||||
|
|
||||||
import java.math.BigInteger;
|
import java.math.BigInteger;
|
||||||
import java.util.ArrayDeque;
|
import java.util.ArrayDeque;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -60,6 +62,12 @@ import java.util.Properties;
|
||||||
* @author <a href="mailto:kenney@apache.org">Kenney Westerhof</a>
|
* @author <a href="mailto:kenney@apache.org">Kenney Westerhof</a>
|
||||||
* @author <a href="mailto:hboutemy@apache.org">Hervé Boutemy</a>
|
* @author <a href="mailto:hboutemy@apache.org">Hervé Boutemy</a>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@ToString
|
||||||
public class ComparableVersion
|
public class ComparableVersion
|
||||||
implements Comparable<ComparableVersion>
|
implements Comparable<ComparableVersion>
|
||||||
{
|
{
|
||||||
|
|
|
@ -4,7 +4,6 @@ import lombok.*;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
|
|
|
@ -2,11 +2,24 @@ package org.gcube.application.geoportal.common.model.document;
|
||||||
|
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
public class LifecycleInformation {
|
public class LifecycleInformation {
|
||||||
|
|
||||||
|
public enum Status{
|
||||||
|
PASSED,ERROR,WARNING
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private String phase;
|
||||||
|
private Status lastOperationStatus;
|
||||||
|
private List<String> errorMessages;
|
||||||
|
private List<String> warningMessages;
|
||||||
|
private List<LifecycleInformation> children;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,6 @@ import org.bson.Document;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
|
|
|
@ -5,7 +5,6 @@ import org.gcube.application.geoportal.common.model.legacy.AccessPolicy;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
|
|
|
@ -4,9 +4,12 @@ import lombok.*;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
public class Relationship {
|
public class Relationship {
|
||||||
|
|
||||||
|
private String relationshipName;
|
||||||
|
private String targetID;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,9 +4,10 @@ import lombok.*;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
public class TemporalReference {
|
public class TemporalReference {
|
||||||
|
|
||||||
|
private String field;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,6 @@ import lombok.*;
|
||||||
|
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@RequiredArgsConstructor
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
|
|
|
@ -7,6 +7,8 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
|
||||||
- Fixes [#22193](https://support.d4science.org/issues/22193)
|
- Fixes [#22193](https://support.d4science.org/issues/22193)
|
||||||
- Fixes [#22280](https://support.d4science.org/issues/22280)
|
- Fixes [#22280](https://support.d4science.org/issues/22280)
|
||||||
- Fixes [#20755](https://support.d4science.org/issues/20755)
|
- Fixes [#20755](https://support.d4science.org/issues/20755)
|
||||||
|
- Profiled Documents
|
||||||
|
|
||||||
|
|
||||||
## [v1.0.6] 2021-09-20
|
## [v1.0.6] 2021-09-20
|
||||||
- Refactored repositories
|
- Refactored repositories
|
||||||
|
|
|
@ -1,24 +1,29 @@
|
||||||
package org.gcube.application.geoportal.service.engine.mongo;
|
package org.gcube.application.geoportal.service.engine.mongo;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import org.bson.Document;
|
||||||
import org.gcube.application.geoportal.common.model.rest.QueryRequest;
|
import org.gcube.application.geoportal.common.model.rest.QueryRequest;
|
||||||
|
import org.gcube.application.geoportal.service.model.internal.faults.DeletionException;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
public interface MongoManagerI<T> {
|
public interface MongoManagerI<T> {
|
||||||
|
|
||||||
|
|
||||||
// create
|
// create
|
||||||
|
|
||||||
public T registerNew(T toRegister);
|
public T registerNew(T toRegister) throws IOException;
|
||||||
|
|
||||||
// update
|
// update
|
||||||
public T update(String id,T toSet);
|
public T update(String id,T toSet) throws IOException;
|
||||||
|
|
||||||
// delete
|
// delete
|
||||||
|
|
||||||
public void delete(String id);
|
public void delete(String id,boolean force) throws DeletionException;
|
||||||
|
|
||||||
// get By ID
|
// get By ID
|
||||||
|
|
||||||
public T getByID(String id);
|
public T getByID(String id) throws IOException;
|
||||||
|
|
||||||
// query
|
// query
|
||||||
|
|
||||||
|
@ -37,4 +42,6 @@ public interface MongoManagerI<T> {
|
||||||
|
|
||||||
// deIndex
|
// deIndex
|
||||||
public T deIndex(String id);
|
public T deIndex(String id);
|
||||||
|
|
||||||
|
public T performStep(String id, String step, Document options);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,145 @@
|
||||||
package org.gcube.application.geoportal.service.engine.mongo;
|
package org.gcube.application.geoportal.service.engine.mongo;
|
||||||
|
|
||||||
public class ProfiledMongoManager {
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.mongodb.client.MongoDatabase;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.bson.Document;
|
||||||
|
import org.bson.types.ObjectId;
|
||||||
|
import org.gcube.application.geoportal.common.model.document.ProfiledDocument;
|
||||||
|
import org.gcube.application.geoportal.common.model.legacy.Concessione;
|
||||||
|
import org.gcube.application.geoportal.common.model.legacy.report.ValidationReport;
|
||||||
|
import org.gcube.application.geoportal.common.model.rest.QueryRequest;
|
||||||
|
import org.gcube.application.geoportal.service.model.internal.faults.ConfigurationException;
|
||||||
|
import org.gcube.application.geoportal.service.model.internal.faults.DeletionException;
|
||||||
|
import org.gcube.application.geoportal.service.utils.Serialization;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.LinkedBlockingQueue;
|
||||||
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
|
import static org.gcube.application.geoportal.service.engine.mongo.ConcessioniMongoManager.asConcessione;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
public class ProfiledMongoManager extends MongoManager implements MongoManagerI<ProfiledDocument>{
|
||||||
|
|
||||||
|
|
||||||
|
public ProfiledMongoManager() throws ConfigurationException {
|
||||||
|
}
|
||||||
|
|
||||||
|
private ProfiledDocument onUpdate(ProfiledDocument updatedDocument){
|
||||||
|
throw new RuntimeException("Implement Me");
|
||||||
|
}
|
||||||
|
|
||||||
|
private Document asDocument(ProfiledDocument d) throws JsonProcessingException {
|
||||||
|
return Document.parse(Serialization.write(d));
|
||||||
|
}
|
||||||
|
|
||||||
|
private ProfiledDocument asProfiledDocument(Document d) throws IOException {
|
||||||
|
return Serialization.read(d.toJson(),ProfiledDocument.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getCollectionName(){
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected MongoDatabase getDatabase() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument registerNew(ProfiledDocument toRegister) throws IOException {
|
||||||
|
super.insert(asDocument(toRegister),getCollectionName());
|
||||||
|
|
||||||
|
log.trace("Going to register {} ",toRegister);
|
||||||
|
toRegister=onUpdate(toRegister);
|
||||||
|
log.trace("Concessione with defaults is {}",toRegister);
|
||||||
|
ObjectId id=insert(asDocument(toRegister), getCollectionName());
|
||||||
|
|
||||||
|
log.trace("Obtained id {}",id);
|
||||||
|
ProfiledDocument toReturn=asProfiledDocument(getById(id,getCollectionName()));
|
||||||
|
toReturn.setId(asString(id));
|
||||||
|
|
||||||
|
|
||||||
|
toReturn = asProfiledDocument(replace(asDocument(toReturn),getCollectionName()));
|
||||||
|
log.debug("Registered {} ",toReturn);
|
||||||
|
return toReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument update(String id, ProfiledDocument toSet) throws IOException {
|
||||||
|
log.trace("Replacing {} ",toSet);
|
||||||
|
toSet=onUpdate(toSet);
|
||||||
|
return asProfiledDocument(replace(asDocument(toSet),getCollectionName()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void delete(String id,boolean force) throws DeletionException {
|
||||||
|
log.debug("Deleting by ID {}, force {}",id,force);
|
||||||
|
try{
|
||||||
|
ProfiledDocument doc =getByID(id);
|
||||||
|
|
||||||
|
|
||||||
|
//if(!force&&isPublished(id)) throw new Exception("Cannot delete published documents. Unpublish it or use force = true");
|
||||||
|
|
||||||
|
try{
|
||||||
|
// TODO CHECK PHASE AND STATUS
|
||||||
|
// DEINDEX
|
||||||
|
// DEMATERIALIZE
|
||||||
|
// DELETE CONTENT
|
||||||
|
// DELETE ENTRY
|
||||||
|
throw new DeletionException("IMPLEMENT THIS");
|
||||||
|
// delete(asId(id), getCollectionName());
|
||||||
|
}catch(DeletionException e) {
|
||||||
|
//storing updated - partially deleted
|
||||||
|
// concessione=onUpdate(concessione);
|
||||||
|
// replace(asDocument(concessione), collectionName);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
}catch(Throwable t){
|
||||||
|
throw new DeletionException("Unable to delete "+id,t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument getByID(String id) throws IOException {
|
||||||
|
return asProfiledDocument(super.getById(asId(id),getCollectionName()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Iterable<ProfiledDocument> query(QueryRequest queryRequest) {
|
||||||
|
log.info("Searching concessione for filter {} ",queryRequest);
|
||||||
|
LinkedBlockingQueue queue=new LinkedBlockingQueue<Concessione>();
|
||||||
|
query(queryRequest,getCollectionName()).forEach(
|
||||||
|
(Consumer<? super Document>) (Document d)->{try{
|
||||||
|
queue.put(d);
|
||||||
|
}catch(Throwable t){log.warn("Unable to translate "+d);}});
|
||||||
|
log.info("Returned {} elements ",queue.size());
|
||||||
|
return queue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument materialize(String id) {
|
||||||
|
throw new RuntimeException("TO IMPLEMENT");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument dematerialize(String id) {
|
||||||
|
throw new RuntimeException("TO IMPLEMENT");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument index(String id) {
|
||||||
|
throw new RuntimeException("TO IMPLEMENT");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument deIndex(String id) {
|
||||||
|
throw new RuntimeException("TO IMPLEMENT");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProfiledDocument performStep(String id, String step, Document options) {
|
||||||
|
throw new RuntimeException("TO IMPLEMENT");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
{
|
||||||
|
"filter" : { "nome" : { "$eq" : "stupid_mock_impossible_to_find_one" } }
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue