HDFS-9916. OzoneHandler : Add Key handler. Contributed by Anu Engineer.
This commit is contained in:
parent
ff4ea053d3
commit
e882d6273c
|
@ -202,9 +202,12 @@ public final class ErrorTable {
|
||||||
Exception ex) {
|
Exception ex) {
|
||||||
OzoneException err =
|
OzoneException err =
|
||||||
new OzoneException(e.getHttpCode(), e.getShortMessage(), ex);
|
new OzoneException(e.getHttpCode(), e.getShortMessage(), ex);
|
||||||
|
|
||||||
|
if(args != null) {
|
||||||
err.setRequestId(args.getRequestID());
|
err.setRequestId(args.getRequestID());
|
||||||
err.setResource(args.getResourceName());
|
err.setResource(args.getResourceName());
|
||||||
err.setHostID(args.getHostName());
|
err.setHostID(args.getHostName());
|
||||||
|
}
|
||||||
err.setMessage(ex.getMessage());
|
err.setMessage(ex.getMessage());
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
|
@ -174,11 +174,9 @@ public class BucketHandler implements Bucket {
|
||||||
public Response doProcess(BucketArgs args)
|
public Response doProcess(BucketArgs args)
|
||||||
throws OzoneException, IOException {
|
throws OzoneException, IOException {
|
||||||
switch (info) {
|
switch (info) {
|
||||||
//TODO : Enable when Object support is enabled.
|
case Header.OZONE_LIST_QUERY_KEY:
|
||||||
// case Header.OZONE_LIST_QUERY_KEY:
|
ListArgs listArgs = new ListArgs(args, prefix, maxKeys, startPage);
|
||||||
// ListArgs listArgs = new ListArgs(args, prefix,
|
return getBucketKeysList(listArgs);
|
||||||
// maxKeys, startPage);
|
|
||||||
// return getBucketKeysList(listArgs);
|
|
||||||
case Header.OZONE_LIST_QUERY_BUCKET:
|
case Header.OZONE_LIST_QUERY_BUCKET:
|
||||||
return getBucketInfoResponse(args);
|
return getBucketInfoResponse(args);
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -26,6 +26,7 @@ import org.apache.hadoop.ozone.web.headers.Header;
|
||||||
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
||||||
import org.apache.hadoop.ozone.web.interfaces.UserAuth;
|
import org.apache.hadoop.ozone.web.interfaces.UserAuth;
|
||||||
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
import org.apache.hadoop.ozone.web.response.BucketInfo;
|
||||||
|
import org.apache.hadoop.ozone.web.response.ListKeys;
|
||||||
import org.apache.hadoop.ozone.web.utils.OzoneConsts;
|
import org.apache.hadoop.ozone.web.utils.OzoneConsts;
|
||||||
import org.apache.hadoop.ozone.web.utils.OzoneUtils;
|
import org.apache.hadoop.ozone.web.utils.OzoneUtils;
|
||||||
|
|
||||||
|
@ -179,7 +180,6 @@ public abstract class BucketProcessTemplate {
|
||||||
*
|
*
|
||||||
* @return List of ACLs
|
* @return List of ACLs
|
||||||
*
|
*
|
||||||
* @throws OzoneException
|
|
||||||
*/
|
*/
|
||||||
List<String> getAcls(BucketArgs args, String tag) {
|
List<String> getAcls(BucketArgs args, String tag) {
|
||||||
List<String> aclStrings =
|
List<String> aclStrings =
|
||||||
|
@ -275,4 +275,17 @@ public abstract class BucketProcessTemplate {
|
||||||
return OzoneUtils.getResponse(args, HTTP_OK, info.toJsonString());
|
return OzoneUtils.getResponse(args, HTTP_OK, info.toJsonString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns list of objects in a bucket.
|
||||||
|
* @param args - ListArgs
|
||||||
|
* @return Response
|
||||||
|
* @throws IOException
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
Response getBucketKeysList(ListArgs args) throws IOException, OzoneException {
|
||||||
|
StorageHandler fs = StorageHandlerBuilder.getStorageHandler();
|
||||||
|
ListKeys objects = fs.listKeys(args);
|
||||||
|
return OzoneUtils.getResponse(args, HTTP_OK, objects.toJsonString());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,7 @@ public final class Header {
|
||||||
|
|
||||||
public static final String OZONE_LIST_QUERY_TAG ="info";
|
public static final String OZONE_LIST_QUERY_TAG ="info";
|
||||||
public static final String OZONE_QUOTA_QUERY_TAG ="quota";
|
public static final String OZONE_QUOTA_QUERY_TAG ="quota";
|
||||||
|
public static final String CONTENT_MD5 = "Content-MD5";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -19,16 +19,21 @@
|
||||||
package org.apache.hadoop.ozone.web.interfaces;
|
package org.apache.hadoop.ozone.web.interfaces;
|
||||||
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
|
import org.apache.hadoop.hdfs.server.datanode.fsdataset.LengthInputStream;
|
||||||
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
||||||
import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
||||||
|
import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
|
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.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.ListVolumes;
|
import org.apache.hadoop.ozone.web.response.ListVolumes;
|
||||||
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Storage handler Interface is the Interface between
|
* Storage handler Interface is the Interface between
|
||||||
|
@ -205,5 +210,64 @@ public interface StorageHandler {
|
||||||
*/
|
*/
|
||||||
BucketInfo getBucketInfo(BucketArgs args) throws IOException, OzoneException;
|
BucketInfo getBucketInfo(BucketArgs args) throws IOException, OzoneException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a key in an existing bucket.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
*
|
||||||
|
* @return InputStream
|
||||||
|
*
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
OutputStream newKeyWriter(KeyArgs args)
|
||||||
|
throws IOException, OzoneException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tells the file system that the object has been written out
|
||||||
|
* completely and it can do any house keeping operation that needs
|
||||||
|
* to be done.
|
||||||
|
*
|
||||||
|
* @param args Key Args
|
||||||
|
*
|
||||||
|
* @param stream
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
void commitKey(KeyArgs args, OutputStream stream)
|
||||||
|
throws IOException, OzoneException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads a key from an existing bucket.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
*
|
||||||
|
* @return LengthInputStream
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
LengthInputStream newKeyReader(KeyArgs args)
|
||||||
|
throws IOException, OzoneException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes an existing key.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
*
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
void deleteKey(KeyArgs args) throws IOException, OzoneException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a list of Key.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
*
|
||||||
|
* @return BucketList
|
||||||
|
*
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
ListKeys listKeys(ListArgs args) throws IOException, OzoneException;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,28 +20,33 @@ package org.apache.hadoop.ozone.web.localstorage;
|
||||||
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
import org.apache.hadoop.hdfs.server.datanode.fsdataset.LengthInputStream;
|
||||||
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
||||||
import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
||||||
|
import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
|
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.interfaces.StorageHandler;
|
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
||||||
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;
|
||||||
|
import org.apache.hadoop.ozone.web.response.ListKeys;
|
||||||
import org.apache.hadoop.ozone.web.response.ListVolumes;
|
import org.apache.hadoop.ozone.web.response.ListVolumes;
|
||||||
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* PLEASE NOTE : This file is a dummy backend for test purposes
|
* PLEASE NOTE : This file is a dummy backend for test purposes and prototyping
|
||||||
* and prototyping effort only. It does not handle any Object semantics
|
* effort only. It does not handle any Object semantics correctly, neither does
|
||||||
* correctly, neither does it take care of security.
|
* it take care of security.
|
||||||
*/
|
*/
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class LocalStorageHandler implements StorageHandler {
|
public class LocalStorageHandler implements StorageHandler {
|
||||||
private final Configuration conf;
|
private final Configuration conf;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs LocalStorageHandler.
|
* Constructs LocalStorageHandler.
|
||||||
*/
|
*/
|
||||||
|
@ -53,7 +58,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Creates Storage Volume.
|
* Creates Storage Volume.
|
||||||
*
|
*
|
||||||
* @param args - volumeArgs
|
* @param args - volumeArgs
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -68,7 +72,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* setVolumeOwner - sets the owner of the volume.
|
* setVolumeOwner - sets the owner of the volume.
|
||||||
*
|
*
|
||||||
* @param args volumeArgs
|
* @param args volumeArgs
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -84,7 +87,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
*
|
*
|
||||||
* @param args - volumeArgs
|
* @param args - volumeArgs
|
||||||
* @param remove - true if the request is to remove the quota
|
* @param remove - true if the request is to remove the quota
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -100,16 +102,12 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
oz.setVolumeProperty(args, OzoneMetadataManager.VolumeProperty.QUOTA);
|
oz.setVolumeProperty(args, OzoneMetadataManager.VolumeProperty.QUOTA);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if a Volume exists and the user specified has access to the
|
* Checks if a Volume exists and the user specified has access to the volume.
|
||||||
* volume.
|
|
||||||
*
|
*
|
||||||
* @param args - volumeArgs
|
* @param args - volumeArgs
|
||||||
*
|
* @return - Boolean - True if the user can modify the volume. This is
|
||||||
* @return - Boolean - True if the user can modify the volume.
|
* possible for owners of the volume and admin users
|
||||||
* This is possible for owners of the volume and admin users
|
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -120,14 +118,11 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
return oz.checkVolumeAccess(args);
|
return oz.checkVolumeAccess(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns Info about the specified Volume.
|
* Returns Info about the specified Volume.
|
||||||
*
|
*
|
||||||
* @param args - volumeArgs
|
* @param args - volumeArgs
|
||||||
*
|
|
||||||
* @return VolumeInfo
|
* @return VolumeInfo
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -138,12 +133,10 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
return oz.getVolumeInfo(args);
|
return oz.getVolumeInfo(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes an Empty Volume.
|
* Deletes an Empty Volume.
|
||||||
*
|
*
|
||||||
* @param args - Volume Args
|
* @param args - Volume Args
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -158,9 +151,7 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Returns the List of Volumes owned by the specific user.
|
* Returns the List of Volumes owned by the specific user.
|
||||||
*
|
*
|
||||||
* @param args - UserArgs
|
* @param args - UserArgs
|
||||||
*
|
|
||||||
* @return - List of Volumes
|
* @return - List of Volumes
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -172,11 +163,10 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* true if the bucket exists and user has read access
|
* true if the bucket exists and user has read access to the bucket else
|
||||||
* to the bucket else throws Exception.
|
* throws Exception.
|
||||||
*
|
*
|
||||||
* @param args Bucket args structure
|
* @param args Bucket args structure
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -189,7 +179,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Creates a Bucket in specified Volume.
|
* Creates a Bucket in specified Volume.
|
||||||
*
|
*
|
||||||
* @param args BucketArgs- BucketName, UserName and Acls
|
* @param args BucketArgs- BucketName, UserName and Acls
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -203,7 +192,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Adds or Removes ACLs from a Bucket.
|
* Adds or Removes ACLs from a Bucket.
|
||||||
*
|
*
|
||||||
* @param args - BucketArgs
|
* @param args - BucketArgs
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -218,7 +206,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Enables or disables Bucket Versioning.
|
* Enables or disables Bucket Versioning.
|
||||||
*
|
*
|
||||||
* @param args - BucketArgs
|
* @param args - BucketArgs
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -234,7 +221,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Sets the Storage Class of a Bucket.
|
* Sets the Storage Class of a Bucket.
|
||||||
*
|
*
|
||||||
* @param args - BucketArgs
|
* @param args - BucketArgs
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -250,7 +236,6 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Deletes a bucket if it is empty.
|
* Deletes a bucket if it is empty.
|
||||||
*
|
*
|
||||||
* @param args Bucket args structure
|
* @param args Bucket args structure
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -264,9 +249,7 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Returns all Buckets of a specified Volume.
|
* Returns all Buckets of a specified Volume.
|
||||||
*
|
*
|
||||||
* @param args --User Args
|
* @param args --User Args
|
||||||
*
|
|
||||||
* @return ListAllBuckets
|
* @return ListAllBuckets
|
||||||
*
|
|
||||||
* @throws OzoneException
|
* @throws OzoneException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -281,9 +264,7 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
* Returns Bucket's Metadata as a String.
|
* Returns Bucket's Metadata as a String.
|
||||||
*
|
*
|
||||||
* @param args Bucket args structure
|
* @param args Bucket args structure
|
||||||
*
|
|
||||||
* @return Info about the bucket
|
* @return Info about the bucket
|
||||||
*
|
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -293,4 +274,68 @@ public class LocalStorageHandler implements StorageHandler {
|
||||||
OzoneMetadataManager.getOzoneMetadataManager(conf);
|
OzoneMetadataManager.getOzoneMetadataManager(conf);
|
||||||
return oz.getBucketInfo(args);
|
return oz.getBucketInfo(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a key in an existing bucket.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @return InputStream
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public OutputStream newKeyWriter(KeyArgs args) throws IOException,
|
||||||
|
OzoneException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tells the file system that the object has been written out completely and
|
||||||
|
* it can do any house keeping operation that needs to be done.
|
||||||
|
*
|
||||||
|
* @param args Key Args
|
||||||
|
* @param stream
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void commitKey(KeyArgs args, OutputStream stream) throws
|
||||||
|
IOException, OzoneException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads a key from an existing bucket.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @return LengthInputStream
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public LengthInputStream newKeyReader(KeyArgs args) throws IOException,
|
||||||
|
OzoneException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes an existing key.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void deleteKey(KeyArgs args) throws IOException, OzoneException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a list of Key.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @return BucketList
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public ListKeys listKeys(ListArgs args) throws IOException, OzoneException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,18 +18,23 @@
|
||||||
|
|
||||||
package org.apache.hadoop.ozone.web.storage;
|
package org.apache.hadoop.ozone.web.storage;
|
||||||
|
|
||||||
import java.io.IOException;
|
import org.apache.hadoop.hdfs.server.datanode.fsdataset.LengthInputStream;
|
||||||
|
|
||||||
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
import org.apache.hadoop.ozone.web.exceptions.OzoneException;
|
||||||
import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
import org.apache.hadoop.ozone.web.handlers.BucketArgs;
|
||||||
|
import org.apache.hadoop.ozone.web.handlers.KeyArgs;
|
||||||
|
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.interfaces.StorageHandler;
|
import org.apache.hadoop.ozone.web.interfaces.StorageHandler;
|
||||||
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.ListVolumes;
|
import org.apache.hadoop.ozone.web.response.ListVolumes;
|
||||||
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
import org.apache.hadoop.ozone.web.response.VolumeInfo;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A {@link StorageHandler} implementation that distributes object storage
|
* A {@link StorageHandler} implementation that distributes object storage
|
||||||
* across the nodes of an HDFS cluster.
|
* across the nodes of an HDFS cluster.
|
||||||
|
@ -125,4 +130,67 @@ public final class DistributedStorageHandler implements StorageHandler {
|
||||||
throws IOException, OzoneException {
|
throws IOException, OzoneException {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Writes a key in an existing bucket.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @return InputStream
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public OutputStream newKeyWriter(KeyArgs args) throws IOException,
|
||||||
|
OzoneException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tells the file system that the object has been written out completely and
|
||||||
|
* it can do any house keeping operation that needs to be done.
|
||||||
|
*
|
||||||
|
* @param args Key Args
|
||||||
|
* @param stream
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void commitKey(KeyArgs args, OutputStream stream) throws
|
||||||
|
IOException, OzoneException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads a key from an existing bucket.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @return LengthInputStream
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public LengthInputStream newKeyReader(KeyArgs args) throws IOException,
|
||||||
|
OzoneException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes an existing key.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @throws OzoneException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void deleteKey(KeyArgs args) throws IOException, OzoneException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a list of Key.
|
||||||
|
*
|
||||||
|
* @param args KeyArgs
|
||||||
|
* @return BucketList
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public ListKeys listKeys(ListArgs args) throws IOException, OzoneException {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue