task_28150 #19

Merged
francesco.mangiacrapa merged 14 commits from task_28150 into master 2024-10-04 15:07:01 +02:00
24 changed files with 287 additions and 232 deletions

View File

@ -2,7 +2,7 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
# Changelog for org.gcube.spatial.data.gcube-sdi-suite # Changelog for org.gcube.spatial.data.gcube-sdi-suite
## [v1.0.6] ## [v1.0.6-SNAPSHOT]
- Integrated an EventManager centrally [#26321] - Integrated an EventManager centrally [#26321]
- sdi-plugins: add the logic to apply a regex to the value that must be added to index [#26322] - sdi-plugins: add the logic to apply a regex to the value that must be added to index [#26322]

View File

@ -1,5 +1,9 @@
# Changelog for org.gcube.application.cms-plugin-framework # Changelog for org.gcube.application.cms-plugin-framework
## [v1.0.6-SNAPSHOT] - 2024-10-01
- Included the file size to reduce/optimize the time to upload files to the storage hub [#28150]
## [v1.0.5] - 2024-07-03 ## [v1.0.5] - 2024-07-03
- Implemented Event Broker [#26321] - Implemented Event Broker [#26321]

View File

@ -4,7 +4,7 @@
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>cms-plugin-framework</artifactId> <artifactId>cms-plugin-framework</artifactId>
<version>1.0.5</version> <version>1.0.6-SNAPSHOT</version>
<parent> <parent>
<groupId>org.gcube.application.cms</groupId> <groupId>org.gcube.application.cms</groupId>

View File

@ -24,7 +24,6 @@ public class WorkspaceManager {
private static final String APP_FOLDER = ".GNA_RECORDS"; private static final String APP_FOLDER = ".GNA_RECORDS";
private StorageHubClient sgClient = null; private StorageHubClient sgClient = null;
@Getter @Getter
private FolderContainer appBase = null; private FolderContainer appBase = null;
@ -52,7 +51,8 @@ public class WorkspaceManager {
private String fileDescription; private String fileDescription;
private FolderContainer parent; private FolderContainer parent;
// Added by Francesco, see #28150
private Long size;
} }
public Archive getConfiguration() { public Archive getConfiguration() {
@ -88,7 +88,6 @@ public class WorkspaceManager {
return getSubFolder(parentFolder, path, ""); return getSubFolder(parentFolder, path, "");
} }
/** /**
* Returns sub folder. Creates it if missing * Returns sub folder. Creates it if missing
* *
@ -97,7 +96,8 @@ public class WorkspaceManager {
* @return * @return
* @throws StorageHubException * @throws StorageHubException
*/ */
public FolderContainer getSubFolder(FolderContainer parentFolder,String path, String description) throws StorageHubException { public FolderContainer getSubFolder(FolderContainer parentFolder, String path, String description)
throws StorageHubException {
try { try {
return parentFolder.openByRelativePath(path).asFolder(); return parentFolder.openByRelativePath(path).asFolder();
} catch (StorageHubException e) { } catch (StorageHubException e) {
@ -116,7 +116,6 @@ public class WorkspaceManager {
} }
} }
// public WorkspaceContent storeToWS(FileOptions opts) throws FileNotFoundException, StorageHubException { // public WorkspaceContent storeToWS(FileOptions opts) throws FileNotFoundException, StorageHubException {
// FileContainer item=createFileRoutine(opts); // FileContainer item=createFileRoutine(opts);
// item=sgClient.open(item.getId()).asFile(); // item=sgClient.open(item.getId()).asFile();
@ -136,7 +135,6 @@ public class WorkspaceManager {
RegisteredFile file = new RegisteredFile(); RegisteredFile file = new RegisteredFile();
file.setLink(item.getPublicLink().toString()); file.setLink(item.getPublicLink().toString());
file.setMimetype(item.get().getContent().getMimeType()); file.setMimetype(item.get().getContent().getMimeType());
file.setStorageID(item.getId()); file.setStorageID(item.getId());
@ -145,7 +143,6 @@ public class WorkspaceManager {
} }
// public void deleteFromWS(WorkspaceContent toDelete) throws StorageHubException { // public void deleteFromWS(WorkspaceContent toDelete) throws StorageHubException {
// sgClient.open(toDelete.getStorageID()).asFile().forceDelete(); // sgClient.open(toDelete.getStorageID()).asFile().forceDelete();
// } // }
@ -162,7 +159,7 @@ public class WorkspaceManager {
try { try {
return vre.openByRelativePath(APP_FOLDER).asFolder(); return vre.openByRelativePath(APP_FOLDER).asFolder();
} catch (StorageHubException e) { } catch (StorageHubException e) {
log.debug("APP Fodler missing. Initializing.."); log.debug("APP Folder missing. Initializing..");
FolderContainer toReturn = vre.newFolder(APP_FOLDER, "Base folder for GNA records"); FolderContainer toReturn = vre.newFolder(APP_FOLDER, "Base folder for GNA records");
toReturn.setHidden(); toReturn.setHidden();
return toReturn; return toReturn;
@ -177,7 +174,14 @@ public class WorkspaceManager {
@Synchronized @Synchronized
private static FileContainer createFileRoutine(FileOptions opts) throws StorageHubException { private static FileContainer createFileRoutine(FileOptions opts) throws StorageHubException {
// Updated by Francesco, see #28150
log.info("Uploading file name: {}, in the parent folder id: {}, filesize is: " + opts.getSize(),
opts.getFileName(), opts.getParent().getId());
opts.setFileName(Files.fixFilename(opts.getFileName())); opts.setFileName(Files.fixFilename(opts.getFileName()));
if (opts.getSize() == null)
return opts.getParent().uploadFile(opts.getIs(), opts.getFileName(), opts.getFileDescription()); return opts.getParent().uploadFile(opts.getIs(), opts.getFileName(), opts.getFileDescription());
else
return opts.getParent().uploadFile(opts.getIs(), opts.getFileName(), opts.getFileDescription(),
opts.getSize());
} }
} }

View File

@ -1,5 +1,8 @@
# Changelog for org.gcube.application.geoportal-common # Changelog for org.gcube.application.geoportal-common
## [v1.1.1-SNAPSHOT] - 2024-10-01
- Included the file size to reduce/optimize the time to upload files to the storage hub [#28150]
## [v1.1.0] - 2024-04-08 ## [v1.1.0] - 2024-04-08
- Added message to StepExecutionRequest [#27192] - Added message to StepExecutionRequest [#27192]
- Fixed pom. Duplicate declaration of `registry-publisher` dependency - Fixed pom. Duplicate declaration of `registry-publisher` dependency

View File

@ -3,7 +3,7 @@
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>geoportal-common</artifactId> <artifactId>geoportal-common</artifactId>
<version>1.1.0</version> <version>1.1.1-SNAPSHOT</version>
<name>Geoportal Common</name> <name>Geoportal Common</name>
<parent> <parent>

View File

@ -15,8 +15,20 @@ public class TempFile {
private String url; private String url;
private String filename; private String filename;
// Added by Francesco, see #28150
private Long size;
public void validate() throws InvalidRequestException { public void validate() throws InvalidRequestException {
if((id==null || id.isEmpty() )&&(url==null||url.isEmpty())) throw new InvalidRequestException("Invalid temp file "+this+" : ID null or empty and no url defined"); if ((id == null || id.isEmpty()) && (url == null || url.isEmpty()))
if(filename==null || filename.isEmpty()) throw new InvalidRequestException("Invalid temp file "+this+" : filename null or empty"); throw new InvalidRequestException("Invalid temp file " + this + " : ID null or empty and no url defined");
if (filename == null || filename.isEmpty())
throw new InvalidRequestException("Invalid temp file " + this + " : filename null or empty");
} }
public TempFile(String id, String url, String filename) {
this.id = id;
this.url = url;
this.filename = filename;
}
} }

View File

@ -11,9 +11,9 @@ import org.gcube.application.geoportal.common.model.document.access.Access;
import org.gcube.application.geoportal.common.model.document.relationships.RelationshipNavigationObject; import org.gcube.application.geoportal.common.model.document.relationships.RelationshipNavigationObject;
import org.gcube.application.geoportal.common.model.rest.CreateRelationshipRequest; import org.gcube.application.geoportal.common.model.rest.CreateRelationshipRequest;
import org.gcube.application.geoportal.common.model.rest.DeleteRelationshipRequest; import org.gcube.application.geoportal.common.model.rest.DeleteRelationshipRequest;
import org.gcube.application.geoportal.common.model.rest.PerformStepRequest;
import org.gcube.application.geoportal.common.model.rest.QueryRequest; import org.gcube.application.geoportal.common.model.rest.QueryRequest;
import org.gcube.application.geoportal.common.model.rest.RegisterFileSetRequest; import org.gcube.application.geoportal.common.model.rest.RegisterFileSetRequest;
import org.gcube.application.geoportal.common.model.rest.PerformStepRequest;
public interface Projects<P extends Project> { public interface Projects<P extends Project> {

View File

@ -13,6 +13,9 @@ import org.gcube.application.geoportal.common.model.rest.RegisterFileSetRequest;
import org.gcube.application.geoportal.common.model.rest.TempFile; import org.gcube.application.geoportal.common.model.rest.TempFile;
import org.gcube.contentmanagement.blobstorage.transport.backend.RemoteBackendException; import org.gcube.contentmanagement.blobstorage.transport.backend.RemoteBackendException;
import lombok.extern.slf4j.Slf4j;
@Slf4j
public class FileSets { public class FileSets {
public static class RequestBuilder { public static class RequestBuilder {
@ -24,6 +27,7 @@ public class FileSets {
theRequest.getStreams().addAll(toAdd); theRequest.getStreams().addAll(toAdd);
return this; return this;
} }
public RequestBuilder add(TempFile... f) { public RequestBuilder add(TempFile... f) {
if (theRequest.getStreams() == null) if (theRequest.getStreams() == null)
theRequest.setStreams(new ArrayList<TempFile>()); theRequest.setStreams(new ArrayList<TempFile>());
@ -68,7 +72,8 @@ public class FileSets {
if (theRequest.getClashOption() == null) if (theRequest.getClashOption() == null)
// default Clash Policy // default Clash Policy
setClashPolicy(RegisterFileSetRequest.ClashOptions.REPLACE_EXISTING); setClashPolicy(RegisterFileSetRequest.ClashOptions.REPLACE_EXISTING);
return theRequest;} return theRequest;
}
public RequestBuilder setAccess(Access access) { public RequestBuilder setAccess(Access access) {
theRequest.setToSetAccess(access); theRequest.setToSetAccess(access);
@ -77,28 +82,30 @@ public class FileSets {
} }
public static RequestBuilder build(String parent, String fieldName, String fieldDefinition) { public static RequestBuilder build(String parent, String fieldName, String fieldDefinition) {
return new RequestBuilder().setParentPath(parent).setFieldDefinitionPath(fieldDefinition).setFieldName(fieldName); return new RequestBuilder().setParentPath(parent).setFieldDefinitionPath(fieldDefinition)
.setFieldName(fieldName);
} }
public static RequestBuilder build(String parent, String fieldName, String fieldDefinition, TempFile... files) { public static RequestBuilder build(String parent, String fieldName, String fieldDefinition, TempFile... files) {
return build(parent, fieldName, fieldDefinition).add(files); return build(parent, fieldName, fieldDefinition).add(files);
} }
public static TempFile asTemp(StorageUtils storage,InputStreamDescriptor descriptor) throws RemoteBackendException, FileNotFoundException { public static TempFile asTemp(StorageUtils storage, InputStreamDescriptor descriptor)
throws RemoteBackendException, FileNotFoundException {
return storage.putOntoStorage(descriptor.getStream(), descriptor.getFilename()); return storage.putOntoStorage(descriptor.getStream(), descriptor.getFilename());
} }
public static TempFile[] asTemp(StorageUtils storage,InputStreamDescriptor... descriptors) throws RemoteBackendException, FileNotFoundException { public static TempFile[] asTemp(StorageUtils storage, InputStreamDescriptor... descriptors)
throws RemoteBackendException, FileNotFoundException {
ArrayList<TempFile> toReturn = new ArrayList<TempFile>(); ArrayList<TempFile> toReturn = new ArrayList<TempFile>();
for (InputStreamDescriptor desc : descriptors) for (InputStreamDescriptor desc : descriptors)
toReturn.add(storage.putOntoStorage(desc.getStream(), desc.getFilename())); toReturn.add(storage.putOntoStorage(desc.getStream(), desc.getFilename()));
return toReturn.toArray(new TempFile[toReturn.size()]); return toReturn.toArray(new TempFile[toReturn.size()]);
} }
public static RegisterFileSetRequest prepareRequestFromFolder(StorageUtils storage, public static RegisterFileSetRequest prepareRequestFromFolder(StorageUtils storage, String parentPath,
String parentPath,String fieldName,String fieldDefinition, File directory) throws FileNotFoundException { String fieldName, String fieldDefinition, File directory) throws FileNotFoundException {
File[] children = directory.listFiles(); File[] children = directory.listFiles();
InputStreamDescriptor[] iss = new InputStreamDescriptor[children.length]; InputStreamDescriptor[] iss = new InputStreamDescriptor[children.length];
@ -106,13 +113,20 @@ public class FileSets {
} }
public static RegisterFileSetRequest prepareRequest(StorageUtils storage, public static RegisterFileSetRequest prepareRequest(StorageUtils storage, String parentPath, String fieldName,
String parentPath,String fieldName,String fieldDefinition, File... toUpload) throws FileNotFoundException { String fieldDefinition, File... toUpload) throws FileNotFoundException {
FileSets.RequestBuilder builder = FileSets.build(parentPath, fieldName, fieldDefinition); FileSets.RequestBuilder builder = FileSets.build(parentPath, fieldName, fieldDefinition);
for (File f : toUpload) { for (File f : toUpload) {
if(!f.isDirectory()) if (!f.isDirectory()) {
builder.add(FileSets.asTemp(storage, new InputStreamDescriptor(new FileInputStream(f), f.getName()))); long fileSize = f.length();
TempFile file = FileSets.asTemp(storage,
new InputStreamDescriptor(new FileInputStream(f), f.getName()));
// Added by Francesco, see #28150
log.debug("PrepareRequest for tempfile name " + file.getFilename() + " size: " + file.getSize());
file.setSize(fileSize);
builder.add(file);
}
} }
return builder.getTheRequest(); return builder.getTheRequest();
} }

View File

@ -1,8 +1,6 @@
package org.gcube.application.geoportal.common; package org.gcube.application.geoportal.common;
import lombok.extern.slf4j.Slf4j; import static org.junit.Assert.assertTrue;
import org.gcube.application.geoportal.common.utils.Files;
import org.junit.Test;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
@ -11,7 +9,9 @@ import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import static org.junit.Assert.assertTrue; import org.gcube.application.geoportal.common.utils.Files;
import lombok.extern.slf4j.Slf4j;
@Slf4j @Slf4j
public class FilesTests { public class FilesTests {

View File

@ -1,5 +1,8 @@
package org.gcube.application.geoportal.common; package org.gcube.application.geoportal.common;
import java.util.EnumSet;
import java.util.Set;
import com.jayway.jsonpath.Configuration; import com.jayway.jsonpath.Configuration;
import com.jayway.jsonpath.Option; import com.jayway.jsonpath.Option;
import com.jayway.jsonpath.spi.json.JacksonJsonProvider; import com.jayway.jsonpath.spi.json.JacksonJsonProvider;
@ -7,9 +10,6 @@ import com.jayway.jsonpath.spi.json.JsonProvider;
import com.jayway.jsonpath.spi.mapper.JacksonMappingProvider; import com.jayway.jsonpath.spi.mapper.JacksonMappingProvider;
import com.jayway.jsonpath.spi.mapper.MappingProvider; import com.jayway.jsonpath.spi.mapper.MappingProvider;
import java.util.EnumSet;
import java.util.Set;
public class JacksonProvider implements JSONSerializationProvider { public class JacksonProvider implements JSONSerializationProvider {

View File

@ -1,16 +1,6 @@
package org.gcube.application.geoportal.common; package org.gcube.application.geoportal.common;
import lombok.extern.slf4j.Slf4j; import static org.junit.Assume.assumeTrue;
import org.gcube.application.geoportal.common.rest.InterfaceConstants;
import org.gcube.application.geoportal.common.utils.ContextUtils;
import org.gcube.application.geoportal.common.utils.StorageUtils;
import org.gcube.application.geoportal.common.utils.tests.GCubeTest;
import org.gcube.contentmanagement.blobstorage.service.IClient;
import org.gcube.contentmanager.storageclient.wrapper.AccessType;
import org.gcube.contentmanager.storageclient.wrapper.MemoryType;
import org.gcube.contentmanager.storageclient.wrapper.StorageClient;
import org.junit.Before;
import org.junit.Test;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
@ -22,7 +12,16 @@ import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicLong;
import static org.junit.Assume.assumeTrue; import org.gcube.application.geoportal.common.rest.InterfaceConstants;
import org.gcube.application.geoportal.common.utils.ContextUtils;
import org.gcube.application.geoportal.common.utils.StorageUtils;
import org.gcube.application.geoportal.common.utils.tests.GCubeTest;
import org.gcube.contentmanagement.blobstorage.service.IClient;
import org.gcube.contentmanager.storageclient.wrapper.AccessType;
import org.gcube.contentmanager.storageclient.wrapper.MemoryType;
import org.gcube.contentmanager.storageclient.wrapper.StorageClient;
import lombok.extern.slf4j.Slf4j;
@Slf4j @Slf4j
public class StorageUtilsTest { public class StorageUtilsTest {

View File

@ -1,10 +1,11 @@
package org.gcube.application.geoportal.common; package org.gcube.application.geoportal.common;
import lombok.extern.slf4j.Slf4j; import java.util.Properties;
import org.gcube.common.authorization.library.provider.SecurityTokenProvider; import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
import org.gcube.common.scope.api.ScopeProvider; import org.gcube.common.scope.api.ScopeProvider;
import java.util.Properties; import lombok.extern.slf4j.Slf4j;
@Slf4j @Slf4j
public class TokenSetter { public class TokenSetter {

View File

@ -1,13 +1,12 @@
package org.gcube.application.geoportal.common.legacy; package org.gcube.application.geoportal.common.legacy;
import static org.junit.Assert.assertEquals;
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.legacy.RelazioneScavo; import org.gcube.application.geoportal.common.model.legacy.RelazioneScavo;
import org.gcube.application.geoportal.common.model.legacy.report.ConstraintCheck; import org.gcube.application.geoportal.common.model.legacy.report.ConstraintCheck;
import org.gcube.application.geoportal.common.model.legacy.report.ValidationReport; import org.gcube.application.geoportal.common.model.legacy.report.ValidationReport;
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class DefaultsTests { public class DefaultsTests {

View File

@ -1,12 +1,8 @@
package org.gcube.application.geoportal.common.model; package org.gcube.application.geoportal.common.model;
import com.jayway.jsonpath.JsonPath; import static junit.framework.TestCase.assertEquals;
import org.gcube.application.geoportal.common.model.document.Project; import static junit.framework.TestCase.assertFalse;
import org.gcube.application.geoportal.common.model.document.filesets.RegisteredFileSet; import static junit.framework.TestCase.assertTrue;
import org.gcube.application.geoportal.common.model.document.lifecycle.TriggeredEvents;
import org.gcube.application.geoportal.common.model.useCaseDescriptor.HandlerDeclaration;
import org.gcube.application.geoportal.common.utils.Files;
import org.junit.Test;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
@ -15,7 +11,13 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import static junit.framework.TestCase.*; import org.gcube.application.geoportal.common.model.document.Project;
import org.gcube.application.geoportal.common.model.document.filesets.RegisteredFileSet;
import org.gcube.application.geoportal.common.model.document.lifecycle.TriggeredEvents;
import org.gcube.application.geoportal.common.model.useCaseDescriptor.HandlerDeclaration;
import org.gcube.application.geoportal.common.utils.Files;
import com.jayway.jsonpath.JsonPath;
public class JSONPathTests { public class JSONPathTests {

View File

@ -1,5 +1,9 @@
# Changelog for org.gcube.application.geoportal-service # Changelog for org.gcube.application.geoportal-service
## [v1.2.1-SNAPSHOT] - 2024-10-02
- Included the file size to reduce/optimize the time to upload files to the storage hub [#28150]
## [v1.2.0] - 2024-09-24 ## [v1.2.0] - 2024-09-24
- Integrated the EventManager of the cms-plugin-framework [#26321] - Integrated the EventManager of the cms-plugin-framework [#26321]

View File

@ -4,7 +4,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<groupId>org.gcube.application</groupId> <groupId>org.gcube.application</groupId>
<artifactId>geoportal-service</artifactId> <artifactId>geoportal-service</artifactId>
<version>1.2.0</version> <version>1.2.1-SNAPSHOT</version>
<name>Geoportal Service</name> <name>Geoportal Service</name>
<packaging>war</packaging> <packaging>war</packaging>

View File

@ -1562,10 +1562,10 @@ public class ProfiledMongoManager extends MongoManager implements MongoManagerI<
else else
fileUrl = storage.getURL(f.getId()); fileUrl = storage.getURL(f.getId());
log.info("Got URL {} from ID {}", fileUrl, f.getId()); log.info("Got URL {} from ID {}, filesize {}", fileUrl, f.getId(), f.getSize());
is = new URL(fileUrl).openStream(); is = new URL(fileUrl).openStream();
RegisteredFile registered = ws.registerFile(new WorkspaceManager.FileOptions(f.getFilename(), is, RegisteredFile registered = ws.registerFile(new WorkspaceManager.FileOptions(f.getFilename(), is,
"Imported via gcube CMS service ", sectionFolder)); "Imported via gcube CMS service ", sectionFolder, f.getSize()));
log.info("Registered " + registered); log.info("Registered " + registered);
registeredFiles.add(registered); registeredFiles.add(registered);
} catch (StorageHubException | IOException e) { } catch (StorageHubException | IOException e) {

View File

@ -1,7 +1,8 @@
# Changelog for org.gcube.application.cms.notifications-plugins # Changelog for org.gcube.application.cms.notifications-plugins
## [v1.0.5] - 2024-07-03 ## [v1.0.5-SNAPSHOT] - 2024-07-03
- Implemented the notification-plugin [#26453] - Implemented the notification-plugin [#26453]
- Updated lower range of social-service-client to `2.1.0-SNAPSHOT`
## [v1.0.4] - 2023-09-06 ## [v1.0.4] - 2023-09-06
- Using parent version range [#25572] - Using parent version range [#25572]

View File

@ -5,7 +5,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>notifications-plugins</artifactId> <artifactId>notifications-plugins</artifactId>
<version>1.0.5</version> <version>1.0.5-SNAPSHOT</version>
<name>gCube CMS - Notifications Plugins</name> <name>gCube CMS - Notifications Plugins</name>
<parent> <parent>
@ -58,7 +58,7 @@
<dependency> <dependency>
<groupId>org.gcube.social-networking</groupId> <groupId>org.gcube.social-networking</groupId>
<artifactId>social-service-client</artifactId> <artifactId>social-service-client</artifactId>
<version>[2.0.0-SNAPSHOT, 3.0.0-SNAPSHOT)</version> <version>[2.1.0-SNAPSHOT, 3.0.0-SNAPSHOT)</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.gcube.portlets.user</groupId> <groupId>org.gcube.portlets.user</groupId>

12
pom.xml
View File

@ -10,7 +10,7 @@
<groupId>org.gcube.application.cms</groupId> <groupId>org.gcube.application.cms</groupId>
<artifactId>gcube-cms-suite</artifactId> <artifactId>gcube-cms-suite</artifactId>
<packaging>pom</packaging> <packaging>pom</packaging>
<version>1.0.6</version> <version>1.0.6-SNAPSHOT</version>
<name>Gcube CMS Suite</name> <name>Gcube CMS Suite</name>
<description>gCube CMS Suite is a set of components designed to manage complex space-temporal Documents defined by metadata Profiles.</description> <description>gCube CMS Suite is a set of components designed to manage complex space-temporal Documents defined by metadata Profiles.</description>
@ -22,10 +22,10 @@
<distroDirectory>distro</distroDirectory> <distroDirectory>distro</distroDirectory>
<gitBaseUrl>https://code-repo.d4science.org/gCubeSystem</gitBaseUrl> <gitBaseUrl>https://code-repo.d4science.org/gCubeSystem</gitBaseUrl>
<!-- default is prod --> <!-- default properties -->
<gcube-smartgears-bom-version>2.5.1</gcube-smartgears-bom-version> <gcube-smartgears-bom-version>2.5.1-SNAPSHOT</gcube-smartgears-bom-version>
<storagehub-version-range>[2.0.0-SNAPSHOT,3.0.0-SNAPSHOT)</storagehub-version-range> <storagehub-version-range>[2.0.0-SNAPSHOT,3.0.0-SNAPSHOT)</storagehub-version-range>
<plugin-framework-version>1.0.5-SNAPSHOT</plugin-framework-version> <plugin-framework-version>1.0.6-SNAPSHOT</plugin-framework-version>
<authorization-utils-range>[2.0.0, 3.0.0-SNAPSHOT)</authorization-utils-range> <authorization-utils-range>[2.0.0, 3.0.0-SNAPSHOT)</authorization-utils-range>
<cms-suite-version>1.0.6-SNAPSHOT</cms-suite-version> <cms-suite-version>1.0.6-SNAPSHOT</cms-suite-version>
</properties> </properties>
@ -41,7 +41,7 @@
</activation> </activation>
<properties> <properties>
<gcube-smartgears-bom-version>2.5.1</gcube-smartgears-bom-version> <gcube-smartgears-bom-version>2.5.1</gcube-smartgears-bom-version>
<plugin-framework-version>1.0.5</plugin-framework-version> <plugin-framework-version>1.0.6</plugin-framework-version>
<authorization-utils-range>[2.0.0, 3.0.0-SNAPSHOT)</authorization-utils-range> <authorization-utils-range>[2.0.0, 3.0.0-SNAPSHOT)</authorization-utils-range>
</properties> </properties>
</profile> </profile>
@ -55,7 +55,7 @@
</activation> </activation>
<properties> <properties>
<gcube-smartgears-bom-version>2.5.1-SNAPSHOT</gcube-smartgears-bom-version> <gcube-smartgears-bom-version>2.5.1-SNAPSHOT</gcube-smartgears-bom-version>
<plugin-framework-version>1.0.5-SNAPSHOT</plugin-framework-version> <plugin-framework-version>1.0.6-SNAPSHOT</plugin-framework-version>
<authorization-utils-range>[2.0.0, 3.0.0-SNAPSHOT)</authorization-utils-range> <authorization-utils-range>[2.0.0, 3.0.0-SNAPSHOT)</authorization-utils-range>
</properties> </properties>
</profile> </profile>

View File

@ -1,5 +1,9 @@
# Changelog for org.gcube.application.cms.sdi-plugins # Changelog for org.gcube.application.cms.sdi-plugins
## [v1.1.4-SNAPSHOT]
- Improved logs
- Added fallback on /geoserver/rest path [#28150#note-8]
## [v1.1.3] ## [v1.1.3]
- Added apply regex business logic [#26322] - Added apply regex business logic [#26322]
- Added reconnection attempts to DB on DB connection failure [#26322] - Added reconnection attempts to DB on DB connection failure [#26322]

View File

@ -5,7 +5,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sdi-plugins</artifactId> <artifactId>sdi-plugins</artifactId>
<version>1.1.3</version> <version>1.1.4-SNAPSHOT</version>
<name>gCube CMS - SDI Plugins</name> <name>gCube CMS - SDI Plugins</name>
<parent> <parent>

View File

@ -1,6 +1,5 @@
package org.gcube.application.cms.sdi.engine; package org.gcube.application.cms.sdi.engine;
import java.io.File; import java.io.File;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.net.URL; import java.net.URL;
@ -13,6 +12,7 @@ import org.gcube.data.transfer.library.DataTransferClient;
import org.gcube.spatial.data.gis.GISInterface; import org.gcube.spatial.data.gis.GISInterface;
import org.gcube.spatial.data.gis.is.AbstractGeoServerDescriptor; import org.gcube.spatial.data.gis.is.AbstractGeoServerDescriptor;
import it.geosolutions.geoserver.rest.HTTPUtils;
import it.geosolutions.geoserver.rest.encoder.datastore.GSPostGISDatastoreEncoder; import it.geosolutions.geoserver.rest.encoder.datastore.GSPostGISDatastoreEncoder;
import lombok.Getter; import lombok.Getter;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
@ -20,13 +20,10 @@ import lombok.extern.slf4j.Slf4j;
@Slf4j @Slf4j
public class SDIManager { public class SDIManager {
public static final Pattern HOSTNAME_PATTERN = Pattern.compile("(?<=\\:\\/\\/)[^\\:]*"); public static final Pattern HOSTNAME_PATTERN = Pattern.compile("(?<=\\:\\/\\/)[^\\:]*");
public static final Pattern PORT_PATTERN = Pattern.compile("(?<=\\:)[\\d]+"); public static final Pattern PORT_PATTERN = Pattern.compile("(?<=\\:)[\\d]+");
public static final Pattern DB_NAME_PATTERN = Pattern.compile("(?<=\\/)[^\\/]*(?=$)"); public static final Pattern DB_NAME_PATTERN = Pattern.compile("(?<=\\/)[^\\/]*(?=$)");
private final GISInterface gis; private final GISInterface gis;
@Getter @Getter
private final DataTransferClient dtGeoServer; private final DataTransferClient dtGeoServer;
@ -35,6 +32,7 @@ public class SDIManager {
@Getter @Getter
private final AbstractGeoServerDescriptor currentGeoserver; private final AbstractGeoServerDescriptor currentGeoserver;
private final String FALLBACK_GS_REST_INTERFACE = "/rest";
public SDIManager() throws SDIInteractionException { public SDIManager() throws SDIInteractionException {
try { try {
@ -48,31 +46,38 @@ public class SDIManager {
geoserverHostName = new URL(currentGeoserver.getUrl()).getHost(); geoserverHostName = new URL(currentGeoserver.getUrl()).getHost();
log.debug("Contacting Data Transfer from geoserver {} ", geoserverHostName); log.debug("Contacting Data Transfer from geoserver {} ", geoserverHostName);
dtGeoServer=DataTransferClient.getInstanceByEndpoint("https://"+geoserverHostName); String gsEP = "https://" + geoserverHostName;
if(!currentGeoserver.getReader().existGeoserver()) dtGeoServer = DataTransferClient.getInstanceByEndpoint(gsEP);
throw new Exception("Geoserver not reachable"); if (!currentGeoserver.getReader().existGeoserver()) {
// not a good but necessary solution here, see #28150#note-8
String fallbackGSRestURL = currentGeoserver.getUrl() + FALLBACK_GS_REST_INTERFACE;
log.warn("Geoserver rest interface not reachable at /rest/. Going to check "
+ fallbackGSRestURL);
if (!HTTPUtils.httpPing(fallbackGSRestURL, currentGeoserver.getUser(),
currentGeoserver.getPassword())) {
throw new Exception("Geoserver rest interface not reachable at " + fallbackGSRestURL);
}
}
} catch (Exception e) { } catch (Exception e) {
log.error("SDIManager init failed: ", e);
throw new SDIInteractionException("Unable to initialize SDI Manager", e); throw new SDIInteractionException("Unable to initialize SDI Manager", e);
} }
} }
public String createWorkspace(String toCreate) throws SDIInteractionException { public String createWorkspace(String toCreate) throws SDIInteractionException {
try { try {
if (!currentGeoserver.getReader().getWorkspaceNames().contains(toCreate)) { if (!currentGeoserver.getReader().getWorkspaceNames().contains(toCreate)) {
log.debug("Creating workspace : " + toCreate); log.debug("Creating workspace : " + toCreate);
if (!currentGeoserver.getPublisher().createWorkspace(toCreate)) if (!currentGeoserver.getPublisher().createWorkspace(toCreate))
throw new SDIInteractionException("Unable to create workspace " + toCreate); throw new SDIInteractionException("Unable to create workspace " + toCreate);
}else log.debug("Workspace "+toCreate+" exists."); } else
log.debug("Workspace " + toCreate + " exists.");
return toCreate; return toCreate;
} catch (IllegalArgumentException | MalformedURLException e) { } catch (IllegalArgumentException | MalformedURLException e) {
throw new SDIInteractionException("Unable to create workspace " + toCreate, e); throw new SDIInteractionException("Unable to create workspace " + toCreate, e);
} }
} }
// protected static final String getToUseBaseLayerName(RegisteredFileSet fileset){ // protected static final String getToUseBaseLayerName(RegisteredFileSet fileset){
// // ******** IDENTIFY LAYER NAME correct layer name // // ******** IDENTIFY LAYER NAME correct layer name
// // Must be unique under same WS // // Must be unique under same WS
@ -109,19 +114,21 @@ public class SDIManager {
} }
} }
protected String createStoreFromPostgisDB(String workspace, String storeName, DatabaseConnection connection)
protected String createStoreFromPostgisDB(String workspace, String storeName, DatabaseConnection connection) throws SDIInteractionException{ throws SDIInteractionException {
String connectionUrl = connection.getUrl(); String connectionUrl = connection.getUrl();
Matcher hostname = HOSTNAME_PATTERN.matcher(connectionUrl); Matcher hostname = HOSTNAME_PATTERN.matcher(connectionUrl);
if (!hostname.find()) throw new SDIInteractionException("Unable to get Hostname from "+connection); if (!hostname.find())
throw new SDIInteractionException("Unable to get Hostname from " + connection);
Matcher port = PORT_PATTERN.matcher(connectionUrl); Matcher port = PORT_PATTERN.matcher(connectionUrl);
if (!port.find()) throw new SDIInteractionException("Unable to get PORT from "+connection); if (!port.find())
throw new SDIInteractionException("Unable to get PORT from " + connection);
Matcher db = DB_NAME_PATTERN.matcher(connectionUrl); Matcher db = DB_NAME_PATTERN.matcher(connectionUrl);
if (!db.find()) throw new SDIInteractionException("Unable to get DB from "+connection); if (!db.find())
throw new SDIInteractionException("Unable to get DB from " + connection);
GSPostGISDatastoreEncoder encoder = new GSPostGISDatastoreEncoder(storeName); GSPostGISDatastoreEncoder encoder = new GSPostGISDatastoreEncoder(storeName);
encoder.setHost(hostname.group()); encoder.setHost(hostname.group());
@ -145,7 +152,8 @@ public class SDIManager {
log.debug("Registering style " + name); log.debug("Registering style " + name);
if (!currentGeoserver.getPublisher().publishStyle(sldFile, name)) if (!currentGeoserver.getPublisher().publishStyle(sldFile, name))
throw new SDIInteractionException("Unable to register style " + name); throw new SDIInteractionException("Unable to register style " + name);
}else log.debug("Style "+name+" already existing"); } else
log.debug("Style " + name + " already existing");
return name; return name;
} catch (IllegalArgumentException | MalformedURLException e) { } catch (IllegalArgumentException | MalformedURLException e) {
throw new SDIInteractionException("Unable to create style " + name, e); throw new SDIInteractionException("Unable to create style " + name, e);