HDFS-3481. Refactor HttpFS handling of JAX-RS query string parameters (tucu)
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1354599 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
bb9ac4fe4c
commit
d263653ae2
|
@ -154,42 +154,34 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
|
|
||||||
public static final int HTTP_TEMPORARY_REDIRECT = 307;
|
public static final int HTTP_TEMPORARY_REDIRECT = 307;
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get operations.
|
|
||||||
*/
|
|
||||||
public enum GetOpValues {
|
|
||||||
OPEN, GETFILESTATUS, LISTSTATUS, GETHOMEDIRECTORY, GETCONTENTSUMMARY, GETFILECHECKSUM,
|
|
||||||
GETDELEGATIONTOKEN, GETFILEBLOCKLOCATIONS, INSTRUMENTATION
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Post operations.
|
|
||||||
*/
|
|
||||||
public static enum PostOpValues {
|
|
||||||
APPEND
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Put operations.
|
|
||||||
*/
|
|
||||||
public static enum PutOpValues {
|
|
||||||
CREATE, MKDIRS, RENAME, SETOWNER, SETPERMISSION, SETREPLICATION, SETTIMES,
|
|
||||||
RENEWDELEGATIONTOKEN, CANCELDELEGATIONTOKEN
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Delete operations.
|
|
||||||
*/
|
|
||||||
public static enum DeleteOpValues {
|
|
||||||
DELETE
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final String HTTP_GET = "GET";
|
private static final String HTTP_GET = "GET";
|
||||||
private static final String HTTP_PUT = "PUT";
|
private static final String HTTP_PUT = "PUT";
|
||||||
private static final String HTTP_POST = "POST";
|
private static final String HTTP_POST = "POST";
|
||||||
private static final String HTTP_DELETE = "DELETE";
|
private static final String HTTP_DELETE = "DELETE";
|
||||||
|
|
||||||
|
public enum Operation {
|
||||||
|
OPEN(HTTP_GET), GETFILESTATUS(HTTP_GET), LISTSTATUS(HTTP_GET),
|
||||||
|
GETHOMEDIRECTORY(HTTP_GET), GETCONTENTSUMMARY(HTTP_GET),
|
||||||
|
GETFILECHECKSUM(HTTP_GET), GETFILEBLOCKLOCATIONS(HTTP_GET),
|
||||||
|
INSTRUMENTATION(HTTP_GET),
|
||||||
|
APPEND(HTTP_POST),
|
||||||
|
CREATE(HTTP_PUT), MKDIRS(HTTP_PUT), RENAME(HTTP_PUT), SETOWNER(HTTP_PUT),
|
||||||
|
SETPERMISSION(HTTP_PUT), SETREPLICATION(HTTP_PUT), SETTIMES(HTTP_PUT),
|
||||||
|
DELETE(HTTP_DELETE);
|
||||||
|
|
||||||
|
private String httpMethod;
|
||||||
|
|
||||||
|
Operation(String httpMethod) {
|
||||||
|
this.httpMethod = httpMethod;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getMethod() {
|
||||||
|
return httpMethod;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private AuthenticatedURL.Token authToken = new AuthenticatedURL.Token();
|
private AuthenticatedURL.Token authToken = new AuthenticatedURL.Token();
|
||||||
private URI uri;
|
private URI uri;
|
||||||
private Path workingDir;
|
private Path workingDir;
|
||||||
|
@ -402,10 +394,12 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public FSDataInputStream open(Path f, int bufferSize) throws IOException {
|
public FSDataInputStream open(Path f, int bufferSize) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, GetOpValues.OPEN.toString());
|
params.put(OP_PARAM, Operation.OPEN.toString());
|
||||||
HttpURLConnection conn = getConnection(HTTP_GET, params, f, true);
|
HttpURLConnection conn = getConnection(Operation.OPEN.getMethod(), params,
|
||||||
|
f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
return new FSDataInputStream(new HttpFSDataInputStream(conn.getInputStream(), bufferSize));
|
return new FSDataInputStream(
|
||||||
|
new HttpFSDataInputStream(conn.getInputStream(), bufferSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -508,15 +502,18 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
* @see #setPermission(Path, FsPermission)
|
* @see #setPermission(Path, FsPermission)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FSDataOutputStream create(Path f, FsPermission permission, boolean overwrite, int bufferSize,
|
public FSDataOutputStream create(Path f, FsPermission permission,
|
||||||
short replication, long blockSize, Progressable progress) throws IOException {
|
boolean overwrite, int bufferSize,
|
||||||
|
short replication, long blockSize,
|
||||||
|
Progressable progress) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.CREATE.toString());
|
params.put(OP_PARAM, Operation.CREATE.toString());
|
||||||
params.put(OVERWRITE_PARAM, Boolean.toString(overwrite));
|
params.put(OVERWRITE_PARAM, Boolean.toString(overwrite));
|
||||||
params.put(REPLICATION_PARAM, Short.toString(replication));
|
params.put(REPLICATION_PARAM, Short.toString(replication));
|
||||||
params.put(BLOCKSIZE_PARAM, Long.toString(blockSize));
|
params.put(BLOCKSIZE_PARAM, Long.toString(blockSize));
|
||||||
params.put(PERMISSION_PARAM, permissionToString(permission));
|
params.put(PERMISSION_PARAM, permissionToString(permission));
|
||||||
return uploadData(HTTP_PUT, f, params, bufferSize, HttpURLConnection.HTTP_CREATED);
|
return uploadData(Operation.CREATE.getMethod(), f, params, bufferSize,
|
||||||
|
HttpURLConnection.HTTP_CREATED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -532,10 +529,12 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FSDataOutputStream append(Path f, int bufferSize, Progressable progress) throws IOException {
|
public FSDataOutputStream append(Path f, int bufferSize,
|
||||||
|
Progressable progress) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PostOpValues.APPEND.toString());
|
params.put(OP_PARAM, Operation.APPEND.toString());
|
||||||
return uploadData(HTTP_POST, f, params, bufferSize, HttpURLConnection.HTTP_OK);
|
return uploadData(Operation.APPEND.getMethod(), f, params, bufferSize,
|
||||||
|
HttpURLConnection.HTTP_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -545,9 +544,10 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public boolean rename(Path src, Path dst) throws IOException {
|
public boolean rename(Path src, Path dst) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.RENAME.toString());
|
params.put(OP_PARAM, Operation.RENAME.toString());
|
||||||
params.put(DESTINATION_PARAM, dst.toString());
|
params.put(DESTINATION_PARAM, dst.toString());
|
||||||
HttpURLConnection conn = getConnection(HTTP_PUT, params, src, true);
|
HttpURLConnection conn = getConnection(Operation.RENAME.getMethod(),
|
||||||
|
params, src, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
return (Boolean) json.get(RENAME_JSON);
|
return (Boolean) json.get(RENAME_JSON);
|
||||||
|
@ -580,9 +580,10 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public boolean delete(Path f, boolean recursive) throws IOException {
|
public boolean delete(Path f, boolean recursive) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, DeleteOpValues.DELETE.toString());
|
params.put(OP_PARAM, Operation.DELETE.toString());
|
||||||
params.put(RECURSIVE_PARAM, Boolean.toString(recursive));
|
params.put(RECURSIVE_PARAM, Boolean.toString(recursive));
|
||||||
HttpURLConnection conn = getConnection(HTTP_DELETE, params, f, true);
|
HttpURLConnection conn = getConnection(Operation.DELETE.getMethod(),
|
||||||
|
params, f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
return (Boolean) json.get(DELETE_JSON);
|
return (Boolean) json.get(DELETE_JSON);
|
||||||
|
@ -601,8 +602,9 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public FileStatus[] listStatus(Path f) throws IOException {
|
public FileStatus[] listStatus(Path f) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, GetOpValues.LISTSTATUS.toString());
|
params.put(OP_PARAM, Operation.LISTSTATUS.toString());
|
||||||
HttpURLConnection conn = getConnection(HTTP_GET, params, f, true);
|
HttpURLConnection conn = getConnection(Operation.LISTSTATUS.getMethod(),
|
||||||
|
params, f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
json = (JSONObject) json.get(FILE_STATUSES_JSON);
|
json = (JSONObject) json.get(FILE_STATUSES_JSON);
|
||||||
|
@ -647,9 +649,10 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public boolean mkdirs(Path f, FsPermission permission) throws IOException {
|
public boolean mkdirs(Path f, FsPermission permission) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.MKDIRS.toString());
|
params.put(OP_PARAM, Operation.MKDIRS.toString());
|
||||||
params.put(PERMISSION_PARAM, permissionToString(permission));
|
params.put(PERMISSION_PARAM, permissionToString(permission));
|
||||||
HttpURLConnection conn = getConnection(HTTP_PUT, params, f, true);
|
HttpURLConnection conn = getConnection(Operation.MKDIRS.getMethod(),
|
||||||
|
params, f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
return (Boolean) json.get(MKDIRS_JSON);
|
return (Boolean) json.get(MKDIRS_JSON);
|
||||||
|
@ -668,8 +671,9 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public FileStatus getFileStatus(Path f) throws IOException {
|
public FileStatus getFileStatus(Path f) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, GetOpValues.GETFILESTATUS.toString());
|
params.put(OP_PARAM, Operation.GETFILESTATUS.toString());
|
||||||
HttpURLConnection conn = getConnection(HTTP_GET, params, f, true);
|
HttpURLConnection conn = getConnection(Operation.GETFILESTATUS.getMethod(),
|
||||||
|
params, f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
json = (JSONObject) json.get(FILE_STATUS_JSON);
|
json = (JSONObject) json.get(FILE_STATUS_JSON);
|
||||||
|
@ -684,9 +688,11 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public Path getHomeDirectory() {
|
public Path getHomeDirectory() {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, GetOpValues.GETHOMEDIRECTORY.toString());
|
params.put(OP_PARAM, Operation.GETHOMEDIRECTORY.toString());
|
||||||
try {
|
try {
|
||||||
HttpURLConnection conn = getConnection(HTTP_GET, params, new Path(getUri().toString(), "/"), false);
|
HttpURLConnection conn =
|
||||||
|
getConnection(Operation.GETHOMEDIRECTORY.getMethod(), params,
|
||||||
|
new Path(getUri().toString(), "/"), false);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
return new Path((String) json.get(HOME_DIR_JSON));
|
return new Path((String) json.get(HOME_DIR_JSON));
|
||||||
|
@ -704,12 +710,14 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
* @param groupname If it is null, the original groupname remains unchanged.
|
* @param groupname If it is null, the original groupname remains unchanged.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void setOwner(Path p, String username, String groupname) throws IOException {
|
public void setOwner(Path p, String username, String groupname)
|
||||||
|
throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.SETOWNER.toString());
|
params.put(OP_PARAM, Operation.SETOWNER.toString());
|
||||||
params.put(OWNER_PARAM, username);
|
params.put(OWNER_PARAM, username);
|
||||||
params.put(GROUP_PARAM, groupname);
|
params.put(GROUP_PARAM, groupname);
|
||||||
HttpURLConnection conn = getConnection(HTTP_PUT, params, p, true);
|
HttpURLConnection conn = getConnection(Operation.SETOWNER.getMethod(),
|
||||||
|
params, p, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -722,9 +730,9 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public void setPermission(Path p, FsPermission permission) throws IOException {
|
public void setPermission(Path p, FsPermission permission) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.SETPERMISSION.toString());
|
params.put(OP_PARAM, Operation.SETPERMISSION.toString());
|
||||||
params.put(PERMISSION_PARAM, permissionToString(permission));
|
params.put(PERMISSION_PARAM, permissionToString(permission));
|
||||||
HttpURLConnection conn = getConnection(HTTP_PUT, params, p, true);
|
HttpURLConnection conn = getConnection(Operation.SETPERMISSION.getMethod(), params, p, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -742,10 +750,11 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public void setTimes(Path p, long mtime, long atime) throws IOException {
|
public void setTimes(Path p, long mtime, long atime) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.SETTIMES.toString());
|
params.put(OP_PARAM, Operation.SETTIMES.toString());
|
||||||
params.put(MODIFICATION_TIME_PARAM, Long.toString(mtime));
|
params.put(MODIFICATION_TIME_PARAM, Long.toString(mtime));
|
||||||
params.put(ACCESS_TIME_PARAM, Long.toString(atime));
|
params.put(ACCESS_TIME_PARAM, Long.toString(atime));
|
||||||
HttpURLConnection conn = getConnection(HTTP_PUT, params, p, true);
|
HttpURLConnection conn = getConnection(Operation.SETTIMES.getMethod(),
|
||||||
|
params, p, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -761,11 +770,13 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean setReplication(Path src, short replication) throws IOException {
|
public boolean setReplication(Path src, short replication)
|
||||||
|
throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, PutOpValues.SETREPLICATION.toString());
|
params.put(OP_PARAM, Operation.SETREPLICATION.toString());
|
||||||
params.put(REPLICATION_PARAM, Short.toString(replication));
|
params.put(REPLICATION_PARAM, Short.toString(replication));
|
||||||
HttpURLConnection conn = getConnection(HTTP_PUT, params, src, true);
|
HttpURLConnection conn =
|
||||||
|
getConnection(Operation.SETREPLICATION.getMethod(), params, src, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) jsonParse(conn);
|
JSONObject json = (JSONObject) jsonParse(conn);
|
||||||
return (Boolean) json.get(SET_REPLICATION_JSON);
|
return (Boolean) json.get(SET_REPLICATION_JSON);
|
||||||
|
@ -814,10 +825,12 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public ContentSummary getContentSummary(Path f) throws IOException {
|
public ContentSummary getContentSummary(Path f) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, GetOpValues.GETCONTENTSUMMARY.toString());
|
params.put(OP_PARAM, Operation.GETCONTENTSUMMARY.toString());
|
||||||
HttpURLConnection conn = getConnection(HTTP_GET, params, f, true);
|
HttpURLConnection conn =
|
||||||
|
getConnection(Operation.GETCONTENTSUMMARY.getMethod(), params, f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
JSONObject json = (JSONObject) ((JSONObject) jsonParse(conn)).get(CONTENT_SUMMARY_JSON);
|
JSONObject json =
|
||||||
|
(JSONObject) ((JSONObject) jsonParse(conn)).get(CONTENT_SUMMARY_JSON);
|
||||||
return new ContentSummary((Long) json.get(CONTENT_SUMMARY_LENGTH_JSON),
|
return new ContentSummary((Long) json.get(CONTENT_SUMMARY_LENGTH_JSON),
|
||||||
(Long) json.get(CONTENT_SUMMARY_FILE_COUNT_JSON),
|
(Long) json.get(CONTENT_SUMMARY_FILE_COUNT_JSON),
|
||||||
(Long) json.get(CONTENT_SUMMARY_DIRECTORY_COUNT_JSON),
|
(Long) json.get(CONTENT_SUMMARY_DIRECTORY_COUNT_JSON),
|
||||||
|
@ -830,10 +843,12 @@ public class HttpFSFileSystem extends FileSystem {
|
||||||
@Override
|
@Override
|
||||||
public FileChecksum getFileChecksum(Path f) throws IOException {
|
public FileChecksum getFileChecksum(Path f) throws IOException {
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
params.put(OP_PARAM, GetOpValues.GETFILECHECKSUM.toString());
|
params.put(OP_PARAM, Operation.GETFILECHECKSUM.toString());
|
||||||
HttpURLConnection conn = getConnection(HTTP_GET, params, f, true);
|
HttpURLConnection conn =
|
||||||
|
getConnection(Operation.GETFILECHECKSUM.getMethod(), params, f, true);
|
||||||
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
validateResponse(conn, HttpURLConnection.HTTP_OK);
|
||||||
final JSONObject json = (JSONObject) ((JSONObject) jsonParse(conn)).get(FILE_CHECKSUM_JSON);
|
final JSONObject json =
|
||||||
|
(JSONObject) ((JSONObject) jsonParse(conn)).get(FILE_CHECKSUM_JSON);
|
||||||
return new FileChecksum() {
|
return new FileChecksum() {
|
||||||
@Override
|
@Override
|
||||||
public String getAlgorithmName() {
|
public String getAlgorithmName() {
|
||||||
|
|
|
@ -30,7 +30,6 @@ import javax.servlet.ServletResponse;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.InetAddress;
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
@ -43,8 +42,8 @@ public class CheckUploadContentTypeFilter implements Filter {
|
||||||
private static final Set<String> UPLOAD_OPERATIONS = new HashSet<String>();
|
private static final Set<String> UPLOAD_OPERATIONS = new HashSet<String>();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
UPLOAD_OPERATIONS.add(HttpFSFileSystem.PostOpValues.APPEND.toString());
|
UPLOAD_OPERATIONS.add(HttpFSFileSystem.Operation.APPEND.toString());
|
||||||
UPLOAD_OPERATIONS.add(HttpFSFileSystem.PutOpValues.CREATE.toString());
|
UPLOAD_OPERATIONS.add(HttpFSFileSystem.Operation.CREATE.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -82,7 +81,7 @@ public class CheckUploadContentTypeFilter implements Filter {
|
||||||
if (method.equals("PUT") || method.equals("POST")) {
|
if (method.equals("PUT") || method.equals("POST")) {
|
||||||
String op = httpReq.getParameter(HttpFSFileSystem.OP_PARAM);
|
String op = httpReq.getParameter(HttpFSFileSystem.OP_PARAM);
|
||||||
if (op != null && UPLOAD_OPERATIONS.contains(op.toUpperCase())) {
|
if (op != null && UPLOAD_OPERATIONS.contains(op.toUpperCase())) {
|
||||||
if ("true".equalsIgnoreCase(httpReq.getParameter(HttpFSParams.DataParam.NAME))) {
|
if ("true".equalsIgnoreCase(httpReq.getParameter(HttpFSParametersProvider.DataParam.NAME))) {
|
||||||
String contentType = httpReq.getContentType();
|
String contentType = httpReq.getContentType();
|
||||||
contentTypeOK =
|
contentTypeOK =
|
||||||
HttpFSFileSystem.UPLOAD_CONTENT_TYPE.equalsIgnoreCase(contentType);
|
HttpFSFileSystem.UPLOAD_CONTENT_TYPE.equalsIgnoreCase(contentType);
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
|
|
||||||
package org.apache.hadoop.fs.http.server;
|
package org.apache.hadoop.fs.http.server;
|
||||||
|
|
||||||
|
import com.sun.jersey.api.container.ContainerException;
|
||||||
import org.apache.hadoop.lib.service.FileSystemAccessException;
|
import org.apache.hadoop.lib.service.FileSystemAccessException;
|
||||||
import org.apache.hadoop.lib.wsrs.ExceptionProvider;
|
import org.apache.hadoop.lib.wsrs.ExceptionProvider;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -59,6 +60,9 @@ public class HttpFSExceptionProvider extends ExceptionProvider {
|
||||||
if (throwable instanceof FileSystemAccessException) {
|
if (throwable instanceof FileSystemAccessException) {
|
||||||
throwable = throwable.getCause();
|
throwable = throwable.getCause();
|
||||||
}
|
}
|
||||||
|
if (throwable instanceof ContainerException) {
|
||||||
|
throwable = throwable.getCause();
|
||||||
|
}
|
||||||
if (throwable instanceof SecurityException) {
|
if (throwable instanceof SecurityException) {
|
||||||
status = Response.Status.UNAUTHORIZED;
|
status = Response.Status.UNAUTHORIZED;
|
||||||
} else if (throwable instanceof FileNotFoundException) {
|
} else if (throwable instanceof FileNotFoundException) {
|
||||||
|
@ -67,6 +71,8 @@ public class HttpFSExceptionProvider extends ExceptionProvider {
|
||||||
status = Response.Status.INTERNAL_SERVER_ERROR;
|
status = Response.Status.INTERNAL_SERVER_ERROR;
|
||||||
} else if (throwable instanceof UnsupportedOperationException) {
|
} else if (throwable instanceof UnsupportedOperationException) {
|
||||||
status = Response.Status.BAD_REQUEST;
|
status = Response.Status.BAD_REQUEST;
|
||||||
|
} else if (throwable instanceof IllegalArgumentException) {
|
||||||
|
status = Response.Status.BAD_REQUEST;
|
||||||
} else {
|
} else {
|
||||||
status = Response.Status.INTERNAL_SERVER_ERROR;
|
status = Response.Status.INTERNAL_SERVER_ERROR;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,398 @@
|
||||||
|
/**
|
||||||
|
* 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.fs.http.server;
|
||||||
|
|
||||||
|
import org.apache.hadoop.fs.http.client.HttpFSFileSystem;
|
||||||
|
import org.apache.hadoop.fs.http.client.HttpFSFileSystem.Operation;
|
||||||
|
import org.apache.hadoop.lib.wsrs.BooleanParam;
|
||||||
|
import org.apache.hadoop.lib.wsrs.EnumParam;
|
||||||
|
import org.apache.hadoop.lib.wsrs.LongParam;
|
||||||
|
import org.apache.hadoop.lib.wsrs.Param;
|
||||||
|
import org.apache.hadoop.lib.wsrs.ParametersProvider;
|
||||||
|
import org.apache.hadoop.lib.wsrs.ShortParam;
|
||||||
|
import org.apache.hadoop.lib.wsrs.StringParam;
|
||||||
|
import org.apache.hadoop.lib.wsrs.UserProvider;
|
||||||
|
import org.slf4j.MDC;
|
||||||
|
|
||||||
|
import javax.ws.rs.ext.Provider;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HttpFS ParametersProvider.
|
||||||
|
*/
|
||||||
|
@Provider
|
||||||
|
public class HttpFSParametersProvider extends ParametersProvider {
|
||||||
|
|
||||||
|
private static final Map<Enum, Class<Param<?>>[]> PARAMS_DEF =
|
||||||
|
new HashMap<Enum, Class<Param<?>>[]>();
|
||||||
|
|
||||||
|
static {
|
||||||
|
PARAMS_DEF.put(Operation.OPEN,
|
||||||
|
new Class[]{DoAsParam.class, OffsetParam.class, LenParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.GETFILESTATUS, new Class[]{DoAsParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.LISTSTATUS,
|
||||||
|
new Class[]{DoAsParam.class, FilterParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.GETHOMEDIRECTORY, new Class[]{DoAsParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.GETCONTENTSUMMARY, new Class[]{DoAsParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.GETFILECHECKSUM, new Class[]{DoAsParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.GETFILEBLOCKLOCATIONS,
|
||||||
|
new Class[]{DoAsParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.INSTRUMENTATION, new Class[]{DoAsParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.APPEND,
|
||||||
|
new Class[]{DoAsParam.class, DataParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.CREATE,
|
||||||
|
new Class[]{DoAsParam.class, PermissionParam.class, OverwriteParam.class,
|
||||||
|
ReplicationParam.class, BlockSizeParam.class, DataParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.MKDIRS,
|
||||||
|
new Class[]{DoAsParam.class, PermissionParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.RENAME,
|
||||||
|
new Class[]{DoAsParam.class, DestinationParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.SETOWNER,
|
||||||
|
new Class[]{DoAsParam.class, OwnerParam.class, GroupParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.SETPERMISSION,
|
||||||
|
new Class[]{DoAsParam.class, PermissionParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.SETREPLICATION,
|
||||||
|
new Class[]{DoAsParam.class, ReplicationParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.SETTIMES,
|
||||||
|
new Class[]{DoAsParam.class, ModifiedTimeParam.class,
|
||||||
|
AccessTimeParam.class});
|
||||||
|
PARAMS_DEF.put(Operation.DELETE,
|
||||||
|
new Class[]{DoAsParam.class, RecursiveParam.class});
|
||||||
|
}
|
||||||
|
|
||||||
|
public HttpFSParametersProvider() {
|
||||||
|
super(HttpFSFileSystem.OP_PARAM, HttpFSFileSystem.Operation.class,
|
||||||
|
PARAMS_DEF);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for access-time parameter.
|
||||||
|
*/
|
||||||
|
public static class AccessTimeParam extends LongParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.ACCESS_TIME_PARAM;
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public AccessTimeParam() {
|
||||||
|
super(NAME, -1l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for block-size parameter.
|
||||||
|
*/
|
||||||
|
public static class BlockSizeParam extends LongParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.BLOCKSIZE_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public BlockSizeParam() {
|
||||||
|
super(NAME, -1l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for data parameter.
|
||||||
|
*/
|
||||||
|
public static class DataParam extends BooleanParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = "data";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public DataParam() {
|
||||||
|
super(NAME, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for operation parameter.
|
||||||
|
*/
|
||||||
|
public static class OperationParam extends EnumParam<HttpFSFileSystem.Operation> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.OP_PARAM;
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public OperationParam(String operation) {
|
||||||
|
super(NAME, HttpFSFileSystem.Operation.class,
|
||||||
|
HttpFSFileSystem.Operation.valueOf(operation.toUpperCase()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for delete's recursive parameter.
|
||||||
|
*/
|
||||||
|
public static class RecursiveParam extends BooleanParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.RECURSIVE_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public RecursiveParam() {
|
||||||
|
super(NAME, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for do-as parameter.
|
||||||
|
*/
|
||||||
|
public static class DoAsParam extends StringParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.DO_AS_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public DoAsParam() {
|
||||||
|
super(NAME, null, UserProvider.USER_PATTERN);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delegates to parent and then adds do-as user to
|
||||||
|
* MDC context for logging purposes.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param str parameter value.
|
||||||
|
*
|
||||||
|
* @return parsed parameter
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String parseParam(String str) {
|
||||||
|
String doAs = super.parseParam(str);
|
||||||
|
MDC.put(getName(), (doAs != null) ? doAs : "-");
|
||||||
|
return doAs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for filter parameter.
|
||||||
|
*/
|
||||||
|
public static class FilterParam extends StringParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = "filter";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public FilterParam() {
|
||||||
|
super(NAME, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for group parameter.
|
||||||
|
*/
|
||||||
|
public static class GroupParam extends StringParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.GROUP_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public GroupParam() {
|
||||||
|
super(NAME, null, UserProvider.USER_PATTERN);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for len parameter.
|
||||||
|
*/
|
||||||
|
public static class LenParam extends LongParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = "len";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public LenParam() {
|
||||||
|
super(NAME, -1l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for modified-time parameter.
|
||||||
|
*/
|
||||||
|
public static class ModifiedTimeParam extends LongParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.MODIFICATION_TIME_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public ModifiedTimeParam() {
|
||||||
|
super(NAME, -1l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for offset parameter.
|
||||||
|
*/
|
||||||
|
public static class OffsetParam extends LongParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = "offset";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public OffsetParam() {
|
||||||
|
super(NAME, 0l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for overwrite parameter.
|
||||||
|
*/
|
||||||
|
public static class OverwriteParam extends BooleanParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.OVERWRITE_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public OverwriteParam() {
|
||||||
|
super(NAME, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for owner parameter.
|
||||||
|
*/
|
||||||
|
public static class OwnerParam extends StringParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.OWNER_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public OwnerParam() {
|
||||||
|
super(NAME, null, UserProvider.USER_PATTERN);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for permission parameter.
|
||||||
|
*/
|
||||||
|
public static class PermissionParam extends StringParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.PERMISSION_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Symbolic Unix permissions regular expression pattern.
|
||||||
|
*/
|
||||||
|
private static final Pattern PERMISSION_PATTERN =
|
||||||
|
Pattern.compile(HttpFSFileSystem.DEFAULT_PERMISSION +
|
||||||
|
"|[0-1]?[0-7][0-7][0-7]");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public PermissionParam() {
|
||||||
|
super(NAME, HttpFSFileSystem.DEFAULT_PERMISSION, PERMISSION_PATTERN);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for replication parameter.
|
||||||
|
*/
|
||||||
|
public static class ReplicationParam extends ShortParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.REPLICATION_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public ReplicationParam() {
|
||||||
|
super(NAME, (short) -1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class for to-path parameter.
|
||||||
|
*/
|
||||||
|
public static class DestinationParam extends StringParam {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameter name.
|
||||||
|
*/
|
||||||
|
public static final String NAME = HttpFSFileSystem.DESTINATION_PARAM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*/
|
||||||
|
public DestinationParam() {
|
||||||
|
super(NAME, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,551 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.fs.http.server;
|
|
||||||
|
|
||||||
import org.apache.hadoop.fs.http.client.HttpFSFileSystem;
|
|
||||||
import org.apache.hadoop.lib.wsrs.BooleanParam;
|
|
||||||
import org.apache.hadoop.lib.wsrs.EnumParam;
|
|
||||||
import org.apache.hadoop.lib.wsrs.LongParam;
|
|
||||||
import org.apache.hadoop.lib.wsrs.ShortParam;
|
|
||||||
import org.apache.hadoop.lib.wsrs.StringParam;
|
|
||||||
import org.apache.hadoop.lib.wsrs.UserProvider;
|
|
||||||
import org.slf4j.MDC;
|
|
||||||
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* HttpFS HTTP Parameters used by {@link HttpFSServer}.
|
|
||||||
*/
|
|
||||||
public class HttpFSParams {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To avoid instantiation.
|
|
||||||
*/
|
|
||||||
private HttpFSParams() {
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for access-time parameter.
|
|
||||||
*/
|
|
||||||
public static class AccessTimeParam extends LongParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.ACCESS_TIME_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "-1";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public AccessTimeParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for block-size parameter.
|
|
||||||
*/
|
|
||||||
public static class BlockSizeParam extends LongParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.BLOCKSIZE_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "-1";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public BlockSizeParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for data parameter.
|
|
||||||
*/
|
|
||||||
public static class DataParam extends BooleanParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = "data";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "false";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public DataParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for DELETE operation parameter.
|
|
||||||
*/
|
|
||||||
public static class DeleteOpParam extends EnumParam<HttpFSFileSystem.DeleteOpValues> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.OP_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public DeleteOpParam(String str) {
|
|
||||||
super(NAME, str, HttpFSFileSystem.DeleteOpValues.class);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for delete's recursive parameter.
|
|
||||||
*/
|
|
||||||
public static class DeleteRecursiveParam extends BooleanParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.RECURSIVE_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "false";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public DeleteRecursiveParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for do-as parameter.
|
|
||||||
*/
|
|
||||||
public static class DoAsParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.DO_AS_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public DoAsParam(String str) {
|
|
||||||
super(NAME, str, UserProvider.USER_PATTERN);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Delegates to parent and then adds do-as user to
|
|
||||||
* MDC context for logging purposes.
|
|
||||||
*
|
|
||||||
* @param name parameter name.
|
|
||||||
* @param str parameter value.
|
|
||||||
*
|
|
||||||
* @return parsed parameter
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String parseParam(String name, String str) {
|
|
||||||
String doAs = super.parseParam(name, str);
|
|
||||||
MDC.put(NAME, (doAs != null) ? doAs : "-");
|
|
||||||
return doAs;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for filter parameter.
|
|
||||||
*/
|
|
||||||
public static class FilterParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = "filter";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param expr parameter value.
|
|
||||||
*/
|
|
||||||
public FilterParam(String expr) {
|
|
||||||
super(NAME, expr);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for path parameter.
|
|
||||||
*/
|
|
||||||
public static class FsPathParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param path parameter value.
|
|
||||||
*/
|
|
||||||
public FsPathParam(String path) {
|
|
||||||
super("path", path);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Makes the path absolute adding '/' to it.
|
|
||||||
* <p/>
|
|
||||||
* This is required because JAX-RS resolution of paths does not add
|
|
||||||
* the root '/'.
|
|
||||||
*/
|
|
||||||
public void makeAbsolute() {
|
|
||||||
String path = value();
|
|
||||||
path = "/" + ((path != null) ? path : "");
|
|
||||||
setValue(path);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for GET operation parameter.
|
|
||||||
*/
|
|
||||||
public static class GetOpParam extends EnumParam<HttpFSFileSystem.GetOpValues> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.OP_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public GetOpParam(String str) {
|
|
||||||
super(NAME, str, HttpFSFileSystem.GetOpValues.class);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for group parameter.
|
|
||||||
*/
|
|
||||||
public static class GroupParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.GROUP_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public GroupParam(String str) {
|
|
||||||
super(NAME, str, UserProvider.USER_PATTERN);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for len parameter.
|
|
||||||
*/
|
|
||||||
public static class LenParam extends LongParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = "len";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "-1";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public LenParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for modified-time parameter.
|
|
||||||
*/
|
|
||||||
public static class ModifiedTimeParam extends LongParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.MODIFICATION_TIME_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "-1";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public ModifiedTimeParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for offset parameter.
|
|
||||||
*/
|
|
||||||
public static class OffsetParam extends LongParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = "offset";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "0";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public OffsetParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for overwrite parameter.
|
|
||||||
*/
|
|
||||||
public static class OverwriteParam extends BooleanParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.OVERWRITE_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "true";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public OverwriteParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for owner parameter.
|
|
||||||
*/
|
|
||||||
public static class OwnerParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.OWNER_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public OwnerParam(String str) {
|
|
||||||
super(NAME, str, UserProvider.USER_PATTERN);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for permission parameter.
|
|
||||||
*/
|
|
||||||
public static class PermissionParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.PERMISSION_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = HttpFSFileSystem.DEFAULT_PERMISSION;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Symbolic Unix permissions regular expression pattern.
|
|
||||||
*/
|
|
||||||
private static final Pattern PERMISSION_PATTERN =
|
|
||||||
Pattern.compile(DEFAULT + "|[0-1]?[0-7][0-7][0-7]");
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param permission parameter value.
|
|
||||||
*/
|
|
||||||
public PermissionParam(String permission) {
|
|
||||||
super(NAME, permission.toLowerCase(), PERMISSION_PATTERN);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for POST operation parameter.
|
|
||||||
*/
|
|
||||||
public static class PostOpParam extends EnumParam<HttpFSFileSystem.PostOpValues> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.OP_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public PostOpParam(String str) {
|
|
||||||
super(NAME, str, HttpFSFileSystem.PostOpValues.class);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for PUT operation parameter.
|
|
||||||
*/
|
|
||||||
public static class PutOpParam extends EnumParam<HttpFSFileSystem.PutOpValues> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.OP_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public PutOpParam(String str) {
|
|
||||||
super(NAME, str, HttpFSFileSystem.PutOpValues.class);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for replication parameter.
|
|
||||||
*/
|
|
||||||
public static class ReplicationParam extends ShortParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.REPLICATION_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "-1";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param str parameter value.
|
|
||||||
*/
|
|
||||||
public ReplicationParam(String str) {
|
|
||||||
super(NAME, str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class for to-path parameter.
|
|
||||||
*/
|
|
||||||
public static class ToPathParam extends StringParam {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parameter name.
|
|
||||||
*/
|
|
||||||
public static final String NAME = HttpFSFileSystem.DESTINATION_PARAM;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default parameter value.
|
|
||||||
*/
|
|
||||||
public static final String DEFAULT = "";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param path parameter value.
|
|
||||||
*/
|
|
||||||
public ToPathParam(String path) {
|
|
||||||
super(NAME, path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -21,26 +21,22 @@ package org.apache.hadoop.fs.http.server;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
import org.apache.hadoop.fs.http.client.HttpFSFileSystem;
|
import org.apache.hadoop.fs.http.client.HttpFSFileSystem;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.AccessTimeParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.OperationParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.BlockSizeParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.AccessTimeParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.DataParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.BlockSizeParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.DeleteOpParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.DataParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.DeleteRecursiveParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.RecursiveParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.DoAsParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.DoAsParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.FilterParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.FilterParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.FsPathParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.GroupParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.GetOpParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.LenParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.GroupParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.ModifiedTimeParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.LenParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.OffsetParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.ModifiedTimeParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.OverwriteParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.OffsetParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.OwnerParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.OverwriteParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.PermissionParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.OwnerParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.ReplicationParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.PermissionParam;
|
import org.apache.hadoop.fs.http.server.HttpFSParametersProvider.DestinationParam;
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.PostOpParam;
|
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.PutOpParam;
|
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.ReplicationParam;
|
|
||||||
import org.apache.hadoop.fs.http.server.HttpFSParams.ToPathParam;
|
|
||||||
import org.apache.hadoop.lib.service.FileSystemAccess;
|
import org.apache.hadoop.lib.service.FileSystemAccess;
|
||||||
import org.apache.hadoop.lib.service.FileSystemAccessException;
|
import org.apache.hadoop.lib.service.FileSystemAccessException;
|
||||||
import org.apache.hadoop.lib.service.Groups;
|
import org.apache.hadoop.lib.service.Groups;
|
||||||
|
@ -49,6 +45,7 @@ import org.apache.hadoop.lib.service.ProxyUser;
|
||||||
import org.apache.hadoop.lib.servlet.FileSystemReleaseFilter;
|
import org.apache.hadoop.lib.servlet.FileSystemReleaseFilter;
|
||||||
import org.apache.hadoop.lib.servlet.HostnameFilter;
|
import org.apache.hadoop.lib.servlet.HostnameFilter;
|
||||||
import org.apache.hadoop.lib.wsrs.InputStreamEntity;
|
import org.apache.hadoop.lib.wsrs.InputStreamEntity;
|
||||||
|
import org.apache.hadoop.lib.wsrs.Parameters;
|
||||||
import org.apache.hadoop.security.authentication.server.AuthenticationToken;
|
import org.apache.hadoop.security.authentication.server.AuthenticationToken;
|
||||||
import org.json.simple.JSONObject;
|
import org.json.simple.JSONObject;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -57,7 +54,6 @@ import org.slf4j.MDC;
|
||||||
|
|
||||||
import javax.ws.rs.Consumes;
|
import javax.ws.rs.Consumes;
|
||||||
import javax.ws.rs.DELETE;
|
import javax.ws.rs.DELETE;
|
||||||
import javax.ws.rs.DefaultValue;
|
|
||||||
import javax.ws.rs.GET;
|
import javax.ws.rs.GET;
|
||||||
import javax.ws.rs.POST;
|
import javax.ws.rs.POST;
|
||||||
import javax.ws.rs.PUT;
|
import javax.ws.rs.PUT;
|
||||||
|
@ -89,39 +85,6 @@ import java.util.Map;
|
||||||
public class HttpFSServer {
|
public class HttpFSServer {
|
||||||
private static Logger AUDIT_LOG = LoggerFactory.getLogger("httpfsaudit");
|
private static Logger AUDIT_LOG = LoggerFactory.getLogger("httpfsaudit");
|
||||||
|
|
||||||
/**
|
|
||||||
* Special binding for '/' as it is not handled by the wildcard binding.
|
|
||||||
*
|
|
||||||
* @param user principal making the request.
|
|
||||||
* @param op GET operation, default value is @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#OPEN}.
|
|
||||||
* @param filter Glob filter, default value is none. Used only if the
|
|
||||||
* operation is @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#LISTSTATUS}
|
|
||||||
* @param doAs user being impersonated, defualt value is none. It can be used
|
|
||||||
* only if the current user is a HttpFSServer proxyuser.
|
|
||||||
*
|
|
||||||
* @return the request response
|
|
||||||
*
|
|
||||||
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
|
||||||
* handled by {@link HttpFSExceptionProvider}.
|
|
||||||
* @throws FileSystemAccessException thrown if a FileSystemAccess releated error occurred. Thrown
|
|
||||||
* exceptions are handled by {@link HttpFSExceptionProvider}.
|
|
||||||
*/
|
|
||||||
@GET
|
|
||||||
@Path("/")
|
|
||||||
@Produces(MediaType.APPLICATION_JSON)
|
|
||||||
public Response root(@Context Principal user,
|
|
||||||
@QueryParam(GetOpParam.NAME) GetOpParam op,
|
|
||||||
@QueryParam(FilterParam.NAME) @DefaultValue(FilterParam.DEFAULT) FilterParam filter,
|
|
||||||
@QueryParam(DoAsParam.NAME) @DefaultValue(DoAsParam.DEFAULT) DoAsParam doAs)
|
|
||||||
throws IOException, FileSystemAccessException {
|
|
||||||
return get(user, new FsPathParam(""), op, new OffsetParam(OffsetParam.DEFAULT),
|
|
||||||
new LenParam(LenParam.DEFAULT), filter, doAs,
|
|
||||||
new OverwriteParam(OverwriteParam.DEFAULT),
|
|
||||||
new BlockSizeParam(BlockSizeParam.DEFAULT),
|
|
||||||
new PermissionParam(PermissionParam.DEFAULT),
|
|
||||||
new ReplicationParam(ReplicationParam.DEFAULT));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Resolves the effective user that will be used to request a FileSystemAccess filesystem.
|
* Resolves the effective user that will be used to request a FileSystemAccess filesystem.
|
||||||
* <p/>
|
* <p/>
|
||||||
|
@ -207,145 +170,261 @@ public class HttpFSServer {
|
||||||
return fs;
|
return fs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void enforceRootPath(HttpFSFileSystem.Operation op, String path) {
|
||||||
|
if (!path.equals("/")) {
|
||||||
|
throw new UnsupportedOperationException(
|
||||||
|
MessageFormat.format("Operation [{0}], invalid path [{1}], must be '/'",
|
||||||
|
op, path));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Binding to handle all GET requests, supported operations are
|
* Special binding for '/' as it is not handled by the wildcard binding.
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues}.
|
|
||||||
* <p/>
|
|
||||||
* The @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#INSTRUMENTATION} operation is available only
|
|
||||||
* to users that are in HttpFSServer's admin group (see {@link HttpFSServer}. It returns
|
|
||||||
* HttpFSServer instrumentation data. The specified path must be '/'.
|
|
||||||
*
|
*
|
||||||
* @param user principal making the request.
|
* @param user the principal of the user making the request.
|
||||||
* @param path path for the GET request.
|
* @param op the HttpFS operation of the request.
|
||||||
* @param op GET operation, default value is @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#OPEN}.
|
* @param params the HttpFS parameters of the request.
|
||||||
* @param offset of the file being fetch, used only with
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#OPEN} operations.
|
|
||||||
* @param len amounts of bytes, used only with @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#OPEN}
|
|
||||||
* operations.
|
|
||||||
* @param filter Glob filter, default value is none. Used only if the
|
|
||||||
* operation is @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.GetOpValues#LISTSTATUS}
|
|
||||||
* @param doAs user being impersonated, defualt value is none. It can be used
|
|
||||||
* only if the current user is a HttpFSServer proxyuser.
|
|
||||||
* @param override default is true. Used only for
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#CREATE} operations.
|
|
||||||
* @param blockSize block size to set, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#CREATE} operations.
|
|
||||||
* @param permission permission to set, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETPERMISSION}.
|
|
||||||
* @param replication replication factor to set, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETREPLICATION}.
|
|
||||||
*
|
*
|
||||||
* @return the request response.
|
* @return the request response.
|
||||||
*
|
*
|
||||||
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
||||||
* handled by {@link HttpFSExceptionProvider}.
|
* handled by {@link HttpFSExceptionProvider}.
|
||||||
* @throws FileSystemAccessException thrown if a FileSystemAccess releated error occurred. Thrown
|
* @throws FileSystemAccessException thrown if a FileSystemAccess releated
|
||||||
* exceptions are handled by {@link HttpFSExceptionProvider}.
|
* error occurred. Thrown exceptions are handled by
|
||||||
|
* {@link HttpFSExceptionProvider}.
|
||||||
|
*/
|
||||||
|
@GET
|
||||||
|
@Path("/")
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
public Response getRoot(@Context Principal user,
|
||||||
|
@QueryParam(OperationParam.NAME) OperationParam op,
|
||||||
|
@Context Parameters params)
|
||||||
|
throws IOException, FileSystemAccessException {
|
||||||
|
return get(user, "", op, params);
|
||||||
|
}
|
||||||
|
|
||||||
|
private String makeAbsolute(String path) {
|
||||||
|
return "/" + ((path != null) ? path : "");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Binding to handle GET requests, supported operations are
|
||||||
|
*
|
||||||
|
* @param user the principal of the user making the request.
|
||||||
|
* @param path the path for operation.
|
||||||
|
* @param op the HttpFS operation of the request.
|
||||||
|
* @param params the HttpFS parameters of the request.
|
||||||
|
*
|
||||||
|
* @return the request response.
|
||||||
|
*
|
||||||
|
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
||||||
|
* handled by {@link HttpFSExceptionProvider}.
|
||||||
|
* @throws FileSystemAccessException thrown if a FileSystemAccess releated
|
||||||
|
* error occurred. Thrown exceptions are handled by
|
||||||
|
* {@link HttpFSExceptionProvider}.
|
||||||
*/
|
*/
|
||||||
@GET
|
@GET
|
||||||
@Path("{path:.*}")
|
@Path("{path:.*}")
|
||||||
@Produces({MediaType.APPLICATION_OCTET_STREAM, MediaType.APPLICATION_JSON})
|
@Produces({MediaType.APPLICATION_OCTET_STREAM, MediaType.APPLICATION_JSON})
|
||||||
public Response get(@Context Principal user,
|
public Response get(@Context Principal user,
|
||||||
@PathParam("path") @DefaultValue("") FsPathParam path,
|
@PathParam("path") String path,
|
||||||
@QueryParam(GetOpParam.NAME) GetOpParam op,
|
@QueryParam(OperationParam.NAME) OperationParam op,
|
||||||
@QueryParam(OffsetParam.NAME) @DefaultValue(OffsetParam.DEFAULT) OffsetParam offset,
|
@Context Parameters params)
|
||||||
@QueryParam(LenParam.NAME) @DefaultValue(LenParam.DEFAULT) LenParam len,
|
|
||||||
@QueryParam(FilterParam.NAME) @DefaultValue(FilterParam.DEFAULT) FilterParam filter,
|
|
||||||
@QueryParam(DoAsParam.NAME) @DefaultValue(DoAsParam.DEFAULT) DoAsParam doAs,
|
|
||||||
|
|
||||||
//these params are only for createHandle operation acceptance purposes
|
|
||||||
@QueryParam(OverwriteParam.NAME) @DefaultValue(OverwriteParam.DEFAULT) OverwriteParam override,
|
|
||||||
@QueryParam(BlockSizeParam.NAME) @DefaultValue(BlockSizeParam.DEFAULT) BlockSizeParam blockSize,
|
|
||||||
@QueryParam(PermissionParam.NAME) @DefaultValue(PermissionParam.DEFAULT)
|
|
||||||
PermissionParam permission,
|
|
||||||
@QueryParam(ReplicationParam.NAME) @DefaultValue(ReplicationParam.DEFAULT)
|
|
||||||
ReplicationParam replication
|
|
||||||
)
|
|
||||||
throws IOException, FileSystemAccessException {
|
throws IOException, FileSystemAccessException {
|
||||||
Response response = null;
|
Response response;
|
||||||
if (op == null) {
|
path = makeAbsolute(path);
|
||||||
throw new UnsupportedOperationException(MessageFormat.format("Missing [{0}] parameter", GetOpParam.NAME));
|
|
||||||
} else {
|
|
||||||
path.makeAbsolute();
|
|
||||||
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
||||||
|
String doAs = params.get(DoAsParam.NAME, DoAsParam.class);
|
||||||
switch (op.value()) {
|
switch (op.value()) {
|
||||||
case OPEN: {
|
case OPEN: {
|
||||||
//Invoking the command directly using an unmanaged FileSystem that is released by the
|
//Invoking the command directly using an unmanaged FileSystem that is
|
||||||
//FileSystemReleaseFilter
|
// released by the FileSystemReleaseFilter
|
||||||
FSOperations.FSOpen command = new FSOperations.FSOpen(path.value());
|
FSOperations.FSOpen command = new FSOperations.FSOpen(path);
|
||||||
FileSystem fs = createFileSystem(user, doAs.value());
|
FileSystem fs = createFileSystem(user, doAs);
|
||||||
InputStream is = command.execute(fs);
|
InputStream is = command.execute(fs);
|
||||||
AUDIT_LOG.info("[{}] offset [{}] len [{}]", new Object[]{path, offset, len});
|
Long offset = params.get(OffsetParam.NAME, OffsetParam.class);
|
||||||
InputStreamEntity entity = new InputStreamEntity(is, offset.value(), len.value());
|
Long len = params.get(LenParam.NAME, LenParam.class);
|
||||||
response = Response.ok(entity).type(MediaType.APPLICATION_OCTET_STREAM).build();
|
AUDIT_LOG.info("[{}] offset [{}] len [{}]",
|
||||||
|
new Object[]{path, offset, len});
|
||||||
|
InputStreamEntity entity = new InputStreamEntity(is, offset, len);
|
||||||
|
response =
|
||||||
|
Response.ok(entity).type(MediaType.APPLICATION_OCTET_STREAM).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GETFILESTATUS: {
|
case GETFILESTATUS: {
|
||||||
FSOperations.FSFileStatus command = new FSOperations.FSFileStatus(path.value());
|
FSOperations.FSFileStatus command =
|
||||||
Map json = fsExecute(user, doAs.value(), command);
|
new FSOperations.FSFileStatus(path);
|
||||||
|
Map json = fsExecute(user, doAs, command);
|
||||||
AUDIT_LOG.info("[{}]", path);
|
AUDIT_LOG.info("[{}]", path);
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case LISTSTATUS: {
|
case LISTSTATUS: {
|
||||||
FSOperations.FSListStatus command = new FSOperations.FSListStatus(path.value(), filter.value());
|
String filter = params.get(FilterParam.NAME, FilterParam.class);
|
||||||
Map json = fsExecute(user, doAs.value(), command);
|
FSOperations.FSListStatus command = new FSOperations.FSListStatus(
|
||||||
if (filter.value() == null) {
|
path, filter);
|
||||||
AUDIT_LOG.info("[{}]", path);
|
Map json = fsExecute(user, doAs, command);
|
||||||
} else {
|
AUDIT_LOG.info("[{}] filter [{}]", path,
|
||||||
AUDIT_LOG.info("[{}] filter [{}]", path, filter.value());
|
(filter != null) ? filter : "-");
|
||||||
}
|
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GETHOMEDIRECTORY: {
|
case GETHOMEDIRECTORY: {
|
||||||
|
enforceRootPath(op.value(), path);
|
||||||
FSOperations.FSHomeDir command = new FSOperations.FSHomeDir();
|
FSOperations.FSHomeDir command = new FSOperations.FSHomeDir();
|
||||||
JSONObject json = fsExecute(user, doAs.value(), command);
|
JSONObject json = fsExecute(user, doAs, command);
|
||||||
AUDIT_LOG.info("");
|
AUDIT_LOG.info("");
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case INSTRUMENTATION: {
|
case INSTRUMENTATION: {
|
||||||
if (!path.value().equals("/")) {
|
enforceRootPath(op.value(), path);
|
||||||
throw new UnsupportedOperationException(
|
|
||||||
MessageFormat.format("Invalid path for {0}={1}, must be '/'",
|
|
||||||
GetOpParam.NAME, HttpFSFileSystem.GetOpValues.INSTRUMENTATION));
|
|
||||||
}
|
|
||||||
Groups groups = HttpFSServerWebApp.get().get(Groups.class);
|
Groups groups = HttpFSServerWebApp.get().get(Groups.class);
|
||||||
List<String> userGroups = groups.getGroups(user.getName());
|
List<String> userGroups = groups.getGroups(user.getName());
|
||||||
if (!userGroups.contains(HttpFSServerWebApp.get().getAdminGroup())) {
|
if (!userGroups.contains(HttpFSServerWebApp.get().getAdminGroup())) {
|
||||||
throw new AccessControlException("User not in HttpFSServer admin group");
|
throw new AccessControlException(
|
||||||
|
"User not in HttpFSServer admin group");
|
||||||
}
|
}
|
||||||
Instrumentation instrumentation = HttpFSServerWebApp.get().get(Instrumentation.class);
|
Instrumentation instrumentation =
|
||||||
|
HttpFSServerWebApp.get().get(Instrumentation.class);
|
||||||
Map snapshot = instrumentation.getSnapshot();
|
Map snapshot = instrumentation.getSnapshot();
|
||||||
response = Response.ok(snapshot).build();
|
response = Response.ok(snapshot).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GETCONTENTSUMMARY: {
|
case GETCONTENTSUMMARY: {
|
||||||
FSOperations.FSContentSummary command = new FSOperations.FSContentSummary(path.value());
|
FSOperations.FSContentSummary command =
|
||||||
Map json = fsExecute(user, doAs.value(), command);
|
new FSOperations.FSContentSummary(path);
|
||||||
|
Map json = fsExecute(user, doAs, command);
|
||||||
AUDIT_LOG.info("[{}]", path);
|
AUDIT_LOG.info("[{}]", path);
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GETFILECHECKSUM: {
|
case GETFILECHECKSUM: {
|
||||||
FSOperations.FSFileChecksum command = new FSOperations.FSFileChecksum(path.value());
|
FSOperations.FSFileChecksum command =
|
||||||
Map json = fsExecute(user, doAs.value(), command);
|
new FSOperations.FSFileChecksum(path);
|
||||||
|
Map json = fsExecute(user, doAs, command);
|
||||||
AUDIT_LOG.info("[{}]", path);
|
AUDIT_LOG.info("[{}]", path);
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GETDELEGATIONTOKEN: {
|
|
||||||
response = Response.status(Response.Status.BAD_REQUEST).build();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case GETFILEBLOCKLOCATIONS: {
|
case GETFILEBLOCKLOCATIONS: {
|
||||||
response = Response.status(Response.Status.BAD_REQUEST).build();
|
response = Response.status(Response.Status.BAD_REQUEST).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
default: {
|
||||||
|
throw new IOException(
|
||||||
|
MessageFormat.format("Invalid HTTP GET operation [{0}]",
|
||||||
|
op.value()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Binding to handle DELETE requests.
|
||||||
|
*
|
||||||
|
* @param user the principal of the user making the request.
|
||||||
|
* @param path the path for operation.
|
||||||
|
* @param op the HttpFS operation of the request.
|
||||||
|
* @param params the HttpFS parameters of the request.
|
||||||
|
*
|
||||||
|
* @return the request response.
|
||||||
|
*
|
||||||
|
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
||||||
|
* handled by {@link HttpFSExceptionProvider}.
|
||||||
|
* @throws FileSystemAccessException thrown if a FileSystemAccess releated
|
||||||
|
* error occurred. Thrown exceptions are handled by
|
||||||
|
* {@link HttpFSExceptionProvider}.
|
||||||
|
*/
|
||||||
|
@DELETE
|
||||||
|
@Path("{path:.*}")
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
public Response delete(@Context Principal user,
|
||||||
|
@PathParam("path") String path,
|
||||||
|
@QueryParam(OperationParam.NAME) OperationParam op,
|
||||||
|
@Context Parameters params)
|
||||||
|
throws IOException, FileSystemAccessException {
|
||||||
|
Response response;
|
||||||
|
path = makeAbsolute(path);
|
||||||
|
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
||||||
|
String doAs = params.get(DoAsParam.NAME, DoAsParam.class);
|
||||||
|
switch (op.value()) {
|
||||||
|
case DELETE: {
|
||||||
|
Boolean recursive =
|
||||||
|
params.get(RecursiveParam.NAME, RecursiveParam.class);
|
||||||
|
AUDIT_LOG.info("[{}] recursive [{}]", path, recursive);
|
||||||
|
FSOperations.FSDelete command =
|
||||||
|
new FSOperations.FSDelete(path, recursive);
|
||||||
|
JSONObject json = fsExecute(user, doAs, command);
|
||||||
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default: {
|
||||||
|
throw new IOException(
|
||||||
|
MessageFormat.format("Invalid HTTP DELETE operation [{0}]",
|
||||||
|
op.value()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Binding to handle POST requests.
|
||||||
|
*
|
||||||
|
* @param is the inputstream for the request payload.
|
||||||
|
* @param user the principal of the user making the request.
|
||||||
|
* @param uriInfo the of the request.
|
||||||
|
* @param path the path for operation.
|
||||||
|
* @param op the HttpFS operation of the request.
|
||||||
|
* @param params the HttpFS parameters of the request.
|
||||||
|
*
|
||||||
|
* @return the request response.
|
||||||
|
*
|
||||||
|
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
||||||
|
* handled by {@link HttpFSExceptionProvider}.
|
||||||
|
* @throws FileSystemAccessException thrown if a FileSystemAccess releated
|
||||||
|
* error occurred. Thrown exceptions are handled by
|
||||||
|
* {@link HttpFSExceptionProvider}.
|
||||||
|
*/
|
||||||
|
@POST
|
||||||
|
@Path("{path:.*}")
|
||||||
|
@Consumes({"*/*"})
|
||||||
|
@Produces({MediaType.APPLICATION_JSON})
|
||||||
|
public Response post(InputStream is,
|
||||||
|
@Context Principal user,
|
||||||
|
@Context UriInfo uriInfo,
|
||||||
|
@PathParam("path") String path,
|
||||||
|
@QueryParam(OperationParam.NAME) OperationParam op,
|
||||||
|
@Context Parameters params)
|
||||||
|
throws IOException, FileSystemAccessException {
|
||||||
|
Response response;
|
||||||
|
path = makeAbsolute(path);
|
||||||
|
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
||||||
|
String doAs = params.get(DoAsParam.NAME, DoAsParam.class);
|
||||||
|
switch (op.value()) {
|
||||||
|
case APPEND: {
|
||||||
|
boolean hasData = params.get(DataParam.NAME, DataParam.class);
|
||||||
|
if (!hasData) {
|
||||||
|
response = Response.temporaryRedirect(
|
||||||
|
createUploadRedirectionURL(uriInfo,
|
||||||
|
HttpFSFileSystem.Operation.APPEND)).build();
|
||||||
|
} else {
|
||||||
|
FSOperations.FSAppend command =
|
||||||
|
new FSOperations.FSAppend(is, path);
|
||||||
|
fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info("[{}]", path);
|
||||||
|
response = Response.ok().type(MediaType.APPLICATION_JSON).build();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default: {
|
||||||
|
throw new IOException(
|
||||||
|
MessageFormat.format("Invalid HTTP POST operation [{0}]",
|
||||||
|
op.value()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -358,97 +437,29 @@ public class HttpFSServer {
|
||||||
*/
|
*/
|
||||||
protected URI createUploadRedirectionURL(UriInfo uriInfo, Enum<?> uploadOperation) {
|
protected URI createUploadRedirectionURL(UriInfo uriInfo, Enum<?> uploadOperation) {
|
||||||
UriBuilder uriBuilder = uriInfo.getRequestUriBuilder();
|
UriBuilder uriBuilder = uriInfo.getRequestUriBuilder();
|
||||||
uriBuilder = uriBuilder.replaceQueryParam(PutOpParam.NAME, uploadOperation).
|
uriBuilder = uriBuilder.replaceQueryParam(OperationParam.NAME, uploadOperation).
|
||||||
queryParam(DataParam.NAME, Boolean.TRUE);
|
queryParam(DataParam.NAME, Boolean.TRUE);
|
||||||
return uriBuilder.build(null);
|
return uriBuilder.build(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Binding to handle all DELETE requests.
|
* Binding to handle PUT requests.
|
||||||
*
|
*
|
||||||
* @param user principal making the request.
|
* @param is the inputstream for the request payload.
|
||||||
* @param path path for the DELETE request.
|
* @param user the principal of the user making the request.
|
||||||
* @param op DELETE operation, default value is @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.DeleteOpValues#DELETE}.
|
* @param uriInfo the of the request.
|
||||||
* @param recursive indicates if the delete is recursive, default is <code>false</code>
|
* @param path the path for operation.
|
||||||
* @param doAs user being impersonated, defualt value is none. It can be used
|
* @param op the HttpFS operation of the request.
|
||||||
* only if the current user is a HttpFSServer proxyuser.
|
* @param params the HttpFS parameters of the request.
|
||||||
*
|
*
|
||||||
* @return the request response.
|
* @return the request response.
|
||||||
*
|
*
|
||||||
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
||||||
* handled by {@link HttpFSExceptionProvider}.
|
* handled by {@link HttpFSExceptionProvider}.
|
||||||
* @throws FileSystemAccessException thrown if a FileSystemAccess releated error occurred. Thrown
|
* @throws FileSystemAccessException thrown if a FileSystemAccess releated
|
||||||
* exceptions are handled by {@link HttpFSExceptionProvider}.
|
* error occurred. Thrown exceptions are handled by
|
||||||
*/
|
* {@link HttpFSExceptionProvider}.
|
||||||
@DELETE
|
|
||||||
@Path("{path:.*}")
|
|
||||||
@Produces(MediaType.APPLICATION_JSON)
|
|
||||||
public Response delete(@Context Principal user,
|
|
||||||
@PathParam("path") FsPathParam path,
|
|
||||||
@QueryParam(DeleteOpParam.NAME) DeleteOpParam op,
|
|
||||||
@QueryParam(DeleteRecursiveParam.NAME) @DefaultValue(DeleteRecursiveParam.DEFAULT)
|
|
||||||
DeleteRecursiveParam recursive,
|
|
||||||
@QueryParam(DoAsParam.NAME) @DefaultValue(DoAsParam.DEFAULT) DoAsParam doAs)
|
|
||||||
throws IOException, FileSystemAccessException {
|
|
||||||
Response response = null;
|
|
||||||
if (op == null) {
|
|
||||||
throw new UnsupportedOperationException(MessageFormat.format("Missing [{0}] parameter", DeleteOpParam.NAME));
|
|
||||||
}
|
|
||||||
switch (op.value()) {
|
|
||||||
case DELETE: {
|
|
||||||
path.makeAbsolute();
|
|
||||||
MDC.put(HttpFSFileSystem.OP_PARAM, "DELETE");
|
|
||||||
AUDIT_LOG.info("[{}] recursive [{}]", path, recursive);
|
|
||||||
FSOperations.FSDelete command = new FSOperations.FSDelete(path.value(), recursive.value());
|
|
||||||
JSONObject json = fsExecute(user, doAs.value(), command);
|
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Binding to handle all PUT requests, supported operations are
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues}.
|
|
||||||
*
|
|
||||||
* @param is request input stream, used only for
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PostOpValues#APPEND} operations.
|
|
||||||
* @param user principal making the request.
|
|
||||||
* @param uriInfo the request uriInfo.
|
|
||||||
* @param path path for the PUT request.
|
|
||||||
* @param op PUT operation, no default value.
|
|
||||||
* @param toPath new path, used only for
|
|
||||||
* {@link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#RENAME} operations.
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETTIMES}.
|
|
||||||
* @param owner owner to set, used only for
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETOWNER} operations.
|
|
||||||
* @param group group to set, used only for
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETOWNER} operations.
|
|
||||||
* @param override default is true. Used only for
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#CREATE} operations.
|
|
||||||
* @param blockSize block size to set, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#CREATE} operations.
|
|
||||||
* @param permission permission to set, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETPERMISSION}.
|
|
||||||
* @param replication replication factor to set, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETREPLICATION}.
|
|
||||||
* @param modifiedTime modified time, in seconds since EPOC, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETTIMES}.
|
|
||||||
* @param accessTime accessed time, in seconds since EPOC, used only by
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PutOpValues#SETTIMES}.
|
|
||||||
* @param hasData indicates if the append request is uploading data or not
|
|
||||||
* (just getting the handle).
|
|
||||||
* @param doAs user being impersonated, defualt value is none. It can be used
|
|
||||||
* only if the current user is a HttpFSServer proxyuser.
|
|
||||||
*
|
|
||||||
* @return the request response.
|
|
||||||
*
|
|
||||||
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
|
||||||
* handled by {@link HttpFSExceptionProvider}.
|
|
||||||
* @throws FileSystemAccessException thrown if a FileSystemAccess releated error occurred. Thrown
|
|
||||||
* exceptions are handled by {@link HttpFSExceptionProvider}.
|
|
||||||
*/
|
*/
|
||||||
@PUT
|
@PUT
|
||||||
@Path("{path:.*}")
|
@Path("{path:.*}")
|
||||||
|
@ -457,152 +468,107 @@ public class HttpFSServer {
|
||||||
public Response put(InputStream is,
|
public Response put(InputStream is,
|
||||||
@Context Principal user,
|
@Context Principal user,
|
||||||
@Context UriInfo uriInfo,
|
@Context UriInfo uriInfo,
|
||||||
@PathParam("path") FsPathParam path,
|
@PathParam("path") String path,
|
||||||
@QueryParam(PutOpParam.NAME) PutOpParam op,
|
@QueryParam(OperationParam.NAME) OperationParam op,
|
||||||
@QueryParam(ToPathParam.NAME) @DefaultValue(ToPathParam.DEFAULT) ToPathParam toPath,
|
@Context Parameters params)
|
||||||
@QueryParam(OwnerParam.NAME) @DefaultValue(OwnerParam.DEFAULT) OwnerParam owner,
|
|
||||||
@QueryParam(GroupParam.NAME) @DefaultValue(GroupParam.DEFAULT) GroupParam group,
|
|
||||||
@QueryParam(OverwriteParam.NAME) @DefaultValue(OverwriteParam.DEFAULT) OverwriteParam override,
|
|
||||||
@QueryParam(BlockSizeParam.NAME) @DefaultValue(BlockSizeParam.DEFAULT) BlockSizeParam blockSize,
|
|
||||||
@QueryParam(PermissionParam.NAME) @DefaultValue(PermissionParam.DEFAULT)
|
|
||||||
PermissionParam permission,
|
|
||||||
@QueryParam(ReplicationParam.NAME) @DefaultValue(ReplicationParam.DEFAULT)
|
|
||||||
ReplicationParam replication,
|
|
||||||
@QueryParam(ModifiedTimeParam.NAME) @DefaultValue(ModifiedTimeParam.DEFAULT)
|
|
||||||
ModifiedTimeParam modifiedTime,
|
|
||||||
@QueryParam(AccessTimeParam.NAME) @DefaultValue(AccessTimeParam.DEFAULT)
|
|
||||||
AccessTimeParam accessTime,
|
|
||||||
@QueryParam(DataParam.NAME) @DefaultValue(DataParam.DEFAULT) DataParam hasData,
|
|
||||||
@QueryParam(DoAsParam.NAME) @DefaultValue(DoAsParam.DEFAULT) DoAsParam doAs)
|
|
||||||
throws IOException, FileSystemAccessException {
|
throws IOException, FileSystemAccessException {
|
||||||
Response response = null;
|
Response response;
|
||||||
if (op == null) {
|
path = makeAbsolute(path);
|
||||||
throw new UnsupportedOperationException(MessageFormat.format("Missing [{0}] parameter", PutOpParam.NAME));
|
|
||||||
}
|
|
||||||
path.makeAbsolute();
|
|
||||||
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
||||||
|
String doAs = params.get(DoAsParam.NAME, DoAsParam.class);
|
||||||
switch (op.value()) {
|
switch (op.value()) {
|
||||||
case CREATE: {
|
case CREATE: {
|
||||||
if (!hasData.value()) {
|
boolean hasData = params.get(DataParam.NAME, DataParam.class);
|
||||||
|
if (!hasData) {
|
||||||
response = Response.temporaryRedirect(
|
response = Response.temporaryRedirect(
|
||||||
createUploadRedirectionURL(uriInfo, HttpFSFileSystem.PutOpValues.CREATE)).build();
|
createUploadRedirectionURL(uriInfo,
|
||||||
|
HttpFSFileSystem.Operation.CREATE)).build();
|
||||||
} else {
|
} else {
|
||||||
FSOperations.FSCreate
|
String permission = params.get(PermissionParam.NAME,
|
||||||
command = new FSOperations.FSCreate(is, path.value(), permission.value(), override.value(),
|
PermissionParam.class);
|
||||||
replication.value(), blockSize.value());
|
boolean override = params.get(OverwriteParam.NAME,
|
||||||
fsExecute(user, doAs.value(), command);
|
OverwriteParam.class);
|
||||||
AUDIT_LOG.info("[{}] permission [{}] override [{}] replication [{}] blockSize [{}]",
|
short replication = params.get(ReplicationParam.NAME,
|
||||||
|
ReplicationParam.class);
|
||||||
|
long blockSize = params.get(BlockSizeParam.NAME,
|
||||||
|
BlockSizeParam.class);
|
||||||
|
FSOperations.FSCreate command =
|
||||||
|
new FSOperations.FSCreate(is, path, permission, override,
|
||||||
|
replication, blockSize);
|
||||||
|
fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info(
|
||||||
|
"[{}] permission [{}] override [{}] replication [{}] blockSize [{}]",
|
||||||
new Object[]{path, permission, override, replication, blockSize});
|
new Object[]{path, permission, override, replication, blockSize});
|
||||||
response = Response.status(Response.Status.CREATED).build();
|
response = Response.status(Response.Status.CREATED).build();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case MKDIRS: {
|
case MKDIRS: {
|
||||||
FSOperations.FSMkdirs command = new FSOperations.FSMkdirs(path.value(), permission.value());
|
String permission = params.get(PermissionParam.NAME,
|
||||||
JSONObject json = fsExecute(user, doAs.value(), command);
|
PermissionParam.class);
|
||||||
AUDIT_LOG.info("[{}] permission [{}]", path, permission.value());
|
FSOperations.FSMkdirs command =
|
||||||
|
new FSOperations.FSMkdirs(path, permission);
|
||||||
|
JSONObject json = fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info("[{}] permission [{}]", path, permission);
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case RENAME: {
|
case RENAME: {
|
||||||
FSOperations.FSRename command = new FSOperations.FSRename(path.value(), toPath.value());
|
String toPath = params.get(DestinationParam.NAME, DestinationParam.class);
|
||||||
JSONObject json = fsExecute(user, doAs.value(), command);
|
FSOperations.FSRename command =
|
||||||
|
new FSOperations.FSRename(path, toPath);
|
||||||
|
JSONObject json = fsExecute(user, doAs, command);
|
||||||
AUDIT_LOG.info("[{}] to [{}]", path, toPath);
|
AUDIT_LOG.info("[{}] to [{}]", path, toPath);
|
||||||
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
response = Response.ok(json).type(MediaType.APPLICATION_JSON).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SETOWNER: {
|
case SETOWNER: {
|
||||||
FSOperations.FSSetOwner command = new FSOperations.FSSetOwner(path.value(), owner.value(), group.value());
|
String owner = params.get(OwnerParam.NAME, OwnerParam.class);
|
||||||
fsExecute(user, doAs.value(), command);
|
String group = params.get(GroupParam.NAME, GroupParam.class);
|
||||||
AUDIT_LOG.info("[{}] to (O/G)[{}]", path, owner.value() + ":" + group.value());
|
FSOperations.FSSetOwner command =
|
||||||
|
new FSOperations.FSSetOwner(path, owner, group);
|
||||||
|
fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info("[{}] to (O/G)[{}]", path, owner + ":" + group);
|
||||||
response = Response.ok().build();
|
response = Response.ok().build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SETPERMISSION: {
|
case SETPERMISSION: {
|
||||||
FSOperations.FSSetPermission command = new FSOperations.FSSetPermission(path.value(), permission.value());
|
String permission = params.get(PermissionParam.NAME,
|
||||||
fsExecute(user, doAs.value(), command);
|
PermissionParam.class);
|
||||||
AUDIT_LOG.info("[{}] to [{}]", path, permission.value());
|
FSOperations.FSSetPermission command =
|
||||||
|
new FSOperations.FSSetPermission(path, permission);
|
||||||
|
fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info("[{}] to [{}]", path, permission);
|
||||||
response = Response.ok().build();
|
response = Response.ok().build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SETREPLICATION: {
|
case SETREPLICATION: {
|
||||||
FSOperations.FSSetReplication command = new FSOperations.FSSetReplication(path.value(), replication.value());
|
short replication = params.get(ReplicationParam.NAME,
|
||||||
JSONObject json = fsExecute(user, doAs.value(), command);
|
ReplicationParam.class);
|
||||||
AUDIT_LOG.info("[{}] to [{}]", path, replication.value());
|
FSOperations.FSSetReplication command =
|
||||||
|
new FSOperations.FSSetReplication(path, replication);
|
||||||
|
JSONObject json = fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info("[{}] to [{}]", path, replication);
|
||||||
response = Response.ok(json).build();
|
response = Response.ok(json).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SETTIMES: {
|
case SETTIMES: {
|
||||||
FSOperations.FSSetTimes
|
long modifiedTime = params.get(ModifiedTimeParam.NAME,
|
||||||
command = new FSOperations.FSSetTimes(path.value(), modifiedTime.value(), accessTime.value());
|
ModifiedTimeParam.class);
|
||||||
fsExecute(user, doAs.value(), command);
|
long accessTime = params.get(AccessTimeParam.NAME,
|
||||||
AUDIT_LOG.info("[{}] to (M/A)[{}]", path, modifiedTime.value() + ":" + accessTime.value());
|
AccessTimeParam.class);
|
||||||
|
FSOperations.FSSetTimes command =
|
||||||
|
new FSOperations.FSSetTimes(path, modifiedTime, accessTime);
|
||||||
|
fsExecute(user, doAs, command);
|
||||||
|
AUDIT_LOG.info("[{}] to (M/A)[{}]", path,
|
||||||
|
modifiedTime + ":" + accessTime);
|
||||||
response = Response.ok().build();
|
response = Response.ok().build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case RENEWDELEGATIONTOKEN: {
|
default: {
|
||||||
response = Response.status(Response.Status.BAD_REQUEST).build();
|
throw new IOException(
|
||||||
break;
|
MessageFormat.format("Invalid HTTP PUT operation [{0}]",
|
||||||
}
|
op.value()));
|
||||||
case CANCELDELEGATIONTOKEN: {
|
|
||||||
response = Response.status(Response.Status.BAD_REQUEST).build();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Binding to handle all OPST requests, supported operations are
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PostOpValues}.
|
|
||||||
*
|
|
||||||
* @param is request input stream, used only for
|
|
||||||
* @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PostOpValues#APPEND} operations.
|
|
||||||
* @param user principal making the request.
|
|
||||||
* @param uriInfo the request uriInfo.
|
|
||||||
* @param path path for the POST request.
|
|
||||||
* @param op POST operation, default is @link org.apache.hadoop.fs.http.client.HttpFSFileSystem.PostOpValues#APPEND}.
|
|
||||||
* @param hasData indicates if the append request is uploading data or not (just getting the handle).
|
|
||||||
* @param doAs user being impersonated, defualt value is none. It can be used
|
|
||||||
* only if the current user is a HttpFSServer proxyuser.
|
|
||||||
*
|
|
||||||
* @return the request response.
|
|
||||||
*
|
|
||||||
* @throws IOException thrown if an IO error occurred. Thrown exceptions are
|
|
||||||
* handled by {@link HttpFSExceptionProvider}.
|
|
||||||
* @throws FileSystemAccessException thrown if a FileSystemAccess releated error occurred. Thrown
|
|
||||||
* exceptions are handled by {@link HttpFSExceptionProvider}.
|
|
||||||
*/
|
|
||||||
@POST
|
|
||||||
@Path("{path:.*}")
|
|
||||||
@Consumes({"*/*"})
|
|
||||||
@Produces({MediaType.APPLICATION_JSON})
|
|
||||||
public Response post(InputStream is,
|
|
||||||
@Context Principal user,
|
|
||||||
@Context UriInfo uriInfo,
|
|
||||||
@PathParam("path") FsPathParam path,
|
|
||||||
@QueryParam(PostOpParam.NAME) PostOpParam op,
|
|
||||||
@QueryParam(DataParam.NAME) @DefaultValue(DataParam.DEFAULT) DataParam hasData,
|
|
||||||
@QueryParam(DoAsParam.NAME) @DefaultValue(DoAsParam.DEFAULT) DoAsParam doAs)
|
|
||||||
throws IOException, FileSystemAccessException {
|
|
||||||
Response response = null;
|
|
||||||
if (op == null) {
|
|
||||||
throw new UnsupportedOperationException(MessageFormat.format("Missing [{0}] parameter", PostOpParam.NAME));
|
|
||||||
}
|
|
||||||
path.makeAbsolute();
|
|
||||||
MDC.put(HttpFSFileSystem.OP_PARAM, op.value().name());
|
|
||||||
switch (op.value()) {
|
|
||||||
case APPEND: {
|
|
||||||
if (!hasData.value()) {
|
|
||||||
response = Response.temporaryRedirect(
|
|
||||||
createUploadRedirectionURL(uriInfo, HttpFSFileSystem.PostOpValues.APPEND)).build();
|
|
||||||
} else {
|
|
||||||
FSOperations.FSAppend command = new FSOperations.FSAppend(is, path.value());
|
|
||||||
fsExecute(user, doAs.value(), command);
|
|
||||||
AUDIT_LOG.info("[{}]", path);
|
|
||||||
response = Response.ok().type(MediaType.APPLICATION_JSON).build();
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
|
|
|
@ -22,15 +22,14 @@ import java.text.MessageFormat;
|
||||||
|
|
||||||
public abstract class BooleanParam extends Param<Boolean> {
|
public abstract class BooleanParam extends Param<Boolean> {
|
||||||
|
|
||||||
public BooleanParam(String name, String str) {
|
public BooleanParam(String name, Boolean defaultValue) {
|
||||||
value = parseParam(name, str);
|
super(name, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Boolean parse(String str) throws Exception {
|
protected Boolean parse(String str) throws Exception {
|
||||||
if (str.equalsIgnoreCase("true")) {
|
if (str.equalsIgnoreCase("true")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
} else if (str.equalsIgnoreCase("false")) {
|
||||||
if (str.equalsIgnoreCase("false")) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
throw new IllegalArgumentException(MessageFormat.format("Invalid value [{0}], must be a boolean", str));
|
throw new IllegalArgumentException(MessageFormat.format("Invalid value [{0}], must be a boolean", str));
|
||||||
|
|
|
@ -20,8 +20,8 @@ package org.apache.hadoop.lib.wsrs;
|
||||||
|
|
||||||
public abstract class ByteParam extends Param<Byte> {
|
public abstract class ByteParam extends Param<Byte> {
|
||||||
|
|
||||||
public ByteParam(String name, String str) {
|
public ByteParam(String name, Byte defaultValue) {
|
||||||
value = parseParam(name, str);
|
super(name, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Byte parse(String str) throws Exception {
|
protected Byte parse(String str) throws Exception {
|
||||||
|
|
|
@ -25,9 +25,9 @@ import java.util.Arrays;
|
||||||
public abstract class EnumParam<E extends Enum<E>> extends Param<E> {
|
public abstract class EnumParam<E extends Enum<E>> extends Param<E> {
|
||||||
Class<E> klass;
|
Class<E> klass;
|
||||||
|
|
||||||
public EnumParam(String label, String str, Class<E> e) {
|
public EnumParam(String name, Class<E> e, E defaultValue) {
|
||||||
|
super(name, defaultValue);
|
||||||
klass = e;
|
klass = e;
|
||||||
value = parseParam(label, str);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected E parse(String str) throws Exception {
|
protected E parse(String str) throws Exception {
|
||||||
|
|
|
@ -20,8 +20,8 @@ package org.apache.hadoop.lib.wsrs;
|
||||||
|
|
||||||
public abstract class IntegerParam extends Param<Integer> {
|
public abstract class IntegerParam extends Param<Integer> {
|
||||||
|
|
||||||
public IntegerParam(String name, String str) {
|
public IntegerParam(String name, Integer defaultValue) {
|
||||||
value = parseParam(name, str);
|
super(name, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Integer parse(String str) throws Exception {
|
protected Integer parse(String str) throws Exception {
|
||||||
|
|
|
@ -20,8 +20,8 @@ package org.apache.hadoop.lib.wsrs;
|
||||||
|
|
||||||
public abstract class LongParam extends Param<Long> {
|
public abstract class LongParam extends Param<Long> {
|
||||||
|
|
||||||
public LongParam(String name, String str) {
|
public LongParam(String name, Long defaultValue) {
|
||||||
value = parseParam(name, str);
|
super(name, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Long parse(String str) throws Exception {
|
protected Long parse(String str) throws Exception {
|
||||||
|
|
|
@ -23,32 +23,39 @@ import org.apache.hadoop.lib.util.Check;
|
||||||
import java.text.MessageFormat;
|
import java.text.MessageFormat;
|
||||||
|
|
||||||
public abstract class Param<T> {
|
public abstract class Param<T> {
|
||||||
|
private String name;
|
||||||
protected T value;
|
protected T value;
|
||||||
|
|
||||||
public T parseParam(String name, String str) {
|
public Param(String name, T defaultValue) {
|
||||||
Check.notNull(name, "name");
|
this.name = name;
|
||||||
|
this.value = defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public T parseParam(String str) {
|
||||||
try {
|
try {
|
||||||
return (str != null && str.trim().length() > 0) ? parse(str) : null;
|
value = (str != null && str.trim().length() > 0) ? parse(str) : value;
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
throw new IllegalArgumentException(
|
throw new IllegalArgumentException(
|
||||||
MessageFormat.format("Parameter [{0}], invalid value [{1}], value must be [{2}]",
|
MessageFormat.format("Parameter [{0}], invalid value [{1}], value must be [{2}]",
|
||||||
name, str, getDomain()));
|
name, str, getDomain()));
|
||||||
}
|
}
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public T value() {
|
public T value() {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void setValue(T value) {
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract String getDomain();
|
protected abstract String getDomain();
|
||||||
|
|
||||||
protected abstract T parse(String str) throws Exception;
|
protected abstract T parse(String str) throws Exception;
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return value.toString();
|
return (value != null) ? value.toString() : "NULL";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,33 +15,37 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.hadoop.lib.wsrs;
|
package org.apache.hadoop.lib.wsrs;
|
||||||
|
|
||||||
import junit.framework.Assert;
|
import java.util.Map;
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class TestLongParam {
|
/**
|
||||||
|
* Class that contains all parsed JAX-RS parameters.
|
||||||
|
* <p/>
|
||||||
|
* Instances are created by the {@link ParametersProvider} class.
|
||||||
|
*/
|
||||||
|
public class Parameters {
|
||||||
|
private Map<String, Param<?>> params;
|
||||||
|
|
||||||
@Test
|
/**
|
||||||
public void param() throws Exception {
|
* Constructor that receives the request parsed parameters.
|
||||||
LongParam param = new LongParam("p", "1") {
|
*
|
||||||
};
|
* @param params the request parsed parameters.
|
||||||
Assert.assertEquals(param.getDomain(), "a long");
|
*/
|
||||||
Assert.assertEquals(param.value(), new Long(1));
|
public Parameters(Map<String, Param<?>> params) {
|
||||||
Assert.assertEquals(param.toString(), "1");
|
this.params = params;
|
||||||
param = new LongParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new LongParam("p", "") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
/**
|
||||||
public void invalid1() throws Exception {
|
* Returns the value of a request parsed parameter.
|
||||||
new LongParam("p", "x") {
|
*
|
||||||
};
|
* @param name parameter name.
|
||||||
|
* @param klass class of the parameter, used for value casting.
|
||||||
|
* @return the value of the parameter.
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
public <V, T extends Param<V>> V get(String name, Class<T> klass) {
|
||||||
|
return ((T)params.get(name)).value();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -0,0 +1,107 @@
|
||||||
|
/**
|
||||||
|
* 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.lib.wsrs;
|
||||||
|
|
||||||
|
import com.sun.jersey.api.core.HttpContext;
|
||||||
|
import com.sun.jersey.core.spi.component.ComponentContext;
|
||||||
|
import com.sun.jersey.core.spi.component.ComponentScope;
|
||||||
|
import com.sun.jersey.server.impl.inject.AbstractHttpContextInjectable;
|
||||||
|
import com.sun.jersey.spi.inject.Injectable;
|
||||||
|
import com.sun.jersey.spi.inject.InjectableProvider;
|
||||||
|
|
||||||
|
import javax.ws.rs.core.Context;
|
||||||
|
import javax.ws.rs.core.MultivaluedMap;
|
||||||
|
import java.lang.reflect.Type;
|
||||||
|
import java.text.MessageFormat;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Jersey provider that parses the request parameters based on the
|
||||||
|
* given parameter definition.
|
||||||
|
*/
|
||||||
|
public class ParametersProvider
|
||||||
|
extends AbstractHttpContextInjectable<Parameters>
|
||||||
|
implements InjectableProvider<Context, Type> {
|
||||||
|
|
||||||
|
private String driverParam;
|
||||||
|
private Class<? extends Enum> enumClass;
|
||||||
|
private Map<Enum, Class<Param<?>>[]> paramsDef;
|
||||||
|
|
||||||
|
public ParametersProvider(String driverParam, Class<? extends Enum> enumClass,
|
||||||
|
Map<Enum, Class<Param<?>>[]> paramsDef) {
|
||||||
|
this.driverParam = driverParam;
|
||||||
|
this.enumClass = enumClass;
|
||||||
|
this.paramsDef = paramsDef;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
public Parameters getValue(HttpContext httpContext) {
|
||||||
|
Map<String, Param<?>> map = new HashMap<String, Param<?>>();
|
||||||
|
MultivaluedMap<String, String> queryString =
|
||||||
|
httpContext.getRequest().getQueryParameters();
|
||||||
|
String str = queryString.getFirst(driverParam);
|
||||||
|
if (str == null) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
MessageFormat.format("Missing Operation parameter [{0}]",
|
||||||
|
driverParam));
|
||||||
|
}
|
||||||
|
Enum op;
|
||||||
|
try {
|
||||||
|
op = Enum.valueOf(enumClass, str.toUpperCase());
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
MessageFormat.format("Invalid Operation [{0}]", str));
|
||||||
|
}
|
||||||
|
if (!paramsDef.containsKey(op)) {
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
MessageFormat.format("Unsupported Operation [{0}]", op));
|
||||||
|
}
|
||||||
|
for (Class<Param<?>> paramClass : paramsDef.get(op)) {
|
||||||
|
Param<?> param;
|
||||||
|
try {
|
||||||
|
param = paramClass.newInstance();
|
||||||
|
} catch (Exception ex) {
|
||||||
|
throw new UnsupportedOperationException(
|
||||||
|
MessageFormat.format(
|
||||||
|
"Param class [{0}] does not have default constructor",
|
||||||
|
paramClass.getName()));
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
param.parseParam(queryString.getFirst(param.getName()));
|
||||||
|
}
|
||||||
|
catch (Exception ex) {
|
||||||
|
throw new IllegalArgumentException(ex.toString(), ex);
|
||||||
|
}
|
||||||
|
map.put(param.getName(), param);
|
||||||
|
}
|
||||||
|
return new Parameters(map);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ComponentScope getScope() {
|
||||||
|
return ComponentScope.PerRequest;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Injectable getInjectable(ComponentContext componentContext, Context context, Type type) {
|
||||||
|
return (type.equals(Parameters.class)) ? this : null;
|
||||||
|
}
|
||||||
|
}
|
|
@ -20,8 +20,8 @@ package org.apache.hadoop.lib.wsrs;
|
||||||
|
|
||||||
public abstract class ShortParam extends Param<Short> {
|
public abstract class ShortParam extends Param<Short> {
|
||||||
|
|
||||||
public ShortParam(String name, String str) {
|
public ShortParam(String name, Short defaultValue) {
|
||||||
value = parseParam(name, str);
|
super(name, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Short parse(String str) throws Exception {
|
protected Short parse(String str) throws Exception {
|
||||||
|
|
|
@ -15,42 +15,38 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.hadoop.lib.wsrs;
|
package org.apache.hadoop.lib.wsrs;
|
||||||
|
|
||||||
import org.apache.hadoop.lib.util.Check;
|
|
||||||
|
|
||||||
import java.text.MessageFormat;
|
import java.text.MessageFormat;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public abstract class StringParam extends Param<String> {
|
public abstract class StringParam extends Param<String> {
|
||||||
private Pattern pattern;
|
private Pattern pattern;
|
||||||
|
|
||||||
public StringParam(String name, String str) {
|
public StringParam(String name, String defaultValue) {
|
||||||
this(name, str, null);
|
this(name, defaultValue, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public StringParam(String name, String str, Pattern pattern) {
|
public StringParam(String name, String defaultValue, Pattern pattern) {
|
||||||
|
super(name, defaultValue);
|
||||||
this.pattern = pattern;
|
this.pattern = pattern;
|
||||||
value = parseParam(name, str);
|
parseParam(defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String parseParam(String name, String str) {
|
public String parseParam(String str) {
|
||||||
String ret = null;
|
|
||||||
Check.notNull(name, "name");
|
|
||||||
try {
|
try {
|
||||||
if (str != null) {
|
if (str != null) {
|
||||||
str = str.trim();
|
str = str.trim();
|
||||||
if (str.length() > 0) {
|
if (str.length() > 0) {
|
||||||
return parse(str);
|
value = parse(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
throw new IllegalArgumentException(
|
throw new IllegalArgumentException(
|
||||||
MessageFormat.format("Parameter [{0}], invalid value [{1}], value must be [{2}]",
|
MessageFormat.format("Parameter [{0}], invalid value [{1}], value must be [{2}]",
|
||||||
name, str, getDomain()));
|
getName(), str, getDomain()));
|
||||||
}
|
}
|
||||||
return ret;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String parse(String str) throws Exception {
|
protected String parse(String str) throws Exception {
|
||||||
|
|
|
@ -475,6 +475,7 @@ public class TestHttpFSFileSystem extends HFSTestCase {
|
||||||
ops[i] = new Object[]{Operation.values()[i]};
|
ops[i] = new Object[]{Operation.values()[i]};
|
||||||
}
|
}
|
||||||
return Arrays.asList(ops);
|
return Arrays.asList(ops);
|
||||||
|
// return Arrays.asList(new Object[][]{ new Object[]{Operation.CREATE}});
|
||||||
}
|
}
|
||||||
|
|
||||||
private Operation operation;
|
private Operation operation;
|
||||||
|
|
|
@ -31,34 +31,34 @@ public class TestCheckUploadContentTypeFilter {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void putUpload() throws Exception {
|
public void putUpload() throws Exception {
|
||||||
test("PUT", HttpFSFileSystem.PutOpValues.CREATE.toString(), "application/octet-stream", true, false);
|
test("PUT", HttpFSFileSystem.Operation.CREATE.toString(), "application/octet-stream", true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void postUpload() throws Exception {
|
public void postUpload() throws Exception {
|
||||||
test("POST", HttpFSFileSystem.PostOpValues.APPEND.toString(), "APPLICATION/OCTET-STREAM", true, false);
|
test("POST", HttpFSFileSystem.Operation.APPEND.toString(), "APPLICATION/OCTET-STREAM", true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void putUploadWrong() throws Exception {
|
public void putUploadWrong() throws Exception {
|
||||||
test("PUT", HttpFSFileSystem.PutOpValues.CREATE.toString(), "plain/text", false, false);
|
test("PUT", HttpFSFileSystem.Operation.CREATE.toString(), "plain/text", false, false);
|
||||||
test("PUT", HttpFSFileSystem.PutOpValues.CREATE.toString(), "plain/text", true, true);
|
test("PUT", HttpFSFileSystem.Operation.CREATE.toString(), "plain/text", true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void postUploadWrong() throws Exception {
|
public void postUploadWrong() throws Exception {
|
||||||
test("POST", HttpFSFileSystem.PostOpValues.APPEND.toString(), "plain/text", false, false);
|
test("POST", HttpFSFileSystem.Operation.APPEND.toString(), "plain/text", false, false);
|
||||||
test("POST", HttpFSFileSystem.PostOpValues.APPEND.toString(), "plain/text", true, true);
|
test("POST", HttpFSFileSystem.Operation.APPEND.toString(), "plain/text", true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getOther() throws Exception {
|
public void getOther() throws Exception {
|
||||||
test("GET", HttpFSFileSystem.GetOpValues.GETHOMEDIRECTORY.toString(), "plain/text", false, false);
|
test("GET", HttpFSFileSystem.Operation.GETHOMEDIRECTORY.toString(), "plain/text", false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void putOther() throws Exception {
|
public void putOther() throws Exception {
|
||||||
test("PUT", HttpFSFileSystem.PutOpValues.MKDIRS.toString(), "plain/text", false, false);
|
test("PUT", HttpFSFileSystem.Operation.MKDIRS.toString(), "plain/text", false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void test(String method, String operation, String contentType,
|
private void test(String method, String operation, String contentType,
|
||||||
|
@ -68,7 +68,7 @@ public class TestCheckUploadContentTypeFilter {
|
||||||
Mockito.reset(request);
|
Mockito.reset(request);
|
||||||
Mockito.when(request.getMethod()).thenReturn(method);
|
Mockito.when(request.getMethod()).thenReturn(method);
|
||||||
Mockito.when(request.getParameter(HttpFSFileSystem.OP_PARAM)).thenReturn(operation);
|
Mockito.when(request.getParameter(HttpFSFileSystem.OP_PARAM)).thenReturn(operation);
|
||||||
Mockito.when(request.getParameter(HttpFSParams.DataParam.NAME)).
|
Mockito.when(request.getParameter(HttpFSParametersProvider.DataParam.NAME)).
|
||||||
thenReturn(Boolean.toString(upload));
|
thenReturn(Boolean.toString(upload));
|
||||||
Mockito.when(request.getContentType()).thenReturn(contentType);
|
Mockito.when(request.getContentType()).thenReturn(contentType);
|
||||||
|
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.lib.wsrs;
|
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class TestBooleanParam {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void param() throws Exception {
|
|
||||||
BooleanParam param = new BooleanParam("p", "true") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "a boolean");
|
|
||||||
Assert.assertEquals(param.value(), Boolean.TRUE);
|
|
||||||
Assert.assertEquals(param.toString(), "true");
|
|
||||||
param = new BooleanParam("p", "false") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), Boolean.FALSE);
|
|
||||||
param = new BooleanParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new BooleanParam("p", "") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid() throws Exception {
|
|
||||||
new BooleanParam("p", "x") {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,53 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.lib.wsrs;
|
|
||||||
|
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class TestByteParam {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void param() throws Exception {
|
|
||||||
ByteParam param = new ByteParam("p", "1") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "a byte");
|
|
||||||
Assert.assertEquals(param.value(), new Byte((byte) 1));
|
|
||||||
Assert.assertEquals(param.toString(), "1");
|
|
||||||
param = new ByteParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new ByteParam("p", "") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid1() throws Exception {
|
|
||||||
new ByteParam("p", "x") {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid2() throws Exception {
|
|
||||||
new ByteParam("p", "256") {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,52 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.lib.wsrs;
|
|
||||||
|
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class TestEnumParam {
|
|
||||||
|
|
||||||
public static enum ENUM {
|
|
||||||
FOO, BAR
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void param() throws Exception {
|
|
||||||
EnumParam<ENUM> param = new EnumParam<ENUM>("p", "FOO", ENUM.class) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "FOO,BAR");
|
|
||||||
Assert.assertEquals(param.value(), ENUM.FOO);
|
|
||||||
Assert.assertEquals(param.toString(), "FOO");
|
|
||||||
param = new EnumParam<ENUM>("p", null, ENUM.class) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new EnumParam<ENUM>("p", "", ENUM.class) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid1() throws Exception {
|
|
||||||
new EnumParam<ENUM>("p", "x", ENUM.class) {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,52 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.lib.wsrs;
|
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class TestIntegerParam {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void param() throws Exception {
|
|
||||||
IntegerParam param = new IntegerParam("p", "1") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "an integer");
|
|
||||||
Assert.assertEquals(param.value(), new Integer(1));
|
|
||||||
Assert.assertEquals(param.toString(), "1");
|
|
||||||
param = new IntegerParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new IntegerParam("p", "") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid1() throws Exception {
|
|
||||||
new IntegerParam("p", "x") {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid2() throws Exception {
|
|
||||||
new IntegerParam("p", "" + Long.MAX_VALUE) {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,120 @@
|
||||||
|
/**
|
||||||
|
* 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.lib.wsrs;
|
||||||
|
|
||||||
|
import junit.framework.Assert;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
public class TestParam {
|
||||||
|
|
||||||
|
private <T> void test(Param<T> param, String name,
|
||||||
|
String domain, T defaultValue, T validValue,
|
||||||
|
String invalidStrValue, String outOfRangeValue) throws Exception {
|
||||||
|
|
||||||
|
Assert.assertEquals(name, param.getName());
|
||||||
|
Assert.assertEquals(domain, param.getDomain());
|
||||||
|
Assert.assertEquals(defaultValue, param.value());
|
||||||
|
Assert.assertEquals(defaultValue, param.parseParam(""));
|
||||||
|
Assert.assertEquals(defaultValue, param.parseParam(null));
|
||||||
|
Assert.assertEquals(validValue, param.parseParam(validValue.toString()));
|
||||||
|
if (invalidStrValue != null) {
|
||||||
|
try {
|
||||||
|
param.parseParam(invalidStrValue);
|
||||||
|
Assert.fail();
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
//NOP
|
||||||
|
} catch (Exception ex) {
|
||||||
|
Assert.fail();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (outOfRangeValue != null) {
|
||||||
|
try {
|
||||||
|
param.parseParam(outOfRangeValue);
|
||||||
|
Assert.fail();
|
||||||
|
} catch (IllegalArgumentException ex) {
|
||||||
|
//NOP
|
||||||
|
} catch (Exception ex) {
|
||||||
|
Assert.fail();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testBoolean() throws Exception {
|
||||||
|
Param<Boolean> param = new BooleanParam("b", false) {
|
||||||
|
};
|
||||||
|
test(param, "b", "a boolean", false, true, "x", null);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testByte() throws Exception {
|
||||||
|
Param<Byte> param = new ByteParam("B", (byte) 1) {
|
||||||
|
};
|
||||||
|
test(param, "B", "a byte", (byte) 1, (byte) 2, "x", "256");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testShort() throws Exception {
|
||||||
|
Param<Short> param = new ShortParam("S", (short) 1) {
|
||||||
|
};
|
||||||
|
test(param, "S", "a short", (short) 1, (short) 2, "x",
|
||||||
|
"" + ((int)Short.MAX_VALUE + 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testInteger() throws Exception {
|
||||||
|
Param<Integer> param = new IntegerParam("I", 1) {
|
||||||
|
};
|
||||||
|
test(param, "I", "an integer", 1, 2, "x", "" + ((long)Integer.MAX_VALUE + 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLong() throws Exception {
|
||||||
|
Param<Long> param = new LongParam("L", 1L) {
|
||||||
|
};
|
||||||
|
test(param, "L", "a long", 1L, 2L, "x", null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static enum ENUM {
|
||||||
|
FOO, BAR
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testEnum() throws Exception {
|
||||||
|
EnumParam<ENUM> param = new EnumParam<ENUM>("e", ENUM.class, ENUM.FOO) {
|
||||||
|
};
|
||||||
|
test(param, "e", "FOO,BAR", ENUM.FOO, ENUM.BAR, "x", null);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testString() throws Exception {
|
||||||
|
Param<String> param = new StringParam("s", "foo") {
|
||||||
|
};
|
||||||
|
test(param, "s", "a string", "foo", "bar", null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRegEx() throws Exception {
|
||||||
|
Param<String> param = new StringParam("r", "aa", Pattern.compile("..")) {
|
||||||
|
};
|
||||||
|
test(param, "r", "..", "aa", "bb", "c", null);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,53 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.lib.wsrs;
|
|
||||||
|
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class TestShortParam {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void param() throws Exception {
|
|
||||||
ShortParam param = new ShortParam("p", "1") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "a short");
|
|
||||||
Assert.assertEquals(param.value(), new Short((short) 1));
|
|
||||||
Assert.assertEquals(param.toString(), "1");
|
|
||||||
param = new ShortParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new ShortParam("p", "") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid1() throws Exception {
|
|
||||||
new ShortParam("p", "x") {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void invalid2() throws Exception {
|
|
||||||
new ShortParam("p", "" + Integer.MAX_VALUE) {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,64 +0,0 @@
|
||||||
/**
|
|
||||||
* 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.lib.wsrs;
|
|
||||||
|
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
public class TestStringParam {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void param() throws Exception {
|
|
||||||
StringParam param = new StringParam("p", "s") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "a string");
|
|
||||||
Assert.assertEquals(param.value(), "s");
|
|
||||||
Assert.assertEquals(param.toString(), "s");
|
|
||||||
param = new StringParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
param = new StringParam("p", "") {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
|
|
||||||
param.setValue("S");
|
|
||||||
Assert.assertEquals(param.value(), "S");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void paramRegEx() throws Exception {
|
|
||||||
StringParam param = new StringParam("p", "Aaa", Pattern.compile("A.*")) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.getDomain(), "A.*");
|
|
||||||
Assert.assertEquals(param.value(), "Aaa");
|
|
||||||
Assert.assertEquals(param.toString(), "Aaa");
|
|
||||||
param = new StringParam("p", null) {
|
|
||||||
};
|
|
||||||
Assert.assertEquals(param.value(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
|
||||||
public void paramInvalidRegEx() throws Exception {
|
|
||||||
new StringParam("p", "Baa", Pattern.compile("A.*")) {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
#
|
||||||
|
# Licensed 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.
|
||||||
|
#
|
||||||
|
#log4j.appender.test=org.apache.log4j.varia.NullAppender
|
||||||
|
#log4j.appender.test=org.apache.log4j.ConsoleAppender
|
||||||
|
log4j.appender.test=org.apache.log4j.FileAppender
|
||||||
|
log4j.appender.test.File=${test.dir}/test.log
|
||||||
|
log4j.appender.test.Append=true
|
||||||
|
log4j.appender.test.layout=org.apache.log4j.PatternLayout
|
||||||
|
log4j.appender.test.layout.ConversionPattern=%d{ISO8601} %5p %20c{1}: %4L - %m%n
|
||||||
|
log4j.rootLogger=ALL, test
|
||||||
|
|
|
@ -246,6 +246,8 @@ Branch-2 ( Unreleased changes )
|
||||||
|
|
||||||
HDFS-3535. Audit logging should log denied accesses. (Andy Isaacson via eli)
|
HDFS-3535. Audit logging should log denied accesses. (Andy Isaacson via eli)
|
||||||
|
|
||||||
|
HDFS-3481. Refactor HttpFS handling of JAX-RS query string parameters (tucu)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
HDFS-2982. Startup performance suffers when there are many edit log
|
HDFS-2982. Startup performance suffers when there are many edit log
|
||||||
|
|
Loading…
Reference in New Issue