From ef78f5af7c5cb60b5fc99998e251df840d82f7fc Mon Sep 17 00:00:00 2001 From: Ainur Date: Wed, 4 Dec 2024 16:35:30 +0100 Subject: [PATCH] CB-6011 fix read from s3 --- .../io/cloudbeaver/service/fs/impl/WebServiceFS.java | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/server/bundles/io.cloudbeaver.service.fs/src/io/cloudbeaver/service/fs/impl/WebServiceFS.java b/server/bundles/io.cloudbeaver.service.fs/src/io/cloudbeaver/service/fs/impl/WebServiceFS.java index 187184c780..d7e2959e5d 100644 --- a/server/bundles/io.cloudbeaver.service.fs/src/io/cloudbeaver/service/fs/impl/WebServiceFS.java +++ b/server/bundles/io.cloudbeaver.service.fs/src/io/cloudbeaver/service/fs/impl/WebServiceFS.java @@ -30,8 +30,10 @@ import org.jkiss.dbeaver.model.navigator.fs.DBNFileSystems; import org.jkiss.dbeaver.model.navigator.fs.DBNPathBase; import org.jkiss.dbeaver.registry.fs.FileSystemProviderRegistry; +import org.jkiss.utils.IOUtils; -import java.nio.charset.StandardCharsets; +import java.io.InputStreamReader; +import java.io.Reader; import java.nio.file.Files; import java.nio.file.Path; import java.text.MessageFormat; @@ -128,8 +130,10 @@ public String readFileContent(@NotNull WebSession webSession, @NotNull String no throws DBWebException { try { Path filePath = FSUtils.getPathFromNode(webSession, nodePath); - var data = Files.readAllBytes(filePath); - return new String(data, StandardCharsets.UTF_8); + // Files.readAllBytes doesn't work for s3 if user doesn't have PutObject permission (need for S3SeekableByteChannel#seek) + try (Reader reader = new InputStreamReader(Files.newInputStream(filePath))) { + return IOUtils.readToString(reader); + } } catch (Exception e) { throw new DBWebException("Failed to read file content: " + e.getMessage(), e); }