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 */ 018package org.apache.hadoop.hbase.rest; 019 020import org.apache.yetus.audience.InterfaceAudience; 021 022/** 023 * Common constants for org.apache.hadoop.hbase.rest 024 */ 025@InterfaceAudience.Public 026public interface Constants { 027 // All constants in a public interface are 'public static final' 028 029 String VERSION_STRING = "0.0.3"; 030 031 int DEFAULT_MAX_AGE = 60 * 60 * 4; // 4 hours 032 033 int DEFAULT_LISTEN_PORT = 8080; 034 035 String MIMETYPE_TEXT = "text/plain"; 036 String MIMETYPE_HTML = "text/html"; 037 String MIMETYPE_XML = "text/xml"; 038 String MIMETYPE_BINARY = "application/octet-stream"; 039 String MIMETYPE_PROTOBUF = "application/x-protobuf"; 040 String MIMETYPE_PROTOBUF_IETF = "application/protobuf"; 041 String MIMETYPE_JSON = "application/json"; 042 043 String CRLF = "\r\n"; 044 045 String REST_KEYTAB_FILE = "hbase.rest.keytab.file"; 046 String REST_KERBEROS_PRINCIPAL = "hbase.rest.kerberos.principal"; 047 String REST_AUTHENTICATION_TYPE = "hbase.rest.authentication.type"; 048 String REST_AUTHENTICATION_PRINCIPAL = "hbase.rest.authentication.kerberos.principal"; 049 050 String REST_SSL_ENABLED = "hbase.rest.ssl.enabled"; 051 String REST_SSL_KEYSTORE_STORE = "hbase.rest.ssl.keystore.store"; 052 String REST_SSL_KEYSTORE_PASSWORD = "hbase.rest.ssl.keystore.password"; 053 String REST_SSL_KEYSTORE_TYPE = "hbase.rest.ssl.keystore.type"; 054 String REST_SSL_TRUSTSTORE_STORE = "hbase.rest.ssl.truststore.store"; 055 String REST_SSL_TRUSTSTORE_PASSWORD = "hbase.rest.ssl.truststore.password"; 056 String REST_SSL_TRUSTSTORE_TYPE = "hbase.rest.ssl.truststore.type"; 057 String REST_SSL_KEYSTORE_KEYPASSWORD = "hbase.rest.ssl.keystore.keypassword"; 058 String REST_SSL_EXCLUDE_CIPHER_SUITES = "hbase.rest.ssl.exclude.cipher.suites"; 059 String REST_SSL_INCLUDE_CIPHER_SUITES = "hbase.rest.ssl.include.cipher.suites"; 060 String REST_SSL_EXCLUDE_PROTOCOLS = "hbase.rest.ssl.exclude.protocols"; 061 String REST_SSL_INCLUDE_PROTOCOLS = "hbase.rest.ssl.include.protocols"; 062 063 String REST_THREAD_POOL_THREADS_MAX = "hbase.rest.threads.max"; 064 String REST_THREAD_POOL_THREADS_MIN = "hbase.rest.threads.min"; 065 String REST_THREAD_POOL_TASK_QUEUE_SIZE = "hbase.rest.task.queue.size"; 066 String REST_THREAD_POOL_THREAD_IDLE_TIMEOUT = "hbase.rest.thread.idle.timeout"; 067 String REST_CONNECTOR_ACCEPT_QUEUE_SIZE = "hbase.rest.connector.accept.queue.size"; 068 069 String REST_DNS_NAMESERVER = "hbase.rest.dns.nameserver"; 070 String REST_DNS_INTERFACE = "hbase.rest.dns.interface"; 071 072 String REST_SCANNERCACHE_SIZE = "hbase.rest.scannercache.size"; 073 final int DEFAULT_REST_SCANNERCACHE_SIZE = 10000; 074 075 String REST_SCANNERCACHE_EXPIRE_TIME = "hbase.rest.scannercache.expire.time"; 076 final long DEFAULT_REST_SCANNERCACHE_EXPIRE_TIME_MS = 60 * 60 * 1000; 077 078 String FILTER_CLASSES = "hbase.rest.filter.classes"; 079 String SCAN_START_ROW = "startrow"; 080 String SCAN_END_ROW = "endrow"; 081 String SCAN_COLUMN = "column"; 082 String SCAN_START_TIME = "starttime"; 083 String SCAN_END_TIME = "endtime"; 084 String SCAN_MAX_VERSIONS = "maxversions"; 085 String SCAN_BATCH_SIZE = "batchsize"; 086 String SCAN_LIMIT = "limit"; 087 String SCAN_FETCH_SIZE = "hbase.rest.scan.fetchsize"; 088 String FILTER = "filter"; 089 /** 090 * @deprecated Since 2.4.18/2.5.9/2.6.0, will be removed in 4.0.0. Please use {@link #FILTER} 091 * instead. 092 */ 093 @Deprecated 094 String SCAN_FILTER = FILTER; 095 String FILTER_B64 = "filter_b64"; 096 String SCAN_REVERSED = "reversed"; 097 String SCAN_CACHE_BLOCKS = "cacheblocks"; 098 String CUSTOM_FILTERS = "hbase.rest.custom.filters"; 099 100 String ROW_KEYS_PARAM_NAME = "row"; 101 String KEY_ENCODING_QUERY_PARAM_NAME = "e"; 102 /** 103 * If this query parameter is present when processing row or scanner resources, it disables server 104 * side block caching 105 */ 106 String NOCACHE_PARAM_NAME = "nocache"; 107 108 /** Configuration parameter to set rest client connection timeout */ 109 String REST_CLIENT_CONN_TIMEOUT = "hbase.rest.client.conn.timeout"; 110 int DEFAULT_REST_CLIENT_CONN_TIMEOUT = 2 * 1000; 111 112 /** Configuration parameter to set rest client socket timeout */ 113 String REST_CLIENT_SOCKET_TIMEOUT = "hbase.rest.client.socket.timeout"; 114 int DEFAULT_REST_CLIENT_SOCKET_TIMEOUT = 30 * 1000; 115 116 String SCAN_INCLUDE_START_ROW = "includeStartRow"; 117 String SCAN_INCLUDE_STOP_ROW = "includeStopRow"; 118}