All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.obs.services.ObsConfiguration Maven / Gradle / Ivy

/**
 * Copyright 2019 Huawei Technologies Co.,Ltd.
 * 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. */ package com.obs.services; import javax.net.ssl.HostnameVerifier; import javax.net.ssl.KeyManagerFactory; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManagerFactory; import com.obs.services.internal.ObsConstraint; import com.obs.services.internal.utils.LocalTimeUtil; import com.obs.services.model.AuthTypeEnum; import com.obs.services.model.HttpProtocolTypeEnum; import okhttp3.Dispatcher; import okhttp3.Dns; import okhttp3.EventListener; import java.security.SecureRandom; /** * Configuration parameters of ObsClient */ public class ObsConfiguration implements Cloneable { private int connectionTimeout; private int idleConnectionTime; private int maxIdleConnections; private int maxConnections; private int maxErrorRetry; private int socketTimeout; private String endPoint; private int endpointHttpPort; private int endpointHttpsPort; private boolean httpsOnly; private boolean pathStyle; private HttpProxyConfiguration httpProxy; private int uploadStreamRetryBufferSize; private boolean validateCertificate; private boolean verifyResponseContentType; private int readBufferSize; private int writeBufferSize; private KeyManagerFactory keyManagerFactory; private TrustManagerFactory trustManagerFactory; private boolean isStrictHostnameVerification; private AuthTypeEnum authType; private int localAuthTypeCacheCapacity; private SecureRandom secureRandom; private String signatString; private String defaultBucketLocation; private int bufferSize; private int socketWriteBufferSize; private int socketReadBufferSize; private boolean isNio; private boolean useReaper; private boolean keepAlive; private int connectionRequestTimeout; private boolean authTypeNegotiation; private boolean cname; private String delimiter; private String sslProvider; private HttpProtocolTypeEnum httpProtocolType; private Dispatcher httpDispatcher; private Dns customizedDnsImpl; private HostnameVerifier hostnameVerifier; private String xmlDocumentBuilderFactoryClass; private EventListener.Factory eventListenerFactory; private LocalTimeUtil localTimeUtil; private SSLContext sslContext; /** * Constructor */ public ObsConfiguration() { this.connectionTimeout = ObsConstraint.HTTP_CONNECT_TIMEOUT_VALUE; this.maxConnections = ObsConstraint.HTTP_MAX_CONNECT_VALUE; this.maxErrorRetry = ObsConstraint.HTTP_RETRY_MAX_VALUE; this.socketTimeout = ObsConstraint.HTTP_SOCKET_TIMEOUT_VALUE; this.endpointHttpPort = ObsConstraint.HTTP_PORT_VALUE; this.endpointHttpsPort = ObsConstraint.HTTPS_PORT_VALUE; this.httpsOnly = true; this.endPoint = ""; this.pathStyle = false; this.validateCertificate = false; this.verifyResponseContentType = true; this.isStrictHostnameVerification = false; this.uploadStreamRetryBufferSize = -1; this.socketWriteBufferSize = -1; this.socketReadBufferSize = -1; this.readBufferSize = -1; this.writeBufferSize = -1; this.idleConnectionTime = ObsConstraint.DEFAULT_IDLE_CONNECTION_TIME; this.maxIdleConnections = ObsConstraint.DEFAULT_MAX_IDLE_CONNECTIONS; this.authType = AuthTypeEnum.OBS; this.keepAlive = true; this.signatString = ""; this.defaultBucketLocation = ""; this.authTypeNegotiation = true; this.cname = false; this.delimiter = "/"; this.httpProtocolType = HttpProtocolTypeEnum.HTTP1_1; this.xmlDocumentBuilderFactoryClass = ObsConstraint.OBS_XML_DOC_BUILDER_FACTORY_CLASS; this.localAuthTypeCacheCapacity = ObsConstraint.DEFAULT_LOCAL_AUTH_TYPE_CACHE_CAPACITY; this.secureRandom = new SecureRandom(); this.localTimeUtil = new LocalTimeUtil(); this.sslContext = null; } public String getDelimiter() { return delimiter; } /** * Set folder isolators to slashes. * * @param delimiter * Folder isolator */ public void setDelimiter(String delimiter) { this.delimiter = delimiter; } @Deprecated public String getSignatString() { return signatString; } @Deprecated public void setSignatString(String signatString) { this.signatString = signatString; } @Deprecated public String getDefaultBucketLocation() { return defaultBucketLocation; } @Deprecated public void setDefaultBucketLocation(String defaultBucketLocation) { this.defaultBucketLocation = defaultBucketLocation; } @Deprecated public int getBufferSize() { return bufferSize; } @Deprecated public void setBufferSize(int bufferSize) { this.bufferSize = bufferSize; } /** * Check whether path-style access to OBS is enabled. "true" indicates that * path-style access is enabled while "false" (default) indicates virtual * hosted-style access is enabled. Note: If the path-style access is * enabled, new bucket features of OBS 3.0 are not supported. * * @return Whether to enable path-style access to OBS. */ public boolean isDisableDnsBucket() { return this.isPathStyle(); } /** * Specify whether to enable path-style access to OBS. "true" indicates that * path-style access is enabled while "false" (default) indicates that * virtual hosted-style access is enabled. Note: If the path-style access is * enabled, new bucket features of OBS 3.0 are not supported. * * @param disableDns * Whether to enable path-style access to OBS. */ public void setDisableDnsBucket(boolean disableDns) { this.setPathStyle(disableDns); } /** * Obtain the size (bytes) of the socket receive buffer, corresponding to * the "java.net.SocketOptions.SO_RVCBUF" parameter. The default value is * "-1", indicating that the size is not set. * * @return Socket receive buffer size */ public int getSocketReadBufferSize() { return socketReadBufferSize; } /** * Set the size (bytes) of the socket receive buffer, corresponding to the * "java.net.SocketOptions.SO_RVCBUF" parameter. The default value is "-1", * indicating that the size is not set. * * @param socketReadBufferSize * Socket receive buffer size */ public void setSocketReadBufferSize(int socketReadBufferSize) { this.socketReadBufferSize = socketReadBufferSize; } /** * Obtain the size (bytes) of the socket send buffer, corresponding to the * "java.net.SocketOptions.SO_SNDBUF" parameter. The default value is "-1", * indicating that the size is not set. * * @return socketSocket send buffer size */ public int getSocketWriteBufferSize() { return socketWriteBufferSize; } /** * Set the size (bytes) of the socket send buffer (in bytes), corresponding * to the "java.net.SocketOptions.SO_SNDBUF" parameter. The default value is * "-1", indicating that the size is not set. * * @param socketWriteBufferSize * socket Socket send buffer size */ public void setSocketWriteBufferSize(int socketWriteBufferSize) { this.socketWriteBufferSize = socketWriteBufferSize; } @Deprecated public int getConnectionRequestTimeout() { return connectionRequestTimeout; } @Deprecated public void setConnectionRequestTimeout(int connectionRequestTimeout) { this.connectionRequestTimeout = connectionRequestTimeout; } @Deprecated public void disableNio() { this.isNio = false; } @Deprecated public void enableNio() { this.isNio = true; } @Deprecated public boolean isNio() { return this.isNio; } @Deprecated public boolean isUseReaper() { return useReaper; } @Deprecated public void setUseReaper(boolean useReaper) { this.useReaper = useReaper; } /** * Obtain the factory for generating the "KeyManager" array. * * @return Factory for generating the "KeyManager" array */ public KeyManagerFactory getKeyManagerFactory() { return keyManagerFactory; } /** * Set the factory for generating the "KeyManager" array. * * @param keyManagerFactory * Factory for generating the "KeyManager" array */ public void setKeyManagerFactory(KeyManagerFactory keyManagerFactory) { this.keyManagerFactory = keyManagerFactory; } /** * Obtain the factory for generating the "TrustManager" array. * * @return Factory for generating the "TrustManager" array */ public TrustManagerFactory getTrustManagerFactory() { return trustManagerFactory; } /** * Set the factory for generating the "TrustManager" array. * * @param trustManagerFactory * Factory for generating the "TrustManager" array */ public void setTrustManagerFactory(TrustManagerFactory trustManagerFactory) { this.trustManagerFactory = trustManagerFactory; } /** * Obtain the identifier specifying whether to verify the domain name * ("false" by default). * * @return Identifier specifying whether to verify the domain name */ public boolean isStrictHostnameVerification() { return isStrictHostnameVerification; } /** * Set the identifier specifying whether to verify the domain name. * * @param isStrictHostnameVerification * Identifier specifying whether to verify the domain name */ public void setIsStrictHostnameVerification(boolean isStrictHostnameVerification) { this.isStrictHostnameVerification = isStrictHostnameVerification; } /** * Check whether path-style access to OBS is enabled. "true" indicates that * path-style access is enabled while "false" (default) indicates virtual * hosted-style access is enabled. Note: If the path-style access is * enabled, new bucket features of OBS 3.0 are not supported. * * @return Whether to enable path-style access to OBS. */ public boolean isPathStyle() { return pathStyle; } /** * Specify whether to enable path-style access to OBS. "true" indicates that * path-style access is enabled while "false" (default) indicates that * virtual hosted-style access is enabled. Note: If the path-style access is * enabled, new bucket features of OBS 3.0 are not supported. * * @param pathStyle * Whether to enable path-style access to OBS. */ public void setPathStyle(boolean pathStyle) { this.pathStyle = pathStyle; } /** * Obtain the timeout interval for establishing HTTP/HTTPS connections (in * milliseconds, 60,000 milliseconds by default). * * @return Timeout interval for establishing HTTP/HTTPS connections */ public int getConnectionTimeout() { return connectionTimeout; } /** * Set the timeout interval for establishing HTTP/HTTPS connections (in * milliseconds, 60,000 milliseconds by default). * * @param connectionTimeout * Timeout interval for establishing HTTP/HTTPS connections */ public void setConnectionTimeout(int connectionTimeout) { this.connectionTimeout = connectionTimeout; } /** * Obtain the maximum number of HTTP connections (1000 by default) that can * be opened. * * @return Maximum number of concurrently opened HTTP connections */ public int getMaxConnections() { return maxConnections; } /** * Set the maximum number of HTTP connections (1000 by default) that can be * opened. * * @param maxConnections * Maximum number of concurrently opened HTTP connections */ public void setMaxConnections(int maxConnections) { this.maxConnections = maxConnections; } /** * Obtain the maximum number of retry attempts (5 by default) upon a request * failure (request exception, or error 500 or 503 on the server). * * @return Maximum number of retry attempts upon a request failure */ public int getMaxErrorRetry() { return maxErrorRetry; } /** * Set the maximum number of retry attempts (5 by default) upon a request * failure (request exception, or error 500 or 503 on the server). * * @param maxErrorRetry * Maximum number of retry attempts upon a request failure */ public void setMaxErrorRetry(int maxErrorRetry) { this.maxErrorRetry = maxErrorRetry; } /** * Obtain the timeout interval for data transmission at the socket layer (in * milliseconds, 60,000 milliseconds by default). * * @return Timeout interval for data transmission at the socket layer */ public int getSocketTimeout() { return socketTimeout; } /** * Set the timeout interval for data transmission at the socket layer (in * milliseconds, 60,000 milliseconds by default). * * @param socketTimeout * Timeout interval for data transmission at the socket layer */ public void setSocketTimeout(int socketTimeout) { this.socketTimeout = socketTimeout; } /** * Obtain the endpoint for accessing OBS. * * @return OBS endpoint */ public String getEndPoint() { if (endPoint == null || endPoint.trim().equals("")) { throw new IllegalArgumentException("EndPoint is not set"); } return endPoint.trim(); } /** * Set the endpoint for accessing OBS. * * @param endPoint * OBS endpoint */ public void setEndPoint(String endPoint) { this.endPoint = endPoint; } /** * Obtain the port number of the HTTP request (80 by default). * * @return Port number of the HTTP request */ public int getEndpointHttpPort() { return endpointHttpPort; } /** * Set the port number of the HTTP request (80 by default). * * @param endpointHttpPort * Port number of the HTTP request */ public void setEndpointHttpPort(int endpointHttpPort) { this.endpointHttpPort = endpointHttpPort; } /** * Obtain the port number of the HTTPS request (443 by default). * * @return Port number of the HTTPS request */ public int getEndpointHttpsPort() { return endpointHttpsPort; } /** * Set the port number of the HTTPS request (443 by default). * * @param endpointHttpsPort * Port number of the HTTPS request */ public void setEndpointHttpsPort(int endpointHttpsPort) { this.endpointHttpsPort = endpointHttpsPort; } /** * Specify whether to use HTTPS to connect OBS ("true" by default). * * @param httpsOnly * Identifier specifying whether to use HTTPS to connect OBS */ public void setHttpsOnly(boolean httpsOnly) { this.httpsOnly = httpsOnly; } /** * Check whether HTTPS is used to connect OBS ("true" by default). * * @return Identifier specifying whether to use HTTPS to connect OBS */ public boolean isHttpsOnly() { return httpsOnly; } @Override public ObsConfiguration clone() throws CloneNotSupportedException { return (ObsConfiguration) super.clone(); } /** * Obtain the proxy configuration. * * @return Proxy configuration */ public HttpProxyConfiguration getHttpProxy() { return httpProxy; } /** * Configure the proxy. * * @param httpProxy * HTTP proxy configuration */ public void setHttpProxy(HttpProxyConfiguration httpProxy) { this.httpProxy = httpProxy; } /** * Configure the proxy server. * * @param proxyAddr * Proxy server address * @param proxyPort * Proxy server port * @param userName * Proxy username * @param password * Proxy password * @param domain * Proxy domain */ @Deprecated public void setHttpProxy(String proxyAddr, int proxyPort, String userName, String password, String domain) { this.httpProxy = new HttpProxyConfiguration(proxyAddr, proxyPort, userName, password, domain); } /** * Configure the proxy server. * * @param proxyAddr * Proxy server address * @param proxyPort * Proxy server port * @param userName * Proxy username * @param password * Proxy password */ public void setHttpProxy(String proxyAddr, int proxyPort, String userName, String password) { this.httpProxy = new HttpProxyConfiguration(proxyAddr, proxyPort, userName, password, null); } /** * Set the buffer size used for uploading stream objects (in bytes). The * default value is 512 KB. * * @param uploadStreamRetryBufferSize * Buffer size used for uploading stream objects */ @Deprecated public void setUploadStreamRetryBufferSize(int uploadStreamRetryBufferSize) { this.uploadStreamRetryBufferSize = uploadStreamRetryBufferSize; } /** * Obtain the buffer size used for uploading stream objects (in bytes). The * default value is 512 KB. * * @return Buffer size used for uploading stream objects */ @Deprecated public int getUploadStreamRetryBufferSize() { return this.uploadStreamRetryBufferSize; } /** * Check whether server-side verification is enabled. The default value is * "false". * * @return Identifier specifying whether to enable server-side verification */ public boolean isValidateCertificate() { return validateCertificate; } /** * Specify whether to enable server-side certificate verification. The * default value is "false". ** * @param validateCertificate * Identifier specifying whether to enable server-side * verification */ public void setValidateCertificate(boolean validateCertificate) { this.validateCertificate = validateCertificate; } /** * Check whether "ContentType" in the response is verified. The default * value is "true". * * @return Identifier specifying whether to verify "ContentType" in the * response */ public boolean isVerifyResponseContentType() { return verifyResponseContentType; } /** * Specify whether to verify "ContentType" in the response. The default * value is "true". * * @param verifyResponseContentType * Identifier specifying whether to verify "ContentType" in the * response */ public void setVerifyResponseContentType(boolean verifyResponseContentType) { this.verifyResponseContentType = verifyResponseContentType; } /** * Obtain the read cache size used for uploading objects to socket streams * (in bytes). The default value is 8192. * * @return Read cache size used for uploading objects to socket streams */ public int getReadBufferSize() { return readBufferSize; } /** * Set the read cache size used for uploading objects to socket streams (in * bytes). The default value is 8192. * * @param readBufferSize * Read cache size used for uploading objects to socket streams */ public void setReadBufferSize(int readBufferSize) { this.readBufferSize = readBufferSize; } /** * Obtain the write cache size used for uploading objects to socket streams * (in bytes). The default value is 8192. * * @return Write cache size used for uploading objects to socket streams */ public int getWriteBufferSize() { return writeBufferSize; } /** * Set the write cache size used for uploading objects to socket streams (in * bytes). The default value is 8192. * * @param writeBufferSize * Write cache size used for uploading objects to socket streams */ public void setWriteBufferSize(int writeBufferSize) { this.writeBufferSize = writeBufferSize; } /** * Obtain the idle time for obtaining connections from the connection pool. * The unit is millisecond and the default value is 30000. * * @return Maximum idle time for obtaining connections from the connection * pool */ public int getIdleConnectionTime() { return idleConnectionTime; } /** * Set the idle time for obtaining connections from the connection pool. The * unit is millisecond and the default value is 30000. * * @param idleConnectionTime * Maximum idle time for obtaining connections from the * connection pool */ public void setIdleConnectionTime(int idleConnectionTime) { this.idleConnectionTime = idleConnectionTime; } /** * Obtain the maximum number of idle connections in the connection pool. The * default value is 1000. * * @return Maximum number of idle connections in the connection pool */ public int getMaxIdleConnections() { return maxIdleConnections; } /** * Set the maximum number of idle connections in the connection pool. The * default value is 1000. * * @param maxIdleConnections * Maximum number of idle connections in the connection pool */ public void setMaxIdleConnections(int maxIdleConnections) { this.maxIdleConnections = maxIdleConnections; } /** * Obtain the authentication type. * * @return Authentication type */ public AuthTypeEnum getAuthType() { return authType; } /** * Set the authentication type. * * @param authType * Authentication type */ public void setAuthType(AuthTypeEnum authType) { this.authType = authType; } /** * Specify whether to use persistent connections. * * @return Identifier specifying whether to use the persistent connections */ public boolean isKeepAlive() { return keepAlive; } /** * Check whether persistent connections are used. * * @param keepAlive * Identifier specifying whether to use the persistent * connections */ public void setKeepAlive(boolean keepAlive) { this.keepAlive = keepAlive; } /** * Check whether protocol negotiation is used. * * @return Identifier specifying whether to use protocol negotiation */ public boolean isAuthTypeNegotiation() { return authTypeNegotiation; } /** * Specify whether to use protocol negotiation. * * @param authTypeNegotiation * Identifier specifying whether to use protocol negotiation */ public void setAuthTypeNegotiation(boolean authTypeNegotiation) { this.authTypeNegotiation = authTypeNegotiation; } /** * Check whether user-defined domain name is used. * * @return Identifier specifying whether to use user-defined domain name */ public boolean isCname() { return cname; } /** * Specify whether to use user-defined domain name. * * @param cname * Identifier specifying whether to use user-defined domain name */ public void setCname(boolean cname) { this.cname = cname; } /** * Set the provider of SSLContext. * * @return SSLContext provider */ public String getSslProvider() { return sslProvider; } /** * Obtain the provider of SSLContext. * * @param sslProvider * SSLContext provider */ public void setSslProvider(String sslProvider) { this.sslProvider = sslProvider; } /** * Set the HTTP type used for accessing OBS servers. * * @return HTTP type */ public HttpProtocolTypeEnum getHttpProtocolType() { return httpProtocolType; } /** * Obtain the HTTP type used for accessing OBS servers. * * @param httpProtocolType * HTTP type */ public void setHttpProtocolType(HttpProtocolTypeEnum httpProtocolType) { this.httpProtocolType = httpProtocolType; } /** * Set the customized dispatcher. * * @return Customized dispatcher */ public Dispatcher getHttpDispatcher() { return httpDispatcher; } /** * Obtain the customized dispatcher. * * @param httpDispatcher * Customized dispatcher */ public void setHttpDispatcher(Dispatcher httpDispatcher) { this.httpDispatcher = httpDispatcher; } /** * Obtain the customized Dns. * * @return customizedDnsImpl * */ public Dns getCustomizedDnsImpl() { return customizedDnsImpl; } /** * set the customized Dns. * * @param customizedDnsImpl * Customized Dns */ public void setCustomizedDnsImpl(Dns customizedDnsImpl) { this.customizedDnsImpl = customizedDnsImpl; } public HostnameVerifier getHostnameVerifier() { return hostnameVerifier; } public void setHostnameVerifier(HostnameVerifier hostnameVerifier) { this.hostnameVerifier = hostnameVerifier; } public String getXmlDocumentBuilderFactoryClass() { return xmlDocumentBuilderFactoryClass; } public void setXmlDocumentBuilderFactoryClass(String xmlDocumentBuilderFactoryClass) { this.xmlDocumentBuilderFactoryClass = xmlDocumentBuilderFactoryClass; } public int getLocalAuthTypeCacheCapacity() { return localAuthTypeCacheCapacity; } public void setLocalAuthTypeCacheCapacity(int localAuthTypeCacheCapacity) { this.localAuthTypeCacheCapacity = localAuthTypeCacheCapacity; } public SecureRandom getSecureRandom() { return secureRandom; } public void setSecureRandom(SecureRandom secureRandom) { this.secureRandom = secureRandom; } public EventListener.Factory getEventListenerFactory() { return eventListenerFactory; } public void setEventListenerFactory(EventListener.Factory eventListenerFactory) { this.eventListenerFactory = eventListenerFactory; } public LocalTimeUtil getLocalTimeUtil() { return localTimeUtil; } public void setLocalTimeUtil(LocalTimeUtil localTimeUtil) { this.localTimeUtil = localTimeUtil; } public SSLContext getSslContext() { return sslContext; } public void setSslContext(SSLContext sslContext) { this.sslContext = sslContext; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy