support for upload of file starting with dot

modified the path serach according to the new storageHub client
This commit is contained in:
lucio 2020-03-05 15:02:46 +01:00
parent 11f98812bc
commit bfd4b3596e
4 changed files with 17 additions and 27 deletions

View File

@ -80,7 +80,6 @@
<dependency> <dependency>
<groupId>ch.qos.logback</groupId> <groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId> <artifactId>logback-classic</artifactId>
<version>1.0.13</version>
</dependency> </dependency>
</dependencies> </dependencies>
@ -111,7 +110,6 @@
</plugin> </plugin>
<plugin> <plugin>
<artifactId>maven-compiler-plugin</artifactId> <artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration> <configuration>
<target>1.8</target> <target>1.8</target>
<source>1.8</source> <source>1.8</source>

View File

@ -1,5 +1,6 @@
package org.gcube.data.access.storagehub.fs; package org.gcube.data.access.storagehub.fs;
import java.awt.Container;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.util.List; import java.util.List;
@ -54,23 +55,21 @@ public class PathUtils {
} else logger.trace("path "+path+" not in cache"); } else logger.trace("path "+path+" not in cache");
synchronized (this) { synchronized (this) {
ItemContainer<? extends Item> retrievedItem = getPathRecursive(path, rootDirectory); ItemContainer<? extends Item> retrievedItem = getByPath(path, rootDirectory);
if (retrievedItem!=null)cache.put(path, (ItemContainer<Item>) retrievedItem); if (retrievedItem!=null) {
cache.put(path, (ItemContainer<Item>) retrievedItem);
logger.trace("retrieved container is of type {}",retrievedItem.getType());
}
return retrievedItem; return retrievedItem;
} }
} }
public ItemContainer<? extends Item> getPathRecursive(String path, FolderContainer parentContainer) { public ItemContainer<? extends Item> getByPath(String path, FolderContainer parentContainer) {
try { try {
while (path.startsWith("/")) { if (path.startsWith("/")) {
path = path.substring(1); path = path.substring(1);
} }
if (!path.contains("/")) {
logger.trace("seaching path "+path+" in "+parentContainer.get().getTitle());
List<ItemContainer<? extends Item>> items = parentContainer.findByName(path).withContent().getContainers();
logger.trace("found? "+(items.size()>0));
return items.size()>0? items.get(0): null;
}
if (path.startsWith(StorageHubFS.VREFOLDERS_NAME)) { if (path.startsWith(StorageHubFS.VREFOLDERS_NAME)) {
List<ItemContainer<? extends Item>> vreFolders = client.getVREFolders().getContainers(); List<ItemContainer<? extends Item>> vreFolders = client.getVREFolders().getContainers();
String vreName = path.split("/")[1]; String vreName = path.split("/")[1];
@ -79,21 +78,13 @@ public class PathUtils {
if (veFolder.getDisplayName().equals(vreName)) { if (veFolder.getDisplayName().equals(vreName)) {
String nextPath = path.replace(StorageHubFS.VREFOLDERS_NAME+"/"+veFolder.getDisplayName(), ""); String nextPath = path.replace(StorageHubFS.VREFOLDERS_NAME+"/"+veFolder.getDisplayName(), "");
if(nextPath.isEmpty()) return vreContainer; if(nextPath.isEmpty()) return vreContainer;
else return getPathRecursive(nextPath, (FolderContainer)vreContainer); else return ((FolderContainer)vreContainer).openByRelativePath(nextPath).resolve();
}
} }
} }
} else return parentContainer.openByRelativePath(path).resolve();
String nextName = path.substring(0, path.indexOf("/"));
String rest = path.substring(path.indexOf("/"));
for (ItemContainer<? extends Item> container : parentContainer.findByName(nextName).withContent().getContainers()) {
if (container instanceof FolderContainer) {
logger.trace("seaching path "+rest+" in "+container.get().getTitle());
return getPathRecursive(rest, (FolderContainer)container);
}
}
}catch(Exception e) { }catch(Exception e) {
logger.error("error in gpath recursive",e); logger.error("error in gpath recursive",e);
} }

View File

@ -160,6 +160,7 @@ public class StorageHubFS extends FuseStubFS {
@Override @Override
public synchronized int getattr(String path, FileStat stat) { public synchronized int getattr(String path, FileStat stat) {
ScopeProvider.instance.set(scope); ScopeProvider.instance.set(scope);
SecurityTokenProvider.instance.set(token); SecurityTokenProvider.instance.set(token);
@ -167,10 +168,10 @@ public class StorageHubFS extends FuseStubFS {
if (Objects.equals(path, "/") || path.contains("Trash") || path.equals("/"+VREFOLDERS_NAME)) { if (Objects.equals(path, "/") || path.contains("Trash") || path.equals("/"+VREFOLDERS_NAME)) {
stat.st_mode.set(FileStat.S_IFDIR | 0755); stat.st_mode.set(FileStat.S_IFDIR | 0755);
stat.st_nlink.set(2); stat.st_nlink.set(2);
} else if(pathUtils.getLastComponent(path).startsWith(".")) { }/* else if(pathUtils.getLastComponent(path).startsWith(".")) {
logger.trace("start with /."); logger.trace("start with /.");
return super.getattr(path, stat); return super.getattr(path, stat);
} else if (tempFiles.containsKey(path)){ } */else if (tempFiles.containsKey(path)){
return tempFiles.get(path).getAttr(stat); return tempFiles.get(path).getAttr(stat);
}else { }else {
logger.trace("trying items"); logger.trace("trying items");

View File

@ -11,7 +11,7 @@ public class FuseTest {
@Test @Test
public void mount() { public void mount() {
StorageHubFS memfs = new StorageHubFS("7c26a682-f47b-4e6e-90e0-6d101a4314cd-980114272","/pred4s/preprod/preVRE"); StorageHubFS memfs = new StorageHubFS("b7c80297-e4ed-42ab-ab42-fdc0b8b0eabf-98187548","/gcube");
try { try {
String path; String path;
switch (Platform.getNativePlatform().getOS()) { switch (Platform.getNativePlatform().getOS()) {
@ -19,7 +19,7 @@ public class FuseTest {
path = "J:\\"; path = "J:\\";
break; break;
default: default:
path = "/home/lucio/javaMount/mnt"; path = "/home/lucio/java/mnt";
} }
memfs.mount(Paths.get(path), true, true); memfs.mount(Paths.get(path), true, true);
} finally { } finally {