ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/ha/session/ClusterManagerBase.java

Path
ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/ha/session/ClusterManagerBase.java
Status
scanned
Type
file
Name
ClusterManagerBase.java
Extension
.java
Programming language
Java
Mime type
text/plain
File type
ASCII text, with CRLF line terminators
Tag

      
    
Rootfs path

      
    
Size
8233 (8.0 KB)
MD5
d8984bc1cdaad0c01a7a1616ff0558d8
SHA1
2be24e1ac0236f67269c25cb24937c873bcd561e
SHA256
647c3fc67941f195c925ddf34db072ecbc857a5f85c77490cf7690c840de2a16
SHA512

      
    
SHA1_git
ddff68829753e47380774a291223cb868113cb01
Is binary

      
    
Is text
True
Is archive

      
    
Is media

      
    
Is legal

      
    
Is manifest

      
    
Is readme

      
    
Is top level

      
    
Is key file

      
    
ClusterManagerBase.java | 8.0 KB |

/* * 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.catalina.ha.session; import java.io.ByteArrayInputStream; import java.io.IOException; import org.apache.catalina.Cluster; import org.apache.catalina.Context; import org.apache.catalina.LifecycleException; import org.apache.catalina.Loader; import org.apache.catalina.SessionIdGenerator; import org.apache.catalina.Valve; import org.apache.catalina.ha.CatalinaCluster; import org.apache.catalina.ha.ClusterManager; import org.apache.catalina.ha.tcp.ReplicationValve; import org.apache.catalina.session.ManagerBase; import org.apache.catalina.tribes.io.ReplicationStream; import org.apache.juli.logging.Log; import org.apache.juli.logging.LogFactory; import org.apache.tomcat.util.collections.SynchronizedStack; import org.apache.tomcat.util.res.StringManager; public abstract class ClusterManagerBase extends ManagerBase implements ClusterManager { protected static final StringManager sm = StringManager.getManager(ClusterManagerBase.class); private final Log log = LogFactory.getLog(ClusterManagerBase.class); // must not be static /** * A reference to the cluster */ protected CatalinaCluster cluster = null; /** * Should listeners be notified? */ private boolean notifyListenersOnReplication = true; /** * cached replication valve cluster container! */ private volatile ReplicationValve replicationValve = null; /** * send all actions of session attributes. */ private boolean recordAllActions = false; private final SynchronizedStack<DeltaRequest> deltaRequestPool = new SynchronizedStack<>(); protected SynchronizedStack<DeltaRequest> getDeltaRequestPool() { return deltaRequestPool; } @Override public CatalinaCluster getCluster() { return cluster; } @Override public void setCluster(CatalinaCluster cluster) { this.cluster = cluster; } @Override public boolean isNotifyListenersOnReplication() { return notifyListenersOnReplication; } public void setNotifyListenersOnReplication(boolean notifyListenersOnReplication) { this.notifyListenersOnReplication = notifyListenersOnReplication; } public boolean isRecordAllActions() { return recordAllActions; } public void setRecordAllActions(boolean recordAllActions) { this.recordAllActions = recordAllActions; } public static ClassLoader[] getClassLoaders(Context context) { ClassLoader tccl = Thread.currentThread().getContextClassLoader(); Loader loader = context.getLoader(); ClassLoader classLoader = null; if (loader != null) { classLoader = loader.getClassLoader(); } if (classLoader == null) { classLoader = tccl; } if (classLoader == tccl) { return new ClassLoader[] { classLoader }; } else { return new ClassLoader[] { classLoader, tccl }; } } public ClassLoader[] getClassLoaders() { return getClassLoaders(getContext()); } @Override public ReplicationStream getReplicationStream(byte[] data) throws IOException { return getReplicationStream(data, 0, data.length); } @Override public ReplicationStream getReplicationStream(byte[] data, int offset, int length) throws IOException { ByteArrayInputStream fis = new ByteArrayInputStream(data, offset, length); return new ReplicationStream(fis, getClassLoaders()); } // ---------------------------------------------------- persistence handler /** * {@link org.apache.catalina.Manager} implementations that also implement {@link ClusterManager} do not support * local session persistence. */ @Override public void load() { // NOOP } /** * {@link org.apache.catalina.Manager} implementations that also implement {@link ClusterManager} do not support * local session persistence. */ @Override public void unload() { // NOOP } protected void clone(ClusterManagerBase copy) { copy.setName("Clone-from-" + getName()); copy.setMaxActiveSessions(getMaxActiveSessions()); copy.setProcessExpiresFrequency(getProcessExpiresFrequency()); copy.setNotifyListenersOnReplication(isNotifyListenersOnReplication()); copy.setSessionAttributeNameFilter(getSessionAttributeNameFilter()); copy.setSessionAttributeValueClassNameFilter(getSessionAttributeValueClassNameFilter()); copy.setWarnOnSessionAttributeFilterFailure(getWarnOnSessionAttributeFilterFailure()); copy.setSecureRandomClass(getSecureRandomClass()); copy.setSecureRandomProvider(getSecureRandomProvider()); copy.setSecureRandomAlgorithm(getSecureRandomAlgorithm()); if (getSessionIdGenerator() != null) { try { SessionIdGenerator copyIdGenerator = sessionIdGeneratorClass.getConstructor().newInstance(); copyIdGenerator.setSessionIdLength(getSessionIdGenerator().getSessionIdLength()); copyIdGenerator.setJvmRoute(getSessionIdGenerator().getJvmRoute()); copy.setSessionIdGenerator(copyIdGenerator); } catch (ReflectiveOperationException e) { // Ignore } } copy.setRecordAllActions(isRecordAllActions()); } /** * Register cross context session at replication valve thread local * * @param session cross context session */ protected void registerSessionAtReplicationValve(DeltaSession session) { if (replicationValve == null) { CatalinaCluster cluster = getCluster(); if (cluster != null) { Valve[] valves = cluster.getValves(); if (valves != null && valves.length > 0) { for (int i = 0; replicationValve == null && i < valves.length; i++) { if (valves[i] instanceof ReplicationValve) { replicationValve = (ReplicationValve) valves[i]; } } // for if (replicationValve == null && log.isDebugEnabled()) { log.debug(sm.getString("clusterManager.noValve")); } // endif } // end if } // endif } // end if if (replicationValve != null) { replicationValve.registerReplicationSession(session); } } @Override protected void startInternal() throws LifecycleException { super.startInternal(); if (getCluster() == null) { Cluster cluster = getContext().getCluster(); if (cluster instanceof CatalinaCluster) { setCluster((CatalinaCluster) cluster); } } if (cluster != null) { cluster.registerManager(this); } } @Override protected void stopInternal() throws LifecycleException { if (cluster != null) { cluster.removeManager(this); } replicationValve = null; super.stopInternal(); } }
Detected license expression
apache-2.0
Detected license expression (SPDX)
Apache-2.0
Percentage of license text
18.06
Copyrights

      
    
Holders

      
    
Authors

      
    
License detections License expression License expression SPDX
apache_2_0-4bde3f57-78aa-4201-96bf-531cba09e7de apache-2.0 Apache-2.0
URL Start line End line
http://www.apache.org/licenses/LICENSE-2.0 9 9