org.wildfly.swarm.config.undertow.ServletContainer Maven / Gradle / Ivy
package org.wildfly.swarm.config.undertow;
import org.wildfly.swarm.config.runtime.AttributeDocumentation;
import org.wildfly.swarm.config.runtime.ResourceDocumentation;
import org.wildfly.swarm.config.runtime.SingletonResource;
import org.wildfly.swarm.config.runtime.Address;
import org.wildfly.swarm.config.runtime.ResourceType;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.util.List;
import org.wildfly.swarm.config.runtime.Subresource;
import org.wildfly.swarm.config.undertow.servlet_container.MimeMappingConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.MimeMappingSupplier;
import org.wildfly.swarm.config.undertow.servlet_container.MimeMapping;
import org.wildfly.swarm.config.runtime.SubresourceInfo;
import org.wildfly.swarm.config.undertow.servlet_container.WelcomeFileConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.WelcomeFileSupplier;
import org.wildfly.swarm.config.undertow.servlet_container.WelcomeFile;
import org.wildfly.swarm.config.undertow.servlet_container.PersistentSessionsSetting;
import org.wildfly.swarm.config.undertow.servlet_container.PersistentSessionsSettingConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.PersistentSessionsSettingSupplier;
import org.wildfly.swarm.config.undertow.servlet_container.CrawlerSessionManagementSetting;
import org.wildfly.swarm.config.undertow.servlet_container.CrawlerSessionManagementSettingConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.CrawlerSessionManagementSettingSupplier;
import org.wildfly.swarm.config.undertow.servlet_container.JSPSetting;
import org.wildfly.swarm.config.undertow.servlet_container.JSPSettingConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.JSPSettingSupplier;
import org.wildfly.swarm.config.undertow.servlet_container.WebsocketsSetting;
import org.wildfly.swarm.config.undertow.servlet_container.WebsocketsSettingConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.WebsocketsSettingSupplier;
import org.wildfly.swarm.config.undertow.servlet_container.SessionCookieSetting;
import org.wildfly.swarm.config.undertow.servlet_container.SessionCookieSettingConsumer;
import org.wildfly.swarm.config.undertow.servlet_container.SessionCookieSettingSupplier;
import org.wildfly.swarm.config.runtime.ModelNodeBinding;
import java.util.Arrays;
/**
* A servlet container
*/
@Address("/subsystem=undertow/servlet-container=*")
@ResourceType("servlet-container")
public class ServletContainer>
implements
org.wildfly.swarm.config.runtime.Keyed {
private String key;
private PropertyChangeSupport pcs;
private ServletContainerResources subresources = new ServletContainerResources();
@AttributeDocumentation("If true then request and response wrappers that do not extend the standard wrapper classes can be used")
private Boolean allowNonStandardWrappers;
@AttributeDocumentation("The buffer cache to use for caching static resources")
private String defaultBufferCache;
@AttributeDocumentation("Default encoding to use for all deployed applications")
private String defaultEncoding;
@AttributeDocumentation("The default session timeout (in minutes) for all applications deployed in the container.")
private Integer defaultSessionTimeout;
@AttributeDocumentation("If directory listing should be enabled for default servlets.")
private Boolean directoryListing;
@AttributeDocumentation("If Undertow should set headers to disable caching for secured paged. Disabling this can cause security problems, as sensitive pages may be cached by an intermediary.")
private Boolean disableCachingForSecuredPages;
@AttributeDocumentation("If this is true then the file watch service will not be used to monitor exploded deployments for changes")
private Boolean disableFileWatchService;
@AttributeDocumentation("If this is true then an unknown session ID will never be reused, and a new session id will be generated. If this is false then it will be re-used if and only if it is present in the session manager of another deployment, to allow the same session id to be shared between applications on the same server.")
private Boolean disableSessionIdReuse;
@AttributeDocumentation("If true undertow calls filter init() on deployment start rather than when first requested.")
private Boolean eagerFilterInitialization;
@AttributeDocumentation("Ignore flushes on the servlet output stream. In most cases these just hurt performance for no good reason.")
private Boolean ignoreFlush;
@AttributeDocumentation("The maximum number of sessions that can be active at one time")
private Integer maxSessions;
@AttributeDocumentation("If proactive authentication should be used. If this is true a user will always be authenticated if credentials are present.")
private Boolean proactiveAuthentication;
@AttributeDocumentation("The length of the generated session ID. Longer session ID's are more secure. This number refers to the number of bytes of randomness that are used to generate the session ID, the actual ID that is sent to the client will be base64 encoded so will be approximately 33% larger (e.g. a session id length of 30 will result in a cookie value of length 40).")
private Integer sessionIdLength;
@AttributeDocumentation("If an error page with the stack trace should be generated on error. Values are all, none and local-only")
private StackTraceOnError stackTraceOnError;
@AttributeDocumentation("Use encoding defined on listener")
private Boolean useListenerEncoding;
public ServletContainer(java.lang.String key) {
super();
this.key = key;
}
public String getKey() {
return this.key;
}
/**
* Adds a property change listener
*/
public void addPropertyChangeListener(PropertyChangeListener listener) {
if (null == this.pcs)
this.pcs = new PropertyChangeSupport(this);
this.pcs.addPropertyChangeListener(listener);
}
/**
* Removes a property change listener
*/
public void removePropertyChangeListener(
java.beans.PropertyChangeListener listener) {
if (this.pcs != null)
this.pcs.removePropertyChangeListener(listener);
}
public ServletContainerResources subresources() {
return this.subresources;
}
/**
* Add all MimeMapping objects to this subresource
*
* @return this
* @param value
* List of MimeMapping objects.
*/
@SuppressWarnings("unchecked")
public T mimeMappings(java.util.List value) {
this.subresources.mimeMappings = value;
return (T) this;
}
/**
* Add the MimeMapping object to the list of subresources
*
* @param value
* The MimeMapping to add
* @return this
*/
@SuppressWarnings("unchecked")
public T mimeMapping(MimeMapping value) {
this.subresources.mimeMappings.add(value);
return (T) this;
}
/**
* Create and configure a MimeMapping object to the list of subresources
*
* @param key
* The key for the MimeMapping resource
* @param config
* The MimeMappingConsumer to use
* @return this
*/
@SuppressWarnings("unchecked")
public T mimeMapping(java.lang.String childKey, MimeMappingConsumer consumer) {
MimeMapping extends MimeMapping> child = new MimeMapping<>(childKey);
if (consumer != null) {
consumer.accept(child);
}
mimeMapping(child);
return (T) this;
}
/**
* Create and configure a MimeMapping object to the list of subresources
*
* @param key
* The key for the MimeMapping resource
* @return this
*/
@SuppressWarnings("unchecked")
public T mimeMapping(java.lang.String childKey) {
mimeMapping(childKey, null);
return (T) this;
}
/**
* Install a supplied MimeMapping object to the list of subresources
*/
@SuppressWarnings("unchecked")
public T mimeMapping(MimeMappingSupplier supplier) {
mimeMapping(supplier.get());
return (T) this;
}
/**
* Add all WelcomeFile objects to this subresource
*
* @return this
* @param value
* List of WelcomeFile objects.
*/
@SuppressWarnings("unchecked")
public T welcomeFiles(java.util.List value) {
this.subresources.welcomeFiles = value;
return (T) this;
}
/**
* Add the WelcomeFile object to the list of subresources
*
* @param value
* The WelcomeFile to add
* @return this
*/
@SuppressWarnings("unchecked")
public T welcomeFile(WelcomeFile value) {
this.subresources.welcomeFiles.add(value);
return (T) this;
}
/**
* Create and configure a WelcomeFile object to the list of subresources
*
* @param key
* The key for the WelcomeFile resource
* @param config
* The WelcomeFileConsumer to use
* @return this
*/
@SuppressWarnings("unchecked")
public T welcomeFile(java.lang.String childKey, WelcomeFileConsumer consumer) {
WelcomeFile extends WelcomeFile> child = new WelcomeFile<>(childKey);
if (consumer != null) {
consumer.accept(child);
}
welcomeFile(child);
return (T) this;
}
/**
* Create and configure a WelcomeFile object to the list of subresources
*
* @param key
* The key for the WelcomeFile resource
* @return this
*/
@SuppressWarnings("unchecked")
public T welcomeFile(java.lang.String childKey) {
welcomeFile(childKey, null);
return (T) this;
}
/**
* Install a supplied WelcomeFile object to the list of subresources
*/
@SuppressWarnings("unchecked")
public T welcomeFile(WelcomeFileSupplier supplier) {
welcomeFile(supplier.get());
return (T) this;
}
/**
* Session persistence sessions
*/
@SuppressWarnings("unchecked")
public T persistentSessionsSetting(PersistentSessionsSetting value) {
this.subresources.persistentSessionsSetting = value;
return (T) this;
}
/**
* Session persistence sessions
*/
@SuppressWarnings("unchecked")
public T persistentSessionsSetting(
PersistentSessionsSettingConsumer consumer) {
PersistentSessionsSetting extends PersistentSessionsSetting> child = new PersistentSessionsSetting<>();
if (consumer != null) {
consumer.accept(child);
}
this.subresources.persistentSessionsSetting = child;
return (T) this;
}
/**
* Session persistence sessions
*/
@SuppressWarnings("unchecked")
public T persistentSessionsSetting() {
PersistentSessionsSetting extends PersistentSessionsSetting> child = new PersistentSessionsSetting<>();
this.subresources.persistentSessionsSetting = child;
return (T) this;
}
/**
* Session persistence sessions
*/
@SuppressWarnings("unchecked")
public T persistentSessionsSetting(
PersistentSessionsSettingSupplier supplier) {
this.subresources.persistentSessionsSetting = supplier.get();
return (T) this;
}
/**
* Configures special session handling for crawler bots
*/
@SuppressWarnings("unchecked")
public T crawlerSessionManagementSetting(
CrawlerSessionManagementSetting value) {
this.subresources.crawlerSessionManagementSetting = value;
return (T) this;
}
/**
* Configures special session handling for crawler bots
*/
@SuppressWarnings("unchecked")
public T crawlerSessionManagementSetting(
CrawlerSessionManagementSettingConsumer consumer) {
CrawlerSessionManagementSetting extends CrawlerSessionManagementSetting> child = new CrawlerSessionManagementSetting<>();
if (consumer != null) {
consumer.accept(child);
}
this.subresources.crawlerSessionManagementSetting = child;
return (T) this;
}
/**
* Configures special session handling for crawler bots
*/
@SuppressWarnings("unchecked")
public T crawlerSessionManagementSetting() {
CrawlerSessionManagementSetting extends CrawlerSessionManagementSetting> child = new CrawlerSessionManagementSetting<>();
this.subresources.crawlerSessionManagementSetting = child;
return (T) this;
}
/**
* Configures special session handling for crawler bots
*/
@SuppressWarnings("unchecked")
public T crawlerSessionManagementSetting(
CrawlerSessionManagementSettingSupplier supplier) {
this.subresources.crawlerSessionManagementSetting = supplier.get();
return (T) this;
}
/**
* JSP container configuration.
*/
@SuppressWarnings("unchecked")
public T jspSetting(JSPSetting value) {
this.subresources.jspSetting = value;
return (T) this;
}
/**
* JSP container configuration.
*/
@SuppressWarnings("unchecked")
public T jspSetting(JSPSettingConsumer consumer) {
JSPSetting extends JSPSetting> child = new JSPSetting<>();
if (consumer != null) {
consumer.accept(child);
}
this.subresources.jspSetting = child;
return (T) this;
}
/**
* JSP container configuration.
*/
@SuppressWarnings("unchecked")
public T jspSetting() {
JSPSetting extends JSPSetting> child = new JSPSetting<>();
this.subresources.jspSetting = child;
return (T) this;
}
/**
* JSP container configuration.
*/
@SuppressWarnings("unchecked")
public T jspSetting(JSPSettingSupplier supplier) {
this.subresources.jspSetting = supplier.get();
return (T) this;
}
/**
* If websockets are enabled for this container
*/
@SuppressWarnings("unchecked")
public T websocketsSetting(WebsocketsSetting value) {
this.subresources.websocketsSetting = value;
return (T) this;
}
/**
* If websockets are enabled for this container
*/
@SuppressWarnings("unchecked")
public T websocketsSetting(WebsocketsSettingConsumer consumer) {
WebsocketsSetting extends WebsocketsSetting> child = new WebsocketsSetting<>();
if (consumer != null) {
consumer.accept(child);
}
this.subresources.websocketsSetting = child;
return (T) this;
}
/**
* If websockets are enabled for this container
*/
@SuppressWarnings("unchecked")
public T websocketsSetting() {
WebsocketsSetting extends WebsocketsSetting> child = new WebsocketsSetting<>();
this.subresources.websocketsSetting = child;
return (T) this;
}
/**
* If websockets are enabled for this container
*/
@SuppressWarnings("unchecked")
public T websocketsSetting(WebsocketsSettingSupplier supplier) {
this.subresources.websocketsSetting = supplier.get();
return (T) this;
}
/**
* Session cookie configuration
*/
@SuppressWarnings("unchecked")
public T sessionCookieSetting(SessionCookieSetting value) {
this.subresources.sessionCookieSetting = value;
return (T) this;
}
/**
* Session cookie configuration
*/
@SuppressWarnings("unchecked")
public T sessionCookieSetting(SessionCookieSettingConsumer consumer) {
SessionCookieSetting extends SessionCookieSetting> child = new SessionCookieSetting<>();
if (consumer != null) {
consumer.accept(child);
}
this.subresources.sessionCookieSetting = child;
return (T) this;
}
/**
* Session cookie configuration
*/
@SuppressWarnings("unchecked")
public T sessionCookieSetting() {
SessionCookieSetting extends SessionCookieSetting> child = new SessionCookieSetting<>();
this.subresources.sessionCookieSetting = child;
return (T) this;
}
/**
* Session cookie configuration
*/
@SuppressWarnings("unchecked")
public T sessionCookieSetting(SessionCookieSettingSupplier supplier) {
this.subresources.sessionCookieSetting = supplier.get();
return (T) this;
}
/**
* Child mutators for ServletContainer
*/
public static class ServletContainerResources {
/**
* The servlet container mime mapping config
*/
@ResourceDocumentation("The servlet container mime mapping config")
@SubresourceInfo("mimeMapping")
private List mimeMappings = new java.util.ArrayList<>();
/**
* The welcome file
*/
@ResourceDocumentation("The welcome file")
@SubresourceInfo("welcomeFile")
private List welcomeFiles = new java.util.ArrayList<>();
@SingletonResource
@ResourceDocumentation("Session persistence sessions")
private PersistentSessionsSetting persistentSessionsSetting;
@SingletonResource
@ResourceDocumentation("Configures special session handling for crawler bots")
private CrawlerSessionManagementSetting crawlerSessionManagementSetting;
@SingletonResource
@ResourceDocumentation("JSP container configuration.")
private JSPSetting jspSetting;
@SingletonResource
@ResourceDocumentation("If websockets are enabled for this container")
private WebsocketsSetting websocketsSetting;
@SingletonResource
@ResourceDocumentation("Session cookie configuration")
private SessionCookieSetting sessionCookieSetting;
/**
* Get the list of MimeMapping resources
*
* @return the list of resources
*/
@Subresource
public List mimeMappings() {
return this.mimeMappings;
}
public MimeMapping mimeMapping(java.lang.String key) {
return this.mimeMappings.stream()
.filter(e -> e.getKey().equals(key)).findFirst()
.orElse(null);
}
/**
* Get the list of WelcomeFile resources
*
* @return the list of resources
*/
@Subresource
public List welcomeFiles() {
return this.welcomeFiles;
}
public WelcomeFile welcomeFile(java.lang.String key) {
return this.welcomeFiles.stream()
.filter(e -> e.getKey().equals(key)).findFirst()
.orElse(null);
}
/**
* Session persistence sessions
*/
@Subresource
public PersistentSessionsSetting persistentSessionsSetting() {
return this.persistentSessionsSetting;
}
/**
* Configures special session handling for crawler bots
*/
@Subresource
public CrawlerSessionManagementSetting crawlerSessionManagementSetting() {
return this.crawlerSessionManagementSetting;
}
/**
* JSP container configuration.
*/
@Subresource
public JSPSetting jspSetting() {
return this.jspSetting;
}
/**
* If websockets are enabled for this container
*/
@Subresource
public WebsocketsSetting websocketsSetting() {
return this.websocketsSetting;
}
/**
* Session cookie configuration
*/
@Subresource
public SessionCookieSetting sessionCookieSetting() {
return this.sessionCookieSetting;
}
}
public static enum StackTraceOnError {
NONE("none"), LOCAL_ONLY("local-only"), ALL("all");
private final String allowedValue;
/**
* Returns the allowed value for the management model.
*
* @return the allowed model value
*/
public String getAllowedValue() {
return allowedValue;
}
StackTraceOnError(java.lang.String allowedValue) {
this.allowedValue = allowedValue;
}
@Override
public String toString() {
return allowedValue;
}
}
/**
* If true then request and response wrappers that do not extend the
* standard wrapper classes can be used
*/
@ModelNodeBinding(detypedName = "allow-non-standard-wrappers")
public Boolean allowNonStandardWrappers() {
return this.allowNonStandardWrappers;
}
/**
* If true then request and response wrappers that do not extend the
* standard wrapper classes can be used
*/
@SuppressWarnings("unchecked")
public T allowNonStandardWrappers(java.lang.Boolean value) {
Object oldValue = this.allowNonStandardWrappers;
this.allowNonStandardWrappers = value;
if (this.pcs != null)
this.pcs.firePropertyChange("allowNonStandardWrappers", oldValue,
value);
return (T) this;
}
/**
* The buffer cache to use for caching static resources
*/
@ModelNodeBinding(detypedName = "default-buffer-cache")
public String defaultBufferCache() {
return this.defaultBufferCache;
}
/**
* The buffer cache to use for caching static resources
*/
@SuppressWarnings("unchecked")
public T defaultBufferCache(java.lang.String value) {
Object oldValue = this.defaultBufferCache;
this.defaultBufferCache = value;
if (this.pcs != null)
this.pcs.firePropertyChange("defaultBufferCache", oldValue, value);
return (T) this;
}
/**
* Default encoding to use for all deployed applications
*/
@ModelNodeBinding(detypedName = "default-encoding")
public String defaultEncoding() {
return this.defaultEncoding;
}
/**
* Default encoding to use for all deployed applications
*/
@SuppressWarnings("unchecked")
public T defaultEncoding(java.lang.String value) {
Object oldValue = this.defaultEncoding;
this.defaultEncoding = value;
if (this.pcs != null)
this.pcs.firePropertyChange("defaultEncoding", oldValue, value);
return (T) this;
}
/**
* The default session timeout (in minutes) for all applications deployed in
* the container.
*/
@ModelNodeBinding(detypedName = "default-session-timeout")
public Integer defaultSessionTimeout() {
return this.defaultSessionTimeout;
}
/**
* The default session timeout (in minutes) for all applications deployed in
* the container.
*/
@SuppressWarnings("unchecked")
public T defaultSessionTimeout(java.lang.Integer value) {
Object oldValue = this.defaultSessionTimeout;
this.defaultSessionTimeout = value;
if (this.pcs != null)
this.pcs.firePropertyChange("defaultSessionTimeout", oldValue,
value);
return (T) this;
}
/**
* If directory listing should be enabled for default servlets.
*/
@ModelNodeBinding(detypedName = "directory-listing")
public Boolean directoryListing() {
return this.directoryListing;
}
/**
* If directory listing should be enabled for default servlets.
*/
@SuppressWarnings("unchecked")
public T directoryListing(java.lang.Boolean value) {
Object oldValue = this.directoryListing;
this.directoryListing = value;
if (this.pcs != null)
this.pcs.firePropertyChange("directoryListing", oldValue, value);
return (T) this;
}
/**
* If Undertow should set headers to disable caching for secured paged.
* Disabling this can cause security problems, as sensitive pages may be
* cached by an intermediary.
*/
@ModelNodeBinding(detypedName = "disable-caching-for-secured-pages")
public Boolean disableCachingForSecuredPages() {
return this.disableCachingForSecuredPages;
}
/**
* If Undertow should set headers to disable caching for secured paged.
* Disabling this can cause security problems, as sensitive pages may be
* cached by an intermediary.
*/
@SuppressWarnings("unchecked")
public T disableCachingForSecuredPages(java.lang.Boolean value) {
Object oldValue = this.disableCachingForSecuredPages;
this.disableCachingForSecuredPages = value;
if (this.pcs != null)
this.pcs.firePropertyChange("disableCachingForSecuredPages",
oldValue, value);
return (T) this;
}
/**
* If this is true then the file watch service will not be used to monitor
* exploded deployments for changes
*/
@ModelNodeBinding(detypedName = "disable-file-watch-service")
public Boolean disableFileWatchService() {
return this.disableFileWatchService;
}
/**
* If this is true then the file watch service will not be used to monitor
* exploded deployments for changes
*/
@SuppressWarnings("unchecked")
public T disableFileWatchService(java.lang.Boolean value) {
Object oldValue = this.disableFileWatchService;
this.disableFileWatchService = value;
if (this.pcs != null)
this.pcs.firePropertyChange("disableFileWatchService", oldValue,
value);
return (T) this;
}
/**
* If this is true then an unknown session ID will never be reused, and a
* new session id will be generated. If this is false then it will be
* re-used if and only if it is present in the session manager of another
* deployment, to allow the same session id to be shared between
* applications on the same server.
*/
@ModelNodeBinding(detypedName = "disable-session-id-reuse")
public Boolean disableSessionIdReuse() {
return this.disableSessionIdReuse;
}
/**
* If this is true then an unknown session ID will never be reused, and a
* new session id will be generated. If this is false then it will be
* re-used if and only if it is present in the session manager of another
* deployment, to allow the same session id to be shared between
* applications on the same server.
*/
@SuppressWarnings("unchecked")
public T disableSessionIdReuse(java.lang.Boolean value) {
Object oldValue = this.disableSessionIdReuse;
this.disableSessionIdReuse = value;
if (this.pcs != null)
this.pcs.firePropertyChange("disableSessionIdReuse", oldValue,
value);
return (T) this;
}
/**
* If true undertow calls filter init() on deployment start rather than when
* first requested.
*/
@ModelNodeBinding(detypedName = "eager-filter-initialization")
public Boolean eagerFilterInitialization() {
return this.eagerFilterInitialization;
}
/**
* If true undertow calls filter init() on deployment start rather than when
* first requested.
*/
@SuppressWarnings("unchecked")
public T eagerFilterInitialization(java.lang.Boolean value) {
Object oldValue = this.eagerFilterInitialization;
this.eagerFilterInitialization = value;
if (this.pcs != null)
this.pcs.firePropertyChange("eagerFilterInitialization", oldValue,
value);
return (T) this;
}
/**
* Ignore flushes on the servlet output stream. In most cases these just
* hurt performance for no good reason.
*/
@ModelNodeBinding(detypedName = "ignore-flush")
public Boolean ignoreFlush() {
return this.ignoreFlush;
}
/**
* Ignore flushes on the servlet output stream. In most cases these just
* hurt performance for no good reason.
*/
@SuppressWarnings("unchecked")
public T ignoreFlush(java.lang.Boolean value) {
Object oldValue = this.ignoreFlush;
this.ignoreFlush = value;
if (this.pcs != null)
this.pcs.firePropertyChange("ignoreFlush", oldValue, value);
return (T) this;
}
/**
* The maximum number of sessions that can be active at one time
*/
@ModelNodeBinding(detypedName = "max-sessions")
public Integer maxSessions() {
return this.maxSessions;
}
/**
* The maximum number of sessions that can be active at one time
*/
@SuppressWarnings("unchecked")
public T maxSessions(java.lang.Integer value) {
Object oldValue = this.maxSessions;
this.maxSessions = value;
if (this.pcs != null)
this.pcs.firePropertyChange("maxSessions", oldValue, value);
return (T) this;
}
/**
* If proactive authentication should be used. If this is true a user will
* always be authenticated if credentials are present.
*/
@ModelNodeBinding(detypedName = "proactive-authentication")
public Boolean proactiveAuthentication() {
return this.proactiveAuthentication;
}
/**
* If proactive authentication should be used. If this is true a user will
* always be authenticated if credentials are present.
*/
@SuppressWarnings("unchecked")
public T proactiveAuthentication(java.lang.Boolean value) {
Object oldValue = this.proactiveAuthentication;
this.proactiveAuthentication = value;
if (this.pcs != null)
this.pcs.firePropertyChange("proactiveAuthentication", oldValue,
value);
return (T) this;
}
/**
* The length of the generated session ID. Longer session ID's are more
* secure. This number refers to the number of bytes of randomness that are
* used to generate the session ID, the actual ID that is sent to the client
* will be base64 encoded so will be approximately 33% larger (e.g. a
* session id length of 30 will result in a cookie value of length 40).
*/
@ModelNodeBinding(detypedName = "session-id-length")
public Integer sessionIdLength() {
return this.sessionIdLength;
}
/**
* The length of the generated session ID. Longer session ID's are more
* secure. This number refers to the number of bytes of randomness that are
* used to generate the session ID, the actual ID that is sent to the client
* will be base64 encoded so will be approximately 33% larger (e.g. a
* session id length of 30 will result in a cookie value of length 40).
*/
@SuppressWarnings("unchecked")
public T sessionIdLength(java.lang.Integer value) {
Object oldValue = this.sessionIdLength;
this.sessionIdLength = value;
if (this.pcs != null)
this.pcs.firePropertyChange("sessionIdLength", oldValue, value);
return (T) this;
}
/**
* If an error page with the stack trace should be generated on error.
* Values are all, none and local-only
*/
@ModelNodeBinding(detypedName = "stack-trace-on-error")
public StackTraceOnError stackTraceOnError() {
return this.stackTraceOnError;
}
/**
* If an error page with the stack trace should be generated on error.
* Values are all, none and local-only
*/
@SuppressWarnings("unchecked")
public T stackTraceOnError(StackTraceOnError value) {
Object oldValue = this.stackTraceOnError;
this.stackTraceOnError = value;
if (this.pcs != null)
this.pcs.firePropertyChange("stackTraceOnError", oldValue, value);
return (T) this;
}
/**
* Use encoding defined on listener
*/
@ModelNodeBinding(detypedName = "use-listener-encoding")
public Boolean useListenerEncoding() {
return this.useListenerEncoding;
}
/**
* Use encoding defined on listener
*/
@SuppressWarnings("unchecked")
public T useListenerEncoding(java.lang.Boolean value) {
Object oldValue = this.useListenerEncoding;
this.useListenerEncoding = value;
if (this.pcs != null)
this.pcs.firePropertyChange("useListenerEncoding", oldValue, value);
return (T) this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy