MapperListenerpublic class MapperListener extends Object implements NotificationFilter, NotificationListener
Fields Summary |
---|
private static com.sun.org.apache.commons.logging.Log | log | protected org.apache.tomcat.util.http.mapper.Mapper | mapperAssociated mapper. | protected MBeanServer | mBeanServerMBean server. | private org.apache.tomcat.util.res.StringManager | smThe string manager for this package. | private String | domain | private String | engine | private int | port | private String | defaultHost | private ConcurrentHashMap | virtualServerPorts | private String | myInstance |
Constructors Summary |
---|
public MapperListener(org.apache.tomcat.util.http.mapper.Mapper mapper)Create mapper listener.
// END SJSAS 6313044
// ----------------------------------------------------------- Constructors
this.mapper = mapper;
virtualServerPorts = new ConcurrentHashMap<ObjectName,int[]>();
|
Methods Summary |
---|
public java.lang.String | getDefaultHost()
return defaultHost;
| public java.lang.String | getDomain()
return domain;
| public java.lang.String | getEngine()
return engine;
| public int | getPort()
return port;
| public void | handleNotification(javax.management.Notification notification, java.lang.Object handback)
if (notification instanceof MBeanServerNotification) {
ObjectName objectName =
((MBeanServerNotification) notification).getMBeanName();
String j2eeType = objectName.getKeyProperty("j2eeType");
String engineName = null;
if (j2eeType != null) {
if ((j2eeType.equals("WebModule")) ||
(j2eeType.equals("Servlet"))) {
if (mBeanServer.isRegistered(objectName)) {
/* SJSAS 6290785
try {
engineName = (String)
mBeanServer.getAttribute(objectName, "engineName");
} catch (Exception e) {
// Ignore
}
*/
// START SJSAS 6290785
MBeanInfo info = null;
try {
info = mBeanServer.getMBeanInfo(objectName);
} catch (Exception e) {
// Ignore
}
if (info != null) {
boolean hasEngineNameAttribute = false;
MBeanAttributeInfo[] attrInfo = info.getAttributes();
if (attrInfo != null) {
for (int i=0; i<attrInfo.length; i++) {
if ("engineName".equals(
attrInfo[i].getName())) {
hasEngineNameAttribute = true;
break;
}
}
}
if (hasEngineNameAttribute) {
try {
engineName = (String)
mBeanServer.getAttribute(objectName,
"engineName");
} catch (Exception e) {
// Ignore
}
}
}
// END SJSAS 6290785
}
}
}
// At deployment time, engineName is always = null.
if ( (!"*".equals(domain)) &&
( !domain.equals(objectName.getDomain()) ) &&
( (!domain.equals(engineName) ) &&
(engineName != null) ) ) {
return;
}
if (log.isDebugEnabled()) {
log.debug( "Handle " + objectName );
}
if (notification.getType().equals
(MBeanServerNotification.REGISTRATION_NOTIFICATION)) {
String type=objectName.getKeyProperty("type");
if( "Host".equals( type )) {
try {
registerHost(objectName);
} catch (Exception e) {
log.warn("Error registering Host " + objectName, e);
}
}
if (j2eeType != null) {
if (j2eeType.equals("WebModule")) {
try {
registerContext(objectName);
} catch (Throwable t) {
log.warn("Error registering Context " + objectName,t);
}
} else if (j2eeType.equals("Servlet")) {
try {
registerWrapper(objectName);
} catch (Throwable t) {
log.warn("Error registering Wrapper " + objectName,t);
}
}
}
} else if (notification.getType().equals
(MBeanServerNotification.UNREGISTRATION_NOTIFICATION)) {
String type=objectName.getKeyProperty("type");
if( "Host".equals( type )) {
try {
unregisterHost(objectName);
} catch (Exception e) {
log.warn("Error unregistering Host " + objectName,e);
}
}
if (j2eeType != null) {
if (j2eeType.equals("WebModule")) {
try {
unregisterContext(objectName);
} catch (Throwable t) {
log.warn("Error unregistering webapp " + objectName,t);
}
}
}
}
}
| public void | init()Initialize associated mapper.
// START SJSAS 6313044
myInstance = System.getProperty("com.sun.aas.instanceName");
// END SJSAS 6313044
if (defaultHost != null) {
mapper.setDefaultHostName(defaultHost);
}
try {
mBeanServer = Registry.getServer();
// Query hosts
String onStr = domain + ":type=Host,*";
ObjectName objectName = new ObjectName(onStr);
Set set = mBeanServer.queryMBeans(objectName, null);
Iterator iterator = set.iterator();
while (iterator.hasNext()) {
ObjectInstance oi = (ObjectInstance) iterator.next();
registerHost(oi.getObjectName());
}
// Query contexts
onStr = domain + ":j2eeType=WebModule,*";
objectName = new ObjectName(onStr);
set = mBeanServer.queryMBeans(objectName, null);
iterator = set.iterator();
while (iterator.hasNext()) {
ObjectInstance oi = (ObjectInstance) iterator.next();
registerContext(oi.getObjectName());
}
// Query wrappers
onStr = domain + ":j2eeType=Servlet,*";
objectName = new ObjectName(onStr);
set = mBeanServer.queryMBeans(objectName, null);
iterator = set.iterator();
while (iterator.hasNext()) {
ObjectInstance oi = (ObjectInstance) iterator.next();
registerWrapper(oi.getObjectName());
}
onStr = "JMImplementation:type=MBeanServerDelegate";
objectName = new ObjectName(onStr);
/* SJSAS 6313044
mBeanServer.addNotificationListener(objectName, this, null, null);
*/
// START SJSAS 6313044
mBeanServer.addNotificationListener(objectName, this, this, null);
// END SJSAS 6313044
} catch (Exception e) {
log.warn("Error registering contexts",e);
}
| public boolean | isNotificationEnabled(javax.management.Notification notification)Filters out any notifications corresponding to MBeans belonging to
a different server instance than the server instance on which this
MapperListener is running.
if (notification instanceof MBeanServerNotification) {
ObjectName objectName =
((MBeanServerNotification) notification).getMBeanName();
String otherDomain = objectName.getDomain();
if (this.domain != null && !(this.domain.equals(otherDomain))) {
return false;
}
String otherInstance = objectName.getKeyProperty("J2EEServer");
if (myInstance != null && otherInstance != null
&& !otherInstance.equals(myInstance)) {
return false;
}
}
return true;
| private void | registerContext(javax.management.ObjectName objectName)Register context.
StandardContext context = (StandardContext)
mBeanServer.invoke(objectName, "findMappingObject", null, null);
if (context == null) {
throw new Exception("No context registered for " + objectName);
}
String name = objectName.getKeyProperty("name");
// If the domain is the same with ours or the engine
// name attribute is the same... - then it's ours
String targetDomain=objectName.getDomain();
if( ! domain.equals( targetDomain )) {
targetDomain = context.getEngineName();
if( ! domain.equals( targetDomain )) {
// not ours
return;
}
}
String hostName = null;
String contextName = null;
if (name.startsWith("//")) {
name = name.substring(2);
}
int slash = name.indexOf("/");
if (slash != -1) {
hostName = name.substring(0, slash);
contextName = name.substring(slash);
contextName = RequestUtil.URLDecode(contextName , "UTF-8");
} else {
return;
}
// Special case for the root context
if (contextName.equals("/")) {
contextName = "";
}
if (log.isDebugEnabled()) {
log.debug(sm.getString("mapperListener.registerContext",
contextName));
}
javax.naming.Context resources = context.findStaticResources();
String[] welcomeFiles = context.getWelcomeFiles();
mapper.addContext(hostName, contextName, context,
welcomeFiles, resources);
| private void | registerEngine()
ObjectName engineName = new ObjectName
(domain + ":type=Engine");
if ( ! mBeanServer.isRegistered(engineName)) return;
// BEGIN S1AS 5000999
/*
String defaultHost =
(String) mBeanServer.getAttribute(engineName, "defaultHost");
*/
if (defaultHost == null) {
defaultHost =
(String) mBeanServer.getAttribute(engineName, "defaultHost");
}
// END S1AS 5000999
ObjectName hostName = new ObjectName
(domain + ":type=Host," + "host=" + defaultHost);
if (!mBeanServer.isRegistered(hostName)) {
// Get the hosts' list
String onStr = domain + ":type=Host,*";
ObjectName objectName = new ObjectName(onStr);
Set set = mBeanServer.queryMBeans(objectName, null);
Iterator iterator = set.iterator();
String[] aliases;
boolean isRegisteredWithAlias = false;
while (iterator.hasNext()) {
if (isRegisteredWithAlias) break;
ObjectInstance oi = (ObjectInstance) iterator.next();
hostName = oi.getObjectName();
aliases = (String[])
mBeanServer.invoke(hostName, "findAliases", null, null);
for (int i=0; i < aliases.length; i++){
if (aliases[i].equalsIgnoreCase(defaultHost)){
isRegisteredWithAlias = true;
break;
}
}
}
if (!isRegisteredWithAlias)
log.warn("Unknown default host: " + defaultHost);
}
// This should probably be called later
if( defaultHost != null ) {
mapper.setDefaultHostName(defaultHost);
}
| public void | registerHost(javax.management.ObjectName objectName)Register host.
String name=objectName.getKeyProperty("host");
if( name != null ) {
Host host = (Host) mBeanServer.invoke(objectName,
"findMappingObject",
null,
null);
if (host == null) {
throw new Exception("No host registered for " + objectName);
}
// BEGIN S1AS 5000999
/*
* Register the given Host only if one of its associated port
* numbers matches the port number of this MapperListener
*/
int[] ports = ((StandardHost) host).findPorts();
boolean portMatch = false;
if (ports != null) {
for (int i=0; i<ports.length; i++) {
if (ports[i] == this.port) {
portMatch = true;
break;
}
}
}
if (!portMatch) {
if (log.isDebugEnabled()) {
log.debug("HTTP listener with port " + port
+ " ignoring registration of host with object "
+ "name " + objectName + ", because none of the "
+ "host's associated HTTP listeners matches "
+ "this port");
}
return;
}
if (ports != null) {
virtualServerPorts.put(objectName, ports);
}
// END S1AS 5000999
String[] aliases = host.findAliases();
mapper.addHost(name, aliases, host);
}
| private void | registerWrapper(javax.management.ObjectName objectName)Register wrapper.
StandardWrapper wrapper = (StandardWrapper)
mBeanServer.invoke(objectName, "findMappingObject", null, null);
if (wrapper == null) {
throw new Exception("No wrapper registered for " + objectName);
}
// If the domain is the same with ours or the engine
// name attribute is the same... - then it's ours
String targetDomain=objectName.getDomain();
if( ! domain.equals( targetDomain )) {
targetDomain= wrapper.getEngineName();
if( ! domain.equals( targetDomain )) {
// not ours
return;
}
}
String wrapperName = objectName.getKeyProperty("name");
String name = objectName.getKeyProperty("WebModule");
String hostName = null;
String contextName = null;
if (name.startsWith("//")) {
name = name.substring(2);
}
int slash = name.indexOf("/");
if (slash != -1) {
hostName = name.substring(0, slash);
contextName = name.substring(slash);
contextName = RequestUtil.URLDecode(contextName , "UTF-8");
} else {
return;
}
// Special case for the root context
if (contextName.equals("/")) {
contextName = "";
}
if (log.isDebugEnabled()) {
log.debug(sm.getString("mapperListener.registerWrapper",
wrapperName, contextName));
}
String[] mappings = wrapper.findMappings();
for (int i = 0; i < mappings.length; i++) {
boolean jspWildCard = (wrapperName.equals("jsp")
&& mappings[i].endsWith("/*"));
mapper.addWrapper(hostName, contextName, mappings[i], wrapper,
jspWildCard);
}
| public void | setDefaultHost(java.lang.String defaultHost)
this.defaultHost = defaultHost;
| public void | setDomain(java.lang.String domain)
this.domain = domain;
| public void | setEngine(java.lang.String engine)
this.engine = engine;
| public void | setPort(int port)
this.port = port;
| private void | unregisterContext(javax.management.ObjectName objectName)Unregister context.
String name = objectName.getKeyProperty("name");
String hostName = null;
String contextName = null;
if (name.startsWith("//")) {
name = name.substring(2);
}
int slash = name.indexOf("/");
if (slash != -1) {
hostName = name.substring(0, slash);
contextName = name.substring(slash);
contextName = RequestUtil.URLDecode(contextName , "UTF-8");
} else {
return;
}
// Special case for the root context
if (contextName.equals("/")) {
contextName = "";
}
if (log.isDebugEnabled()) {
log.debug(sm.getString("mapperListener.unregisterContext",
contextName));
}
mapper.removeContext(hostName, contextName);
| public void | unregisterHost(javax.management.ObjectName objectName)Unregister host.
String name=objectName.getKeyProperty("host");
// BEGIN S1AS 5000999
if (name != null) {
int[] ports = virtualServerPorts.get(objectName);
boolean portMatch = false;
if (ports != null) {
virtualServerPorts.remove(objectName);
for (int i=0; i<ports.length; i++) {
if (ports[i] == this.port) {
portMatch = true;
break;
}
}
}
if (!portMatch) {
return;
}
}
// END S1AS 5000999
mapper.removeHost(name);
|
|