Skip to content

Commit

Permalink
Fix path traversal vulnerability in LocalFileLogServer
Browse files Browse the repository at this point in the history
  • Loading branch information
kaorimatz authored and aamine committed Feb 13, 2024
1 parent 328b4c6 commit 13ebfa1
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 2 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package io.digdag.core.log;

import java.nio.file.NoSuchFileException;
import java.util.concurrent.locks.ReentrantReadWriteLock;
import java.io.InputStream;
import java.io.OutputStream;
Expand Down Expand Up @@ -122,11 +123,15 @@ protected void listFiles(String dateDir, String attemptDir, boolean enableDirect
protected byte[] getFile(String dateDir, String attemptDir, String fileName)
throws StorageFileNotFoundException
{
Path path = getPrefixDir(dateDir, attemptDir).resolve(fileName);
Path prefixDir = getPrefixDir(dateDir, attemptDir);
Path path = prefixDir.resolve(fileName).normalize();
if (!path.startsWith(prefixDir)) {
throw new IllegalArgumentException("Invalid file name: " + fileName);
}
try (InputStream in = Files.newInputStream(path)) {
return ByteStreams.toByteArray(in);
}
catch (FileNotFoundException ex) {
catch (FileNotFoundException | NoSuchFileException ex) {
throw new StorageFileNotFoundException(ex);
}
catch (IOException ex) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import io.digdag.core.agent.AgentId;
import io.digdag.core.config.PropertyUtils;
import io.digdag.spi.LogFilePrefix;
import io.digdag.spi.StorageFileNotFoundException;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
Expand All @@ -23,6 +24,7 @@
import java.util.Properties;

import static java.nio.charset.StandardCharsets.UTF_8;
import static org.junit.Assert.assertThrows;

import io.digdag.core.log.LocalFileLogServerFactory.LocalFileLogServer.LocalFileDirectTaskLogger;

Expand Down Expand Up @@ -142,4 +144,30 @@ private String repeatedString(String v, int num)
}
return b.toString();
}

@Test
public void testGetFile() throws StorageFileNotFoundException
{
setUpTaskLogger(Optional.absent());
String fileName = localServer.putFile(prefix, "+task", Instant.now(), "agent", "foo".getBytes(UTF_8));
byte[] data = localServer.getFile(prefix, fileName);
assertThat(new String(data, UTF_8), is("foo"));
}

@Test
public void testGetFileNotFound()
{
setUpTaskLogger(Optional.absent());
assertThrows(StorageFileNotFoundException.class, () -> localServer.getFile(prefix, "foo"));
}

@Test
public void testGetFileInvalidFileName()
{
setUpTaskLogger(Optional.absent());
assertThrows(IllegalArgumentException.class, () -> localServer.getFile(prefix, ".."));
assertThrows(IllegalArgumentException.class, () -> localServer.getFile(prefix, "../foo"));
assertThrows(IllegalArgumentException.class, () -> localServer.getFile(prefix, "/foo"));
assertThrows(IllegalArgumentException.class, () -> localServer.getFile(prefix, "foo/../../bar"));
}
}
6 changes: 6 additions & 0 deletions digdag-tests/src/test/java/acceptance/LogIT.java
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,15 @@
import utils.CommandStatus;
import utils.TemporaryDigdagServer;

import javax.ws.rs.BadRequestException;
import javax.ws.rs.NotFoundException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.regex.Pattern;

import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.is;
import static org.junit.Assert.assertThrows;
import static org.junit.Assert.assertTrue;
import static utils.TestUtils.*;

Expand Down Expand Up @@ -91,5 +94,8 @@ public void verifyLogWithAttemptIdAndSessionId()

final String regex = "\\[\\d+:\\w+:\\d+:\\d+]";
assertTrue(Pattern.compile(regex, Pattern.DOTALL).matcher(logs).find());

assertThrows(NotFoundException.class, () -> client.getLogFile(attemptId, "foo"));
assertThrows(BadRequestException.class, () -> client.getLogFile(attemptId, "/foo"));
}
}

0 comments on commit 13ebfa1

Please sign in to comment.