Skip to content

Commit

Permalink
8287097: (fs) Files::copy requires an undocumented permission when co…
Browse files Browse the repository at this point in the history
…pying from the default file system to a non-default file system

Reviewed-by: chegar, alanb
  • Loading branch information
Brian Burkhalter committed Jun 2, 2022
1 parent 49e24f0 commit 13596cd
Show file tree
Hide file tree
Showing 3 changed files with 82 additions and 8 deletions.
28 changes: 20 additions & 8 deletions src/java.base/share/classes/java/nio/file/CopyMoveHelper.java
Expand Up @@ -110,13 +110,21 @@ static void copyToForeignTarget(Path source, Path target,
Files.getFileAttributeView(source, PosixFileAttributeView.class);

// attributes of source file
BasicFileAttributes sourceAttrs = sourcePosixView != null ?
Files.readAttributes(source,
PosixFileAttributes.class,
linkOptions) :
Files.readAttributes(source,
BasicFileAttributes.class,
linkOptions);
BasicFileAttributes sourceAttrs = null;
if (sourcePosixView != null) {
try {
sourceAttrs = Files.readAttributes(source,
PosixFileAttributes.class,
linkOptions);
} catch (SecurityException ignored) {
// okay to continue if RuntimePermission("accessUserInformation") not granted
}
}
if (sourceAttrs == null)
sourceAttrs = Files.readAttributes(source,
BasicFileAttributes.class,
linkOptions);
assert sourceAttrs != null;

if (sourceAttrs.isSymbolicLink())
throw new IOException("Copying of symbolic links not supported");
Expand Down Expand Up @@ -157,7 +165,11 @@ static void copyToForeignTarget(Path source, Path target,

if (sourceAttrs instanceof PosixFileAttributes sourcePosixAttrs &&
targetView instanceof PosixFileAttributeView targetPosixView) {
targetPosixView.setPermissions(sourcePosixAttrs.permissions());
try {
targetPosixView.setPermissions(sourcePosixAttrs.permissions());
} catch (SecurityException ignored) {
// okay to continue if RuntimePermission("accessUserInformation") not granted
}
}
} catch (Throwable x) {
// rollback
Expand Down
58 changes: 58 additions & 0 deletions test/jdk/java/nio/file/Files/CopyToNonDefaultFS.java
@@ -0,0 +1,58 @@
/*
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/

/**
* @test
* @bug 8245194
* @run main/othervm/java.security.policy=copy.policy CopyToNonDefaultFS
* @summary Test for exception copying from default to non-default file system
*/

import java.io.*;
import java.nio.ByteBuffer;
import java.nio.channels.*;
import java.nio.file.*;
import java.util.*;

import static java.nio.file.StandardOpenOption.*;

public class CopyToNonDefaultFS {
public static void main(String... args) throws IOException {
Path source = Files.createTempFile(Path.of("."), "tmp", ".dat");
try (FileChannel fc = FileChannel.open(source, CREATE, WRITE)) {
fc.position(8191);
fc.write(ByteBuffer.wrap(new byte[] {27}));
}

Path zip = Path.of("out.zip");
zip.toFile().deleteOnExit();
Map<String,String> env =
Map.of("create", String.valueOf(Files.notExists(zip)));

ClassLoader cl = CopyToNonDefaultFS.class.getClassLoader();
try (FileSystem fileSystem = FileSystems.newFileSystem(zip, env, cl)) {
Path p = fileSystem.getPath(source.getFileName().toString());
Files.copy(source, p);
}
}
}
4 changes: 4 additions & 0 deletions test/jdk/java/nio/file/Files/copy.policy
@@ -0,0 +1,4 @@
grant {
permission java.io.FilePermission "<<ALL FILES>>", "read,write";
permission java.io.FilePermission "out.zip", "delete";
};

0 comments on commit 13596cd

Please sign in to comment.