HDFS-11880. Ozone: KSM: Remove protobuf formats from KSM wrappers. Contributed by Nandakumar Vadivelu.
This commit is contained in:
parent
18706f433f
commit
da8bc385a7
|
@ -18,14 +18,15 @@
|
||||||
package org.apache.hadoop.ksm.helpers;
|
package org.apache.hadoop.ksm.helpers;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import org.apache.hadoop.hdfs.protocol.proto
|
import org.apache.hadoop.fs.StorageType;
|
||||||
.HdfsProtos.StorageTypeProto;
|
import org.apache.hadoop.hdfs.protocolPB.PBHelperClient;
|
||||||
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocol.proto
|
||||||
.KeySpaceManagerProtocolProtos.BucketArgs;
|
.KeySpaceManagerProtocolProtos.BucketArgs;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocolPB.KSMPBHelper;
|
||||||
.KeySpaceManagerProtocolProtos.OzoneAclInfo;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A class that encapsulates Bucket Arguments.
|
* A class that encapsulates Bucket Arguments.
|
||||||
|
@ -42,11 +43,11 @@ public final class KsmBucketArgs {
|
||||||
/**
|
/**
|
||||||
* ACL's that are to be added for the bucket.
|
* ACL's that are to be added for the bucket.
|
||||||
*/
|
*/
|
||||||
private List<OzoneAclInfo> addAcls;
|
private List<OzoneAcl> addAcls;
|
||||||
/**
|
/**
|
||||||
* ACL's that are to be removed from the bucket.
|
* ACL's that are to be removed from the bucket.
|
||||||
*/
|
*/
|
||||||
private List<OzoneAclInfo> removeAcls;
|
private List<OzoneAcl> removeAcls;
|
||||||
/**
|
/**
|
||||||
* Bucket Version flag.
|
* Bucket Version flag.
|
||||||
*/
|
*/
|
||||||
|
@ -55,7 +56,7 @@ public final class KsmBucketArgs {
|
||||||
* Type of storage to be used for this bucket.
|
* Type of storage to be used for this bucket.
|
||||||
* [RAM_DISK, SSD, DISK, ARCHIVE]
|
* [RAM_DISK, SSD, DISK, ARCHIVE]
|
||||||
*/
|
*/
|
||||||
private StorageTypeProto storageType;
|
private StorageType storageType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Private constructor, constructed via builder.
|
* Private constructor, constructed via builder.
|
||||||
|
@ -67,8 +68,8 @@ public final class KsmBucketArgs {
|
||||||
* @param storageType - Storage type to be used.
|
* @param storageType - Storage type to be used.
|
||||||
*/
|
*/
|
||||||
private KsmBucketArgs(String volumeName, String bucketName,
|
private KsmBucketArgs(String volumeName, String bucketName,
|
||||||
List<OzoneAclInfo> addAcls, List<OzoneAclInfo> removeAcls,
|
List<OzoneAcl> addAcls, List<OzoneAcl> removeAcls,
|
||||||
Boolean isVersionEnabled, StorageTypeProto storageType) {
|
Boolean isVersionEnabled, StorageType storageType) {
|
||||||
this.volumeName = volumeName;
|
this.volumeName = volumeName;
|
||||||
this.bucketName = bucketName;
|
this.bucketName = bucketName;
|
||||||
this.addAcls = addAcls;
|
this.addAcls = addAcls;
|
||||||
|
@ -97,7 +98,7 @@ public final class KsmBucketArgs {
|
||||||
* Returns the ACL's that are to be added.
|
* Returns the ACL's that are to be added.
|
||||||
* @return List<OzoneAclInfo>
|
* @return List<OzoneAclInfo>
|
||||||
*/
|
*/
|
||||||
public List<OzoneAclInfo> getAddAcls() {
|
public List<OzoneAcl> getAddAcls() {
|
||||||
return addAcls;
|
return addAcls;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,7 +106,7 @@ public final class KsmBucketArgs {
|
||||||
* Returns the ACL's that are to be removed.
|
* Returns the ACL's that are to be removed.
|
||||||
* @return List<OzoneAclInfo>
|
* @return List<OzoneAclInfo>
|
||||||
*/
|
*/
|
||||||
public List<OzoneAclInfo> getRemoveAcls() {
|
public List<OzoneAcl> getRemoveAcls() {
|
||||||
return removeAcls;
|
return removeAcls;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,7 +122,7 @@ public final class KsmBucketArgs {
|
||||||
* Returns the type of storage to be used.
|
* Returns the type of storage to be used.
|
||||||
* @return StorageType
|
* @return StorageType
|
||||||
*/
|
*/
|
||||||
public StorageTypeProto getStorageType() {
|
public StorageType getStorageType() {
|
||||||
return storageType;
|
return storageType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,10 +141,10 @@ public final class KsmBucketArgs {
|
||||||
public static class Builder {
|
public static class Builder {
|
||||||
private String volumeName;
|
private String volumeName;
|
||||||
private String bucketName;
|
private String bucketName;
|
||||||
private List<OzoneAclInfo> addAcls;
|
private List<OzoneAcl> addAcls;
|
||||||
private List<OzoneAclInfo> removeAcls;
|
private List<OzoneAcl> removeAcls;
|
||||||
private Boolean isVersionEnabled;
|
private Boolean isVersionEnabled;
|
||||||
private StorageTypeProto storageType;
|
private StorageType storageType;
|
||||||
|
|
||||||
public Builder setVolumeName(String volume) {
|
public Builder setVolumeName(String volume) {
|
||||||
this.volumeName = volume;
|
this.volumeName = volume;
|
||||||
|
@ -155,12 +156,12 @@ public final class KsmBucketArgs {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder setAddAcls(List<OzoneAclInfo> acls) {
|
public Builder setAddAcls(List<OzoneAcl> acls) {
|
||||||
this.addAcls = acls;
|
this.addAcls = acls;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder setRemoveAcls(List<OzoneAclInfo> acls) {
|
public Builder setRemoveAcls(List<OzoneAcl> acls) {
|
||||||
this.removeAcls = acls;
|
this.removeAcls = acls;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -170,7 +171,7 @@ public final class KsmBucketArgs {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder setStorageType(StorageTypeProto storage) {
|
public Builder setStorageType(StorageType storage) {
|
||||||
this.storageType = storage;
|
this.storageType = storage;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -195,16 +196,19 @@ public final class KsmBucketArgs {
|
||||||
builder.setVolumeName(volumeName)
|
builder.setVolumeName(volumeName)
|
||||||
.setBucketName(bucketName);
|
.setBucketName(bucketName);
|
||||||
if(addAcls != null && !addAcls.isEmpty()) {
|
if(addAcls != null && !addAcls.isEmpty()) {
|
||||||
builder.addAllAddAcls(addAcls);
|
builder.addAllAddAcls(addAcls.stream().map(
|
||||||
|
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
if(removeAcls != null && !removeAcls.isEmpty()) {
|
if(removeAcls != null && !removeAcls.isEmpty()) {
|
||||||
builder.addAllRemoveAcls(removeAcls);
|
builder.addAllRemoveAcls(removeAcls.stream().map(
|
||||||
|
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
if(isVersionEnabled != null) {
|
if(isVersionEnabled != null) {
|
||||||
builder.setIsVersionEnabled(isVersionEnabled);
|
builder.setIsVersionEnabled(isVersionEnabled);
|
||||||
}
|
}
|
||||||
if(storageType != null) {
|
if(storageType != null) {
|
||||||
builder.setStorageType(storageType);
|
builder.setStorageType(
|
||||||
|
PBHelperClient.convertStorageType(storageType));
|
||||||
}
|
}
|
||||||
return builder.build();
|
return builder.build();
|
||||||
}
|
}
|
||||||
|
@ -217,10 +221,13 @@ public final class KsmBucketArgs {
|
||||||
public static KsmBucketArgs getFromProtobuf(BucketArgs bucketArgs) {
|
public static KsmBucketArgs getFromProtobuf(BucketArgs bucketArgs) {
|
||||||
return new KsmBucketArgs(bucketArgs.getVolumeName(),
|
return new KsmBucketArgs(bucketArgs.getVolumeName(),
|
||||||
bucketArgs.getBucketName(),
|
bucketArgs.getBucketName(),
|
||||||
bucketArgs.getAddAclsList(),
|
bucketArgs.getAddAclsList().stream().map(
|
||||||
bucketArgs.getRemoveAclsList(),
|
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()),
|
||||||
bucketArgs.hasIsVersionEnabled() ? bucketArgs.getIsVersionEnabled() :
|
bucketArgs.getRemoveAclsList().stream().map(
|
||||||
null,
|
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()),
|
||||||
bucketArgs.hasStorageType() ? bucketArgs.getStorageType() : null);
|
bucketArgs.hasIsVersionEnabled() ?
|
||||||
|
bucketArgs.getIsVersionEnabled() : null,
|
||||||
|
bucketArgs.hasStorageType() ? PBHelperClient.convertStorageType(
|
||||||
|
bucketArgs.getStorageType()) : null);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -18,15 +18,16 @@
|
||||||
package org.apache.hadoop.ksm.helpers;
|
package org.apache.hadoop.ksm.helpers;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import org.apache.hadoop.hdfs.protocol.proto
|
import org.apache.hadoop.fs.StorageType;
|
||||||
.HdfsProtos.StorageTypeProto;
|
import org.apache.hadoop.hdfs.protocolPB.PBHelperClient;
|
||||||
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocol.proto
|
||||||
.KeySpaceManagerProtocolProtos.BucketInfo;
|
.KeySpaceManagerProtocolProtos.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocolPB.KSMPBHelper;
|
||||||
.KeySpaceManagerProtocolProtos.OzoneAclInfo;
|
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A class that encapsulates Bucket Info.
|
* A class that encapsulates Bucket Info.
|
||||||
|
@ -43,7 +44,7 @@ public final class KsmBucketInfo {
|
||||||
/**
|
/**
|
||||||
* ACL Information.
|
* ACL Information.
|
||||||
*/
|
*/
|
||||||
private List<OzoneAclInfo> acls;
|
private List<OzoneAcl> acls;
|
||||||
/**
|
/**
|
||||||
* Bucket Version flag.
|
* Bucket Version flag.
|
||||||
*/
|
*/
|
||||||
|
@ -52,7 +53,7 @@ public final class KsmBucketInfo {
|
||||||
* Type of storage to be used for this bucket.
|
* Type of storage to be used for this bucket.
|
||||||
* [RAM_DISK, SSD, DISK, ARCHIVE]
|
* [RAM_DISK, SSD, DISK, ARCHIVE]
|
||||||
*/
|
*/
|
||||||
private StorageTypeProto storageType;
|
private StorageType storageType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Private constructor, constructed via builder.
|
* Private constructor, constructed via builder.
|
||||||
|
@ -63,8 +64,8 @@ public final class KsmBucketInfo {
|
||||||
* @param storageType - Storage type to be used.
|
* @param storageType - Storage type to be used.
|
||||||
*/
|
*/
|
||||||
private KsmBucketInfo(String volumeName, String bucketName,
|
private KsmBucketInfo(String volumeName, String bucketName,
|
||||||
List<OzoneAclInfo> acls, boolean isVersionEnabled,
|
List<OzoneAcl> acls, boolean isVersionEnabled,
|
||||||
StorageTypeProto storageType) {
|
StorageType storageType) {
|
||||||
this.volumeName = volumeName;
|
this.volumeName = volumeName;
|
||||||
this.bucketName = bucketName;
|
this.bucketName = bucketName;
|
||||||
this.acls = acls;
|
this.acls = acls;
|
||||||
|
@ -90,9 +91,9 @@ public final class KsmBucketInfo {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the ACL's associated with this bucket.
|
* Returns the ACL's associated with this bucket.
|
||||||
* @return List<OzoneAclInfo>
|
* @return List<OzoneAcl>
|
||||||
*/
|
*/
|
||||||
public List<OzoneAclInfo> getAcls() {
|
public List<OzoneAcl> getAcls() {
|
||||||
return acls;
|
return acls;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,9 +107,9 @@ public final class KsmBucketInfo {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the type of storage to be used.
|
* Returns the type of storage to be used.
|
||||||
* @return StorageTypeProto
|
* @return StorageType
|
||||||
*/
|
*/
|
||||||
public StorageTypeProto getStorageType() {
|
public StorageType getStorageType() {
|
||||||
return storageType;
|
return storageType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,15 +128,15 @@ public final class KsmBucketInfo {
|
||||||
public static class Builder {
|
public static class Builder {
|
||||||
private String volumeName;
|
private String volumeName;
|
||||||
private String bucketName;
|
private String bucketName;
|
||||||
private List<OzoneAclInfo> acls;
|
private List<OzoneAcl> acls;
|
||||||
private Boolean isVersionEnabled;
|
private Boolean isVersionEnabled;
|
||||||
private StorageTypeProto storageType;
|
private StorageType storageType;
|
||||||
|
|
||||||
Builder() {
|
Builder() {
|
||||||
//Default values
|
//Default values
|
||||||
this.acls = new LinkedList<>();
|
this.acls = new LinkedList<>();
|
||||||
this.isVersionEnabled = false;
|
this.isVersionEnabled = false;
|
||||||
this.storageType = StorageTypeProto.DISK;
|
this.storageType = StorageType.DISK;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder setVolumeName(String volume) {
|
public Builder setVolumeName(String volume) {
|
||||||
|
@ -148,7 +149,7 @@ public final class KsmBucketInfo {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder setAcls(List<OzoneAclInfo> listOfAcls) {
|
public Builder setAcls(List<OzoneAcl> listOfAcls) {
|
||||||
this.acls = listOfAcls;
|
this.acls = listOfAcls;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -158,7 +159,7 @@ public final class KsmBucketInfo {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder setStorageType(StorageTypeProto storage) {
|
public Builder setStorageType(StorageType storage) {
|
||||||
this.storageType = storage;
|
this.storageType = storage;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -185,9 +186,11 @@ public final class KsmBucketInfo {
|
||||||
return BucketInfo.newBuilder()
|
return BucketInfo.newBuilder()
|
||||||
.setVolumeName(volumeName)
|
.setVolumeName(volumeName)
|
||||||
.setBucketName(bucketName)
|
.setBucketName(bucketName)
|
||||||
.addAllAcls(acls)
|
.addAllAcls(acls.stream().map(
|
||||||
|
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()))
|
||||||
.setIsVersionEnabled(isVersionEnabled)
|
.setIsVersionEnabled(isVersionEnabled)
|
||||||
.setStorageType(storageType)
|
.setStorageType(PBHelperClient.convertStorageType(
|
||||||
|
storageType))
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,8 +203,10 @@ public final class KsmBucketInfo {
|
||||||
return new KsmBucketInfo(
|
return new KsmBucketInfo(
|
||||||
bucketInfo.getVolumeName(),
|
bucketInfo.getVolumeName(),
|
||||||
bucketInfo.getBucketName(),
|
bucketInfo.getBucketName(),
|
||||||
bucketInfo.getAclsList(),
|
bucketInfo.getAclsList().stream().map(
|
||||||
|
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()),
|
||||||
bucketInfo.getIsVersionEnabled(),
|
bucketInfo.getIsVersionEnabled(),
|
||||||
bucketInfo.getStorageType());
|
PBHelperClient.convertStorageType(
|
||||||
|
bucketInfo.getStorageType()));
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -17,9 +17,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
package org.apache.hadoop.ozone.web.request;
|
package org.apache.hadoop.ozone;
|
||||||
|
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.hadoop.ozone;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This package contains ozone client side libraries.
|
||||||
|
*/
|
|
@ -17,7 +17,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.ozone.protocolPB;
|
package org.apache.hadoop.ozone.protocolPB;
|
||||||
|
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocol.proto
|
||||||
.KeySpaceManagerProtocolProtos.OzoneAclInfo;
|
.KeySpaceManagerProtocolProtos.OzoneAclInfo;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocol.proto
|
|
@ -0,0 +1,24 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hadoop.ozone.protocolPB;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This package contains classes for the Protocol Buffers binding of Ozone
|
||||||
|
* protocols.
|
||||||
|
*/
|
|
@ -16,9 +16,8 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.hadoop.ozone.web;
|
package org.apache.hadoop.ozone;
|
||||||
|
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
|
@ -17,24 +17,19 @@
|
||||||
package org.apache.hadoop.ozone.ksm;
|
package org.apache.hadoop.ozone.ksm;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import org.apache.hadoop.hdfs.protocol.proto
|
import org.apache.hadoop.fs.StorageType;
|
||||||
.HdfsProtos.StorageTypeProto;
|
|
||||||
import org.apache.hadoop.ksm.helpers.KsmBucketArgs;
|
import org.apache.hadoop.ksm.helpers.KsmBucketArgs;
|
||||||
import org.apache.hadoop.ksm.helpers.KsmBucketInfo;
|
import org.apache.hadoop.ksm.helpers.KsmBucketInfo;
|
||||||
import org.apache.hadoop.ozone.ksm.exceptions.KSMException;
|
import org.apache.hadoop.ozone.ksm.exceptions.KSMException;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
|
||||||
.KeySpaceManagerProtocolProtos.OzoneAclInfo;
|
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.protocol.proto
|
||||||
.KeySpaceManagerProtocolProtos.BucketInfo;
|
.KeySpaceManagerProtocolProtos.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.protocolPB.KSMPBHelper;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
|
||||||
import org.iq80.leveldb.DBException;
|
import org.iq80.leveldb.DBException;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* KSM bucket manager.
|
* KSM bucket manager.
|
||||||
|
@ -179,10 +174,8 @@ public class BucketManagerImpl implements BucketManager {
|
||||||
|
|
||||||
//Check ACLs to update
|
//Check ACLs to update
|
||||||
if(args.getAddAcls() != null || args.getRemoveAcls() != null) {
|
if(args.getAddAcls() != null || args.getRemoveAcls() != null) {
|
||||||
List<OzoneAcl> acls = getUpdatedAclList(oldBucketInfo.getAcls(),
|
bucketInfoBuilder.setAcls(getUpdatedAclList(oldBucketInfo.getAcls(),
|
||||||
args.getRemoveAcls(), args.getAddAcls());
|
args.getRemoveAcls(), args.getAddAcls()));
|
||||||
bucketInfoBuilder.setAcls(acls.stream().map(
|
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
|
||||||
LOG.debug("Updating ACLs for bucket: {} in volume: {}",
|
LOG.debug("Updating ACLs for bucket: {} in volume: {}",
|
||||||
bucketName, volumeName);
|
bucketName, volumeName);
|
||||||
} else {
|
} else {
|
||||||
|
@ -190,9 +183,9 @@ public class BucketManagerImpl implements BucketManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
//Check StorageType to update
|
//Check StorageType to update
|
||||||
StorageTypeProto storageTypeProto = args.getStorageType();
|
StorageType storageType = args.getStorageType();
|
||||||
if(storageTypeProto != null) {
|
if(storageType != null) {
|
||||||
bucketInfoBuilder.setStorageType(storageTypeProto);
|
bucketInfoBuilder.setStorageType(storageType);
|
||||||
LOG.debug("Updating bucket storage type for bucket: {} in volume: {}",
|
LOG.debug("Updating bucket storage type for bucket: {} in volume: {}",
|
||||||
bucketName, volumeName);
|
bucketName, volumeName);
|
||||||
} else {
|
} else {
|
||||||
|
@ -226,26 +219,20 @@ public class BucketManagerImpl implements BucketManager {
|
||||||
* Remove is done before Add.
|
* Remove is done before Add.
|
||||||
*
|
*
|
||||||
* @param existingAcls - old ACL list.
|
* @param existingAcls - old ACL list.
|
||||||
* @param removeAclInfos - ACLs to be removed.
|
* @param removeAcls - ACLs to be removed.
|
||||||
* @param addAclInfos - ACLs to be added.
|
* @param addAcls - ACLs to be added.
|
||||||
* @return updated ACL list.
|
* @return updated ACL list.
|
||||||
*/
|
*/
|
||||||
private List<OzoneAcl> getUpdatedAclList(List<OzoneAclInfo> existingAcls,
|
private List<OzoneAcl> getUpdatedAclList(List<OzoneAcl> existingAcls,
|
||||||
List<OzoneAclInfo> removeAclInfos, List<OzoneAclInfo> addAclInfos) {
|
List<OzoneAcl> removeAcls, List<OzoneAcl> addAcls) {
|
||||||
List<OzoneAcl> acls = existingAcls.stream().map(
|
if(removeAcls != null && !removeAcls.isEmpty()) {
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList());
|
existingAcls.removeAll(removeAcls);
|
||||||
if(removeAclInfos != null && !removeAclInfos.isEmpty()) {
|
|
||||||
List<OzoneAcl> removeAcls = removeAclInfos.stream().map(
|
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList());
|
|
||||||
acls.removeAll(removeAcls);
|
|
||||||
}
|
}
|
||||||
if(addAclInfos != null && !addAclInfos.isEmpty()) {
|
if(addAcls != null && !addAcls.isEmpty()) {
|
||||||
List<OzoneAcl> addAcls = addAclInfos.stream().map(
|
addAcls.stream().filter(acl -> !existingAcls.contains(acl)).forEach(
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList());
|
existingAcls::add);
|
||||||
addAcls.stream().filter(acl -> !acls.contains(acl)).forEach(
|
|
||||||
acls::add);
|
|
||||||
}
|
}
|
||||||
return acls;
|
return existingAcls;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
package org.apache.hadoop.ozone.ksm;
|
package org.apache.hadoop.ozone.ksm;
|
||||||
|
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
/**
|
/**
|
||||||
* KSM Constants.
|
* KSM Constants.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -25,7 +25,7 @@ import org.apache.hadoop.ozone.OzoneClientUtils;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
||||||
import org.apache.hadoop.ozone.web.headers.Header;
|
import org.apache.hadoop.ozone.web.headers.Header;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.KeyInfo;
|
import org.apache.hadoop.ozone.web.response.KeyInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.ListKeys;
|
import org.apache.hadoop.ozone.web.response.ListKeys;
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
package org.apache.hadoop.ozone.web.handlers;
|
package org.apache.hadoop.ozone.web.handlers;
|
||||||
|
|
||||||
import org.apache.hadoop.fs.StorageType;
|
import org.apache.hadoop.fs.StorageType;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
|
|
|
@ -25,7 +25,7 @@ import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.ListArgs;
|
import org.apache.hadoop.ozone.web.handlers.ListArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.ListBuckets;
|
import org.apache.hadoop.ozone.web.response.ListBuckets;
|
||||||
import org.apache.hadoop.ozone.web.response.ListKeys;
|
import org.apache.hadoop.ozone.web.response.ListKeys;
|
||||||
|
|
|
@ -27,7 +27,7 @@ import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.ListArgs;
|
import org.apache.hadoop.ozone.web.handlers.ListArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
||||||
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneQuota;
|
import org.apache.hadoop.ozone.web.request.OzoneQuota;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.ListBuckets;
|
import org.apache.hadoop.ozone.web.response.ListBuckets;
|
||||||
|
|
|
@ -31,7 +31,7 @@ import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.ListArgs;
|
import org.apache.hadoop.ozone.web.handlers.ListArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.UserArgs;
|
import org.apache.hadoop.ozone.web.handlers.UserArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.KeyInfo;
|
import org.apache.hadoop.ozone.web.response.KeyInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.ListBuckets;
|
import org.apache.hadoop.ozone.web.response.ListBuckets;
|
||||||
|
|
|
@ -23,7 +23,7 @@ import java.util.List;
|
||||||
|
|
||||||
import org.apache.hadoop.fs.StorageType;
|
import org.apache.hadoop.fs.StorageType;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.utils.JsonUtils;
|
import org.apache.hadoop.ozone.web.utils.JsonUtils;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonAutoDetect;
|
import com.fasterxml.jackson.annotation.JsonAutoDetect;
|
||||||
|
|
|
@ -25,7 +25,6 @@ import org.apache.hadoop.hdfs.ozone.protocol.proto
|
||||||
import org.apache.hadoop.hdfs.ozone.protocol.proto
|
import org.apache.hadoop.hdfs.ozone.protocol.proto
|
||||||
.ContainerProtos.KeyData;
|
.ContainerProtos.KeyData;
|
||||||
import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
|
import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
|
||||||
import org.apache.hadoop.hdfs.protocolPB.PBHelperClient;
|
|
||||||
import org.apache.hadoop.hdfs.server.datanode.fsdataset
|
import org.apache.hadoop.hdfs.server.datanode.fsdataset
|
||||||
.LengthInputStream;
|
.LengthInputStream;
|
||||||
import org.apache.hadoop.ksm.helpers.KsmBucketArgs;
|
import org.apache.hadoop.ksm.helpers.KsmBucketArgs;
|
||||||
|
@ -40,7 +39,7 @@ import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts.Versioning;
|
import org.apache.hadoop.ozone.OzoneConsts.Versioning;
|
||||||
import org.apache.hadoop.ozone.protocolPB.KSMPBHelper;
|
import org.apache.hadoop.ozone.protocolPB.KSMPBHelper;
|
||||||
import org.apache.hadoop.ozone.ksm.KSMConfigKeys;
|
import org.apache.hadoop.ozone.ksm.KSMConfigKeys;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneQuota;
|
import org.apache.hadoop.ozone.web.request.OzoneQuota;
|
||||||
import org.apache.hadoop.scm.container.common.helpers.Pipeline;
|
import org.apache.hadoop.scm.container.common.helpers.Pipeline;
|
||||||
import org.apache.hadoop.scm.ScmConfigKeys;
|
import org.apache.hadoop.scm.ScmConfigKeys;
|
||||||
|
@ -78,7 +77,6 @@ import java.util.Locale;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A {@link StorageHandler} implementation that distributes object storage
|
* A {@link StorageHandler} implementation that distributes object storage
|
||||||
|
@ -205,12 +203,10 @@ public final class DistributedStorageHandler implements StorageHandler {
|
||||||
builder.setVolumeName(args.getVolumeName())
|
builder.setVolumeName(args.getVolumeName())
|
||||||
.setBucketName(args.getBucketName());
|
.setBucketName(args.getBucketName());
|
||||||
if(args.getAddAcls() != null) {
|
if(args.getAddAcls() != null) {
|
||||||
builder.setAcls(args.getAddAcls().stream().map(
|
builder.setAcls(args.getAddAcls());
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
|
||||||
}
|
}
|
||||||
if(args.getStorageType() != null) {
|
if(args.getStorageType() != null) {
|
||||||
builder.setStorageType(PBHelperClient.convertStorageType(
|
builder.setStorageType(args.getStorageType());
|
||||||
args.getStorageType()));
|
|
||||||
}
|
}
|
||||||
if(args.getVersioning() != null) {
|
if(args.getVersioning() != null) {
|
||||||
builder.setIsVersionEnabled(getBucketVersioningProtobuf(
|
builder.setIsVersionEnabled(getBucketVersioningProtobuf(
|
||||||
|
@ -250,12 +246,10 @@ public final class DistributedStorageHandler implements StorageHandler {
|
||||||
builder.setVolumeName(args.getVolumeName())
|
builder.setVolumeName(args.getVolumeName())
|
||||||
.setBucketName(args.getBucketName());
|
.setBucketName(args.getBucketName());
|
||||||
if(removeAcls != null && !removeAcls.isEmpty()) {
|
if(removeAcls != null && !removeAcls.isEmpty()) {
|
||||||
builder.setRemoveAcls(args.getRemoveAcls().stream().map(
|
builder.setRemoveAcls(args.getRemoveAcls());
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
|
||||||
}
|
}
|
||||||
if(addAcls != null && !addAcls.isEmpty()) {
|
if(addAcls != null && !addAcls.isEmpty()) {
|
||||||
builder.setAddAcls(args.getAddAcls().stream().map(
|
builder.setAddAcls(args.getAddAcls());
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
|
||||||
}
|
}
|
||||||
keySpaceManagerClient.setBucketProperty(builder.build());
|
keySpaceManagerClient.setBucketProperty(builder.build());
|
||||||
}
|
}
|
||||||
|
@ -278,8 +272,7 @@ public final class DistributedStorageHandler implements StorageHandler {
|
||||||
KsmBucketArgs.Builder builder = KsmBucketArgs.newBuilder();
|
KsmBucketArgs.Builder builder = KsmBucketArgs.newBuilder();
|
||||||
builder.setVolumeName(args.getVolumeName())
|
builder.setVolumeName(args.getVolumeName())
|
||||||
.setBucketName(args.getBucketName())
|
.setBucketName(args.getBucketName())
|
||||||
.setStorageType(PBHelperClient.convertStorageType(
|
.setStorageType(args.getStorageType());
|
||||||
args.getStorageType()));
|
|
||||||
keySpaceManagerClient.setBucketProperty(builder.build());
|
keySpaceManagerClient.setBucketProperty(builder.build());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -317,10 +310,8 @@ public final class DistributedStorageHandler implements StorageHandler {
|
||||||
} else {
|
} else {
|
||||||
bucketInfo.setVersioning(Versioning.DISABLED);
|
bucketInfo.setVersioning(Versioning.DISABLED);
|
||||||
}
|
}
|
||||||
bucketInfo.setStorageType(PBHelperClient.convertStorageType(
|
bucketInfo.setStorageType(ksmBucketInfo.getStorageType());
|
||||||
ksmBucketInfo.getStorageType()));
|
bucketInfo.setAcls(ksmBucketInfo.getAcls());
|
||||||
bucketInfo.setAcls(ksmBucketInfo.getAcls().stream().map(
|
|
||||||
KSMPBHelper::convertOzoneAcl).collect(Collectors.toList()));
|
|
||||||
return bucketInfo;
|
return bucketInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,18 +16,15 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.ozone.ksm;
|
package org.apache.hadoop.ozone.ksm;
|
||||||
|
|
||||||
|
import org.apache.hadoop.fs.StorageType;
|
||||||
import org.apache.hadoop.hdfs.DFSUtil;
|
import org.apache.hadoop.hdfs.DFSUtil;
|
||||||
import org.apache.hadoop.hdfs.protocol.proto.HdfsProtos;
|
|
||||||
import org.apache.hadoop.ksm.helpers.KsmBucketArgs;
|
import org.apache.hadoop.ksm.helpers.KsmBucketArgs;
|
||||||
import org.apache.hadoop.ksm.helpers.KsmBucketInfo;
|
import org.apache.hadoop.ksm.helpers.KsmBucketInfo;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
import org.apache.hadoop.ozone.ksm.exceptions.KSMException;
|
import org.apache.hadoop.ozone.ksm.exceptions.KSMException;
|
||||||
import org.apache.hadoop.ozone.ksm.exceptions
|
import org.apache.hadoop.ozone.ksm.exceptions
|
||||||
.KSMException.ResultCodes;
|
.KSMException.ResultCodes;
|
||||||
import org.apache.hadoop.ozone.protocol.proto
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
.KeySpaceManagerProtocolProtos.OzoneAclInfo;
|
|
||||||
import org.apache.hadoop.ozone.protocolPB.KSMPBHelper;
|
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -203,7 +200,7 @@ public class TestBucketManagerImpl {
|
||||||
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
.setStorageType(HdfsProtos.StorageTypeProto.DISK)
|
.setStorageType(StorageType.DISK)
|
||||||
.setIsVersionEnabled(false)
|
.setIsVersionEnabled(false)
|
||||||
.build();
|
.build();
|
||||||
bucketManager.createBucket(bucketInfo);
|
bucketManager.createBucket(bucketInfo);
|
||||||
|
@ -211,7 +208,7 @@ public class TestBucketManagerImpl {
|
||||||
"sampleVol", "bucketOne");
|
"sampleVol", "bucketOne");
|
||||||
Assert.assertEquals("sampleVol", result.getVolumeName());
|
Assert.assertEquals("sampleVol", result.getVolumeName());
|
||||||
Assert.assertEquals("bucketOne", result.getBucketName());
|
Assert.assertEquals("bucketOne", result.getBucketName());
|
||||||
Assert.assertEquals(HdfsProtos.StorageTypeProto.DISK,
|
Assert.assertEquals(StorageType.DISK,
|
||||||
result.getStorageType());
|
result.getStorageType());
|
||||||
Assert.assertEquals(false, result.getIsVersionEnabled());
|
Assert.assertEquals(false, result.getIsVersionEnabled());
|
||||||
}
|
}
|
||||||
|
@ -219,16 +216,16 @@ public class TestBucketManagerImpl {
|
||||||
@Test
|
@Test
|
||||||
public void testSetBucketPropertyAddACL() throws IOException {
|
public void testSetBucketPropertyAddACL() throws IOException {
|
||||||
MetadataManager metaMgr = getMetadataManagerMock("sampleVol");
|
MetadataManager metaMgr = getMetadataManagerMock("sampleVol");
|
||||||
List<OzoneAclInfo> acls = new LinkedList<>();
|
List<OzoneAcl> acls = new LinkedList<>();
|
||||||
OzoneAcl ozoneAcl = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
OzoneAcl ozoneAcl = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
||||||
"root", OzoneAcl.OzoneACLRights.READ);
|
"root", OzoneAcl.OzoneACLRights.READ);
|
||||||
acls.add(KSMPBHelper.convertOzoneAcl(ozoneAcl));
|
acls.add(ozoneAcl);
|
||||||
BucketManager bucketManager = new BucketManagerImpl(metaMgr);
|
BucketManager bucketManager = new BucketManagerImpl(metaMgr);
|
||||||
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
.setAcls(acls)
|
.setAcls(acls)
|
||||||
.setStorageType(HdfsProtos.StorageTypeProto.DISK)
|
.setStorageType(StorageType.DISK)
|
||||||
.setIsVersionEnabled(false)
|
.setIsVersionEnabled(false)
|
||||||
.build();
|
.build();
|
||||||
bucketManager.createBucket(bucketInfo);
|
bucketManager.createBucket(bucketInfo);
|
||||||
|
@ -237,10 +234,10 @@ public class TestBucketManagerImpl {
|
||||||
Assert.assertEquals("sampleVol", result.getVolumeName());
|
Assert.assertEquals("sampleVol", result.getVolumeName());
|
||||||
Assert.assertEquals("bucketOne", result.getBucketName());
|
Assert.assertEquals("bucketOne", result.getBucketName());
|
||||||
Assert.assertEquals(1, result.getAcls().size());
|
Assert.assertEquals(1, result.getAcls().size());
|
||||||
List<OzoneAclInfo> addAcls = new LinkedList<>();
|
List<OzoneAcl> addAcls = new LinkedList<>();
|
||||||
OzoneAcl newAcl = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
OzoneAcl newAcl = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
||||||
"ozone", OzoneAcl.OzoneACLRights.READ);
|
"ozone", OzoneAcl.OzoneACLRights.READ);
|
||||||
addAcls.add(KSMPBHelper.convertOzoneAcl(newAcl));
|
addAcls.add(newAcl);
|
||||||
KsmBucketArgs bucketArgs = KsmBucketArgs.newBuilder()
|
KsmBucketArgs bucketArgs = KsmBucketArgs.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
|
@ -250,34 +247,33 @@ public class TestBucketManagerImpl {
|
||||||
KsmBucketInfo updatedResult = bucketManager.getBucketInfo(
|
KsmBucketInfo updatedResult = bucketManager.getBucketInfo(
|
||||||
"sampleVol", "bucketOne");
|
"sampleVol", "bucketOne");
|
||||||
Assert.assertEquals(2, updatedResult.getAcls().size());
|
Assert.assertEquals(2, updatedResult.getAcls().size());
|
||||||
Assert.assertTrue(updatedResult.getAcls().contains(
|
Assert.assertTrue(updatedResult.getAcls().contains(newAcl));
|
||||||
KSMPBHelper.convertOzoneAcl(newAcl)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSetBucketPropertyRemoveACL() throws IOException {
|
public void testSetBucketPropertyRemoveACL() throws IOException {
|
||||||
MetadataManager metaMgr = getMetadataManagerMock("sampleVol");
|
MetadataManager metaMgr = getMetadataManagerMock("sampleVol");
|
||||||
List<OzoneAclInfo> acls = new LinkedList<>();
|
List<OzoneAcl> acls = new LinkedList<>();
|
||||||
OzoneAcl aclOne = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
OzoneAcl aclOne = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
||||||
"root", OzoneAcl.OzoneACLRights.READ);
|
"root", OzoneAcl.OzoneACLRights.READ);
|
||||||
OzoneAcl aclTwo = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
OzoneAcl aclTwo = new OzoneAcl(OzoneAcl.OzoneACLType.USER,
|
||||||
"ozone", OzoneAcl.OzoneACLRights.READ);
|
"ozone", OzoneAcl.OzoneACLRights.READ);
|
||||||
acls.add(KSMPBHelper.convertOzoneAcl(aclOne));
|
acls.add(aclOne);
|
||||||
acls.add(KSMPBHelper.convertOzoneAcl(aclTwo));
|
acls.add(aclTwo);
|
||||||
BucketManager bucketManager = new BucketManagerImpl(metaMgr);
|
BucketManager bucketManager = new BucketManagerImpl(metaMgr);
|
||||||
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
.setAcls(acls)
|
.setAcls(acls)
|
||||||
.setStorageType(HdfsProtos.StorageTypeProto.DISK)
|
.setStorageType(StorageType.DISK)
|
||||||
.setIsVersionEnabled(false)
|
.setIsVersionEnabled(false)
|
||||||
.build();
|
.build();
|
||||||
bucketManager.createBucket(bucketInfo);
|
bucketManager.createBucket(bucketInfo);
|
||||||
KsmBucketInfo result = bucketManager.getBucketInfo(
|
KsmBucketInfo result = bucketManager.getBucketInfo(
|
||||||
"sampleVol", "bucketOne");
|
"sampleVol", "bucketOne");
|
||||||
Assert.assertEquals(2, result.getAcls().size());
|
Assert.assertEquals(2, result.getAcls().size());
|
||||||
List<OzoneAclInfo> removeAcls = new LinkedList<>();
|
List<OzoneAcl> removeAcls = new LinkedList<>();
|
||||||
removeAcls.add(KSMPBHelper.convertOzoneAcl(aclTwo));
|
removeAcls.add(aclTwo);
|
||||||
KsmBucketArgs bucketArgs = KsmBucketArgs.newBuilder()
|
KsmBucketArgs bucketArgs = KsmBucketArgs.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
|
@ -287,8 +283,7 @@ public class TestBucketManagerImpl {
|
||||||
KsmBucketInfo updatedResult = bucketManager.getBucketInfo(
|
KsmBucketInfo updatedResult = bucketManager.getBucketInfo(
|
||||||
"sampleVol", "bucketOne");
|
"sampleVol", "bucketOne");
|
||||||
Assert.assertEquals(1, updatedResult.getAcls().size());
|
Assert.assertEquals(1, updatedResult.getAcls().size());
|
||||||
Assert.assertFalse(updatedResult.getAcls().contains(
|
Assert.assertFalse(updatedResult.getAcls().contains(aclTwo));
|
||||||
KSMPBHelper.convertOzoneAcl(aclTwo)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -298,22 +293,22 @@ public class TestBucketManagerImpl {
|
||||||
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
KsmBucketInfo bucketInfo = KsmBucketInfo.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
.setStorageType(HdfsProtos.StorageTypeProto.DISK)
|
.setStorageType(StorageType.DISK)
|
||||||
.build();
|
.build();
|
||||||
bucketManager.createBucket(bucketInfo);
|
bucketManager.createBucket(bucketInfo);
|
||||||
KsmBucketInfo result = bucketManager.getBucketInfo(
|
KsmBucketInfo result = bucketManager.getBucketInfo(
|
||||||
"sampleVol", "bucketOne");
|
"sampleVol", "bucketOne");
|
||||||
Assert.assertEquals(HdfsProtos.StorageTypeProto.DISK,
|
Assert.assertEquals(StorageType.DISK,
|
||||||
result.getStorageType());
|
result.getStorageType());
|
||||||
KsmBucketArgs bucketArgs = KsmBucketArgs.newBuilder()
|
KsmBucketArgs bucketArgs = KsmBucketArgs.newBuilder()
|
||||||
.setVolumeName("sampleVol")
|
.setVolumeName("sampleVol")
|
||||||
.setBucketName("bucketOne")
|
.setBucketName("bucketOne")
|
||||||
.setStorageType(HdfsProtos.StorageTypeProto.SSD)
|
.setStorageType(StorageType.SSD)
|
||||||
.build();
|
.build();
|
||||||
bucketManager.setBucketProperty(bucketArgs);
|
bucketManager.setBucketProperty(bucketArgs);
|
||||||
KsmBucketInfo updatedResult = bucketManager.getBucketInfo(
|
KsmBucketInfo updatedResult = bucketManager.getBucketInfo(
|
||||||
"sampleVol", "bucketOne");
|
"sampleVol", "bucketOne");
|
||||||
Assert.assertEquals(HdfsProtos.StorageTypeProto.SSD,
|
Assert.assertEquals(StorageType.SSD,
|
||||||
updatedResult.getStorageType());
|
updatedResult.getStorageType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.UserArgs;
|
import org.apache.hadoop.ozone.web.handlers.UserArgs;
|
||||||
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
import org.apache.hadoop.ozone.web.handlers.VolumeArgs;
|
||||||
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneQuota;
|
import org.apache.hadoop.ozone.web.request.OzoneQuota;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
||||||
|
|
|
@ -20,7 +20,7 @@ package org.apache.hadoop.ozone.web;
|
||||||
|
|
||||||
|
|
||||||
import org.apache.hadoop.fs.StorageType;
|
import org.apache.hadoop.fs.StorageType;
|
||||||
import org.apache.hadoop.ozone.web.request.OzoneAcl;
|
import org.apache.hadoop.ozone.OzoneAcl;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
Loading…
Reference in New Issue