HDFS-9916. OzoneHandler : Add Key handler. Contributed by Anu Engineer.

This commit is contained in:
Chris Nauroth 2016-03-09 10:17:05 -08:00 committed by Arpit Agarwal
parent ff4ea053d3
commit e882d6273c
7 changed files with 245 additions and 53 deletions

View File

@ -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);
err.setRequestId(args.getRequestID());
err.setResource(args.getResourceName()); if(args != null) {
err.setHostID(args.getHostName()); err.setRequestId(args.getRequestID());
err.setResource(args.getResourceName());
err.setHostID(args.getHostName());
}
err.setMessage(ex.getMessage()); err.setMessage(ex.getMessage());
return err; return err;
} }

View File

@ -174,18 +174,16 @@ 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); case Header.OZONE_LIST_QUERY_BUCKET:
// return getBucketKeysList(listArgs); return getBucketInfoResponse(args);
case Header.OZONE_LIST_QUERY_BUCKET: default:
return getBucketInfoResponse(args); OzoneException ozException =
default: ErrorTable.newError(ErrorTable.INVALID_QUERY_PARAM, args);
OzoneException ozException = ozException.setMessage("Unrecognized query param : " + info);
ErrorTable.newError(ErrorTable.INVALID_QUERY_PARAM, args); throw ozException;
ozException.setMessage("Unrecognized query param : " + info);
throw ozException;
} }
} }
}.handleCall(volume, bucket, req, uriInfo, headers); }.handleCall(volume, bucket, req, uriInfo, headers);

View File

@ -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());
}
} }

View File

@ -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";

View File

@ -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;
} }

View File

@ -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
@ -82,9 +85,8 @@ public class LocalStorageHandler implements StorageHandler {
/** /**
* Set Volume Quota Info. * Set Volume Quota Info.
* *
* @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
@ -93,23 +95,19 @@ public class LocalStorageHandler implements StorageHandler {
OzoneMetadataManager oz = OzoneMetadataManager oz =
OzoneMetadataManager.getOzoneMetadataManager(conf); OzoneMetadataManager.getOzoneMetadataManager(conf);
if(remove) { if (remove) {
OzoneQuota quota = new OzoneQuota(); OzoneQuota quota = new OzoneQuota();
args.setQuota(quota); args.setQuota(quota);
} }
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;
}
} }

View File

@ -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;
}
} }