HDFS-8142. DistributedFileSystem encryption zone commands should resolve relative paths. Contributed by Rakesh R.
(cherry picked from commit 2e8ea780a4
)
This commit is contained in:
parent
6fed2c2a79
commit
9123f26c73
|
@ -184,6 +184,9 @@ Release 2.8.0 - UNRELEASED
|
||||||
HDFS-8055. NullPointerException when topology script is missing.
|
HDFS-8055. NullPointerException when topology script is missing.
|
||||||
(Anu Engineer via cnauroth)
|
(Anu Engineer via cnauroth)
|
||||||
|
|
||||||
|
HDFS-8142. DistributedFileSystem encryption zone commands should resolve
|
||||||
|
relative paths. (Rakesh R via wang)
|
||||||
|
|
||||||
Release 2.7.1 - UNRELEASED
|
Release 2.7.1 - UNRELEASED
|
||||||
|
|
||||||
INCOMPATIBLE CHANGES
|
INCOMPATIBLE CHANGES
|
||||||
|
|
|
@ -2082,16 +2082,59 @@ public class DistributedFileSystem extends FileSystem {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* HDFS only */
|
/* HDFS only */
|
||||||
public void createEncryptionZone(Path path, String keyName)
|
public void createEncryptionZone(final Path path, final String keyName)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
dfs.createEncryptionZone(getPathName(path), keyName);
|
Path absF = fixRelativePart(path);
|
||||||
|
new FileSystemLinkResolver<Void>() {
|
||||||
|
@Override
|
||||||
|
public Void doCall(final Path p) throws IOException,
|
||||||
|
UnresolvedLinkException {
|
||||||
|
dfs.createEncryptionZone(getPathName(p), keyName);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Void next(final FileSystem fs, final Path p) throws IOException {
|
||||||
|
if (fs instanceof DistributedFileSystem) {
|
||||||
|
DistributedFileSystem myDfs = (DistributedFileSystem) fs;
|
||||||
|
myDfs.createEncryptionZone(p, keyName);
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException(
|
||||||
|
"Cannot call createEncryptionZone"
|
||||||
|
+ " on a symlink to a non-DistributedFileSystem: " + path
|
||||||
|
+ " -> " + p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.resolve(this, absF);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* HDFS only */
|
/* HDFS only */
|
||||||
public EncryptionZone getEZForPath(Path path)
|
public EncryptionZone getEZForPath(final Path path)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
Preconditions.checkNotNull(path);
|
Preconditions.checkNotNull(path);
|
||||||
return dfs.getEZForPath(getPathName(path));
|
Path absF = fixRelativePart(path);
|
||||||
|
return new FileSystemLinkResolver<EncryptionZone>() {
|
||||||
|
@Override
|
||||||
|
public EncryptionZone doCall(final Path p) throws IOException,
|
||||||
|
UnresolvedLinkException {
|
||||||
|
return dfs.getEZForPath(getPathName(p));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EncryptionZone next(final FileSystem fs, final Path p)
|
||||||
|
throws IOException {
|
||||||
|
if (fs instanceof DistributedFileSystem) {
|
||||||
|
DistributedFileSystem myDfs = (DistributedFileSystem) fs;
|
||||||
|
return myDfs.getEZForPath(p);
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException(
|
||||||
|
"Cannot call getEZForPath"
|
||||||
|
+ " on a symlink to a non-DistributedFileSystem: " + path
|
||||||
|
+ " -> " + p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.resolve(this, absF);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* HDFS only */
|
/* HDFS only */
|
||||||
|
|
|
@ -1310,4 +1310,22 @@ public class TestEncryptionZones {
|
||||||
true, fs.getFileStatus(zoneFile).isEncrypted());
|
true, fs.getFileStatus(zoneFile).isEncrypted());
|
||||||
DFSTestUtil.verifyFilesNotEqual(fs, zoneFile, rawFile, len);
|
DFSTestUtil.verifyFilesNotEqual(fs, zoneFile, rawFile, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 60000)
|
||||||
|
public void testEncryptionZonesOnRelativePath() throws Exception {
|
||||||
|
final int len = 8196;
|
||||||
|
final Path baseDir = new Path("/somewhere/base");
|
||||||
|
final Path zoneDir = new Path("zone");
|
||||||
|
final Path zoneFile = new Path("file");
|
||||||
|
fs.setWorkingDirectory(baseDir);
|
||||||
|
fs.mkdirs(zoneDir);
|
||||||
|
dfsAdmin.createEncryptionZone(zoneDir, TEST_KEY);
|
||||||
|
DFSTestUtil.createFile(fs, zoneFile, len, (short) 1, 0xFEED);
|
||||||
|
|
||||||
|
assertNumZones(1);
|
||||||
|
assertZonePresent(TEST_KEY, "/somewhere/base/zone");
|
||||||
|
|
||||||
|
assertEquals("Got unexpected ez path", "/somewhere/base/zone", dfsAdmin
|
||||||
|
.getEncryptionZoneForPath(zoneDir).getPath().toString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue