001 /**
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements. See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership. The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License. You may obtain a copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software
013 * distributed under the License is distributed on an "AS IS" BASIS,
014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015 * See the License for the specific language governing permissions and
016 * limitations under the License.
017 */
018 package org.apache.hadoop.hdfs.web.resources;
019
020 import java.net.HttpURLConnection;
021
022 /** Http GET operation parameter. */
023 public class GetOpParam extends HttpOpParam<GetOpParam.Op> {
024 /** Get operations. */
025 public static enum Op implements HttpOpParam.Op {
026 OPEN(true, HttpURLConnection.HTTP_OK),
027
028 GETFILESTATUS(false, HttpURLConnection.HTTP_OK),
029 LISTSTATUS(false, HttpURLConnection.HTTP_OK),
030 GETCONTENTSUMMARY(false, HttpURLConnection.HTTP_OK),
031 GETFILECHECKSUM(true, HttpURLConnection.HTTP_OK),
032
033 GETHOMEDIRECTORY(false, HttpURLConnection.HTTP_OK),
034 GETDELEGATIONTOKEN(false, HttpURLConnection.HTTP_OK, true),
035
036 /** GET_BLOCK_LOCATIONS is a private unstable op. */
037 GET_BLOCK_LOCATIONS(false, HttpURLConnection.HTTP_OK),
038 GETACLSTATUS(false, HttpURLConnection.HTTP_OK),
039 GETXATTRS(false, HttpURLConnection.HTTP_OK),
040 LISTXATTRS(false, HttpURLConnection.HTTP_OK),
041
042 NULL(false, HttpURLConnection.HTTP_NOT_IMPLEMENTED),
043
044 CHECKACCESS(false, HttpURLConnection.HTTP_OK);
045
046 final boolean redirect;
047 final int expectedHttpResponseCode;
048 final boolean requireAuth;
049
050 Op(final boolean redirect, final int expectedHttpResponseCode) {
051 this(redirect, expectedHttpResponseCode, false);
052 }
053
054 Op(final boolean redirect, final int expectedHttpResponseCode,
055 final boolean requireAuth) {
056 this.redirect = redirect;
057 this.expectedHttpResponseCode = expectedHttpResponseCode;
058 this.requireAuth = requireAuth;
059 }
060
061 @Override
062 public HttpOpParam.Type getType() {
063 return HttpOpParam.Type.GET;
064 }
065
066 @Override
067 public boolean getRequireAuth() {
068 return requireAuth;
069 }
070
071 @Override
072 public boolean getDoOutput() {
073 return false;
074 }
075
076 @Override
077 public boolean getRedirect() {
078 return redirect;
079 }
080
081 @Override
082 public int getExpectedHttpResponseCode() {
083 return expectedHttpResponseCode;
084 }
085
086 @Override
087 public String toQueryString() {
088 return NAME + "=" + this;
089 }
090 }
091
092 private static final Domain<Op> DOMAIN = new Domain<Op>(NAME, Op.class);
093
094 /**
095 * Constructor.
096 * @param str a string representation of the parameter value.
097 */
098 public GetOpParam(final String str) {
099 super(DOMAIN, DOMAIN.parse(str));
100 }
101
102 @Override
103 public String getName() {
104 return NAME;
105 }
106 }