
org.apache.pulsar.websocket.service.WebSocketProxyConfiguration Maven / Gradle / Ivy
/*
* 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.pulsar.websocket.service;
import java.util.Optional;
import java.util.Properties;
import java.util.Set;
import java.util.TreeSet;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import org.apache.pulsar.broker.authorization.PulsarAuthorizationProvider;
import org.apache.pulsar.common.configuration.FieldContext;
import org.apache.pulsar.common.configuration.PulsarConfiguration;
@Getter
@Setter
public class WebSocketProxyConfiguration implements PulsarConfiguration {
@FieldContext(required = true, doc = "Name of the cluster to which this broker belongs to")
private String clusterName;
@FieldContext(doc = "The HTTPS REST service URL to connect to broker")
private String serviceUrl;
@FieldContext(doc = "The HTTPS REST service TLS URL")
private String serviceUrlTls;
@FieldContext(doc = "The broker binary service URL (for produce and consume operations)")
private String brokerServiceUrl;
@FieldContext(doc = "The secured broker binary service URL (for produce and consume operations)")
private String brokerServiceUrlTls;
@FieldContext(doc = "Path for the file used to determine the rotation status for the broker "
+ "when responding to service discovery health checks")
private String statusFilePath;
@Deprecated
@FieldContext(
doc = "Configuration Store connection string",
deprecated = true
)
private String globalZookeeperServers;
@Deprecated
@FieldContext(
deprecated = true,
doc = "Configuration store connection string (as a comma-separated list). Deprecated in favor of "
+ "`configurationMetadataStoreUrl`"
)
private String configurationStoreServers;
@FieldContext(doc = "Connection string of configuration metadata store servers")
private String configurationMetadataStoreUrl;
@FieldContext(doc = "Metadata store session timeout in milliseconds.")
private long metadataStoreSessionTimeoutMillis = 30_000;
@FieldContext(doc = "Metadata store cache expiry time in seconds.")
private int metadataStoreCacheExpirySeconds = 300;
@FieldContext(
deprecated = true,
doc = "ZooKeeper session timeout in milliseconds. "
+ "@deprecated - Use metadataStoreSessionTimeoutMillis instead.")
private long zooKeeperSessionTimeoutMillis = -1;
@FieldContext(
deprecated = true,
doc = "ZooKeeper cache expiry time in seconds. "
+ "@deprecated - Use metadataStoreCacheExpirySeconds instead.")
private int zooKeeperCacheExpirySeconds = -1;
@FieldContext(doc = "Port to use to server HTTP request")
private Optional webServicePort = Optional.of(8080);
@FieldContext(doc = "Port to use to server HTTPS request")
private Optional webServicePortTls = Optional.empty();
@FieldContext(doc = "Hostname or IP address the service binds on, default is 0.0.0.0.")
private String bindAddress = "0.0.0.0";
@FieldContext(doc = "Enable or disable the use of HA proxy protocol for resolving the client IP for http/https "
+ "requests. Default is false.")
private boolean webServiceHaProxyProtocolEnabled = false;
@FieldContext(doc = "Trust X-Forwarded-For header for resolving the client IP for http/https requests.\n"
+ "Default is false.")
private boolean webServiceTrustXForwardedFor = false;
@FieldContext(doc =
"Add detailed client/remote and server/local addresses and ports to http/https request logging.\n"
+ "Defaults to true when either webServiceHaProxyProtocolEnabled or webServiceTrustXForwardedFor "
+ "is enabled.")
private Boolean webServiceLogDetailedAddresses;
@FieldContext(doc = "Maximum size of a text message during parsing in WebSocket proxy")
private int webSocketMaxTextFrameSize = 1024 * 1024;
// --- Authentication ---
@FieldContext(doc = "Enable authentication")
private boolean authenticationEnabled;
@FieldContext(doc = "Authentication provider name list, which is a list of class names")
private Set authenticationProviders = new TreeSet<>();
@FieldContext(doc = "Enforce authorization")
private boolean authorizationEnabled;
@FieldContext(doc = "Authorization provider fully qualified class name")
private String authorizationProvider = PulsarAuthorizationProvider.class.getName();
@FieldContext(doc = "Role names that are treated as \"super-user\", "
+ "which means they can do all admin operations and publish to or consume from all topics")
private Set superUserRoles = new TreeSet<>();
@FieldContext(doc = "Allow wildcard matching in authorization "
+ "(wildcard matching only applicable if wildcard-char: "
+ "presents at first or last position. For example: *.pulsar.service,pulsar.service.*)")
private boolean authorizationAllowWildcardsMatching = false;
@FieldContext(doc = "Proxy authentication settings used to connect to brokers")
private String brokerClientAuthenticationPlugin;
@FieldContext(doc = "Proxy authentication parameters used to connect to brokers")
private String brokerClientAuthenticationParameters;
@FieldContext(doc = "Path for the trusted TLS certificate file for outgoing connection to a server (broker)")
private String brokerClientTrustCertsFilePath = "";
// Note: name matches the ServiceConfiguration name to ensure correct mapping
@FieldContext(doc = "Enable TLS hostname verification when connecting to broker")
private boolean tlsHostnameVerificationEnabled = false;
@FieldContext(doc = "Number of IO threads in Pulsar client used in WebSocket proxy")
private int webSocketNumIoThreads = Runtime.getRuntime().availableProcessors();
@FieldContext(doc = "Number of threads to used in HTTP server")
private int numHttpServerThreads = Math.max(6, Runtime.getRuntime().availableProcessors());
@FieldContext(doc = "Number of threads used by Websocket service")
private int webSocketNumServiceThreads = 20;
@FieldContext(doc = "Max concurrent web requests")
private int maxConcurrentHttpRequests = 1024;
@FieldContext(doc = "Capacity for thread pool queue in the HTTP server"
+ " Default is set to 8192."
)
private int httpServerThreadPoolQueueSize = 8192;
@FieldContext(doc = "Capacity for accept queue in the HTTP server"
+ " Default is set to 8192."
)
private int httpServerAcceptQueueSize = 8192;
@FieldContext(doc = "Maximum number of inbound http connections. "
+ "(0 to disable limiting)")
private int maxHttpServerConnections = 2048;
@FieldContext(doc = "Number of connections per broker in Pulsar client used in WebSocket proxy")
private int webSocketConnectionsPerBroker = Runtime.getRuntime().availableProcessors();
@FieldContext(doc = "Memory limit in MBs for direct memory in Pulsar Client used in WebSocket proxy")
private int webSocketPulsarClientMemoryLimitInMB = 0;
@FieldContext(doc = "Timeout of idling WebSocket session (in milliseconds)")
private int webSocketSessionIdleTimeoutMillis = 300000;
@FieldContext(doc = "Interval of time to sending the ping to keep alive. This value greater than 0 means enabled")
private int webSocketPingDurationSeconds = -1;
@FieldContext(doc = "When this parameter is not empty, unauthenticated users perform as anonymousUserRole")
private String anonymousUserRole = null;
/* --- TLS --- */
@Deprecated
private boolean tlsEnabled = false;
@FieldContext(doc = "Enable TLS of broker client")
private boolean brokerClientTlsEnabled = false;
@FieldContext(doc = "Path for the TLS certificate file")
private String tlsCertificateFilePath;
@FieldContext(doc = "Path for the TLS private key file")
private String tlsKeyFilePath;
@FieldContext(doc = "Path for the trusted TLS certificate file")
private String tlsTrustCertsFilePath = "";
@FieldContext(doc = "Accept untrusted TLS certificate from client and broker")
private boolean tlsAllowInsecureConnection = false;
@FieldContext(doc = "Specify whether client certificates are required for "
+ "TLS rejecting the connection if the client certificate is not trusted")
private boolean tlsRequireTrustedClientCertOnConnect = false;
@FieldContext(doc = "TLS cert refresh duration (in seconds). 0 means checking every new connection.")
private long tlsCertRefreshCheckDurationSec = 300;
/**** --- KeyStore TLS config variables. --- ****/
@FieldContext(
doc = "Enable TLS with KeyStore type configuration for WebSocket"
)
private boolean tlsEnabledWithKeyStore = false;
@FieldContext(
doc = "Specify the TLS provider for the WebSocket service: SunJSSE, Conscrypt and etc."
)
private String tlsProvider = "Conscrypt";
@FieldContext(
doc = "TLS KeyStore type configuration in WebSocket: JKS, PKCS12"
)
private String tlsKeyStoreType = "JKS";
@FieldContext(
doc = "TLS KeyStore path in WebSocket"
)
private String tlsKeyStore = null;
@FieldContext(
doc = "TLS KeyStore password for WebSocket"
)
@ToString.Exclude
private String tlsKeyStorePassword = null;
@FieldContext(
doc = "TLS TrustStore type configuration in WebSocket: JKS, PKCS12"
)
private String tlsTrustStoreType = "JKS";
@FieldContext(
doc = "TLS TrustStore path in WebSocket"
)
private String tlsTrustStore = null;
@FieldContext(
doc = "TLS TrustStore password for WebSocket, null means empty password."
)
@ToString.Exclude
private String tlsTrustStorePassword = null;
@FieldContext(
doc = "Specify the tls protocols the proxy's web service will use to negotiate during TLS Handshake.\n\n"
+ "Example:- [TLSv1.3, TLSv1.2]"
)
private Set webServiceTlsProtocols = new TreeSet<>();
@FieldContext(
doc = "Specify the tls cipher the proxy's web service will use to negotiate during TLS Handshake.\n\n"
+ "Example:- [TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256]"
)
private Set webServiceTlsCiphers = new TreeSet<>();
@FieldContext(
doc = "CryptoKeyReader factory classname to support encryption at websocket."
)
private String cryptoKeyReaderFactoryClassName;
@FieldContext(doc = "Key-value properties. Types are all String")
private Properties properties = new Properties();
public long getMetadataStoreSessionTimeoutMillis() {
return zooKeeperSessionTimeoutMillis > 0 ? zooKeeperSessionTimeoutMillis : metadataStoreSessionTimeoutMillis;
}
public int getMetadataStoreCacheExpirySeconds() {
return zooKeeperCacheExpirySeconds > 0 ? zooKeeperCacheExpirySeconds : metadataStoreCacheExpirySeconds;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy