Package org.jboss.mx.interceptor

Source Code of org.jboss.mx.interceptor.AbstractInterceptor

/*
* JBoss, the OpenSource J2EE webOS
*
* Distributable under LGPL license.
* See terms of license at gnu.org.
*/
package org.jboss.mx.interceptor;

import javax.management.MBeanException;
import javax.management.MBeanServer;
import javax.management.ObjectName;

import org.jboss.mx.server.Invocation;
import org.jboss.mx.server.InvocationException;

import org.jboss.mx.logging.Logger;
import org.jboss.mx.logging.LoggerAdapterSupport;
import org.jboss.mx.logging.SystemLogger;


/**
* Base class for all interceptors. This class provides some default method
* implementations for interceptors.
*
* @see org.jboss.mx.interceptor.Interceptor
* @see org.jboss.mx.server.MBeanInvoker
*
* @author  <a href="mailto:juha@jboss.org">Juha Lindfors</a>.
* @version $Revision: 1.3 $  
*/
public abstract class AbstractInterceptor
   implements Interceptor
{

   // Attributes ----------------------------------------------------

   /**
    * Name for this interceptor.
    */
   protected String name            = "<no name>";
  
   /**
    * Indicates whether this interceptor instance is shared or not.
    */
   protected boolean isShared       = false;
  
   /**
    * Logger reference for interceptor implementations. This reference is
    * set by the invoker for non-shared interceptors after construction.
    * Shared interceptors will should create their own logger instance.
    */
   protected Logger log             = null;
  
  
   // Constructors --------------------------------------------------
  
   /**
    * Constructs a new intereceptor instance. This interceptor is not shared
    * in the MBean server.
    */
   public AbstractInterceptor() {}
  
   /**
    * Constructs a new interceptor instance with a given name. This interceptor
    * is not shared in the MBean server.
    *
    * @param name name of this interceptor
    *
    * @throws IllegalArgumentException if name contains <tt>null</tt> reference
    */
   public AbstractInterceptor(String name)
   {
      if (name == null || name.equals(""))
         throw new IllegalArgumentException("null name");
        
      this.name = name;
   }
  

   // Public --------------------------------------------------------

   /**
    * Sets a name for this interceptor.
    *
    * @param   name
    */
   public void setName(String name)
   {
      this.name = name;
   }
  
  
   // Interceptor implementation ------------------------------------  
  
   /**
    * The default invoke implementation queries the invocation object for the
    * next interceptor in the chain. If one exists, it is invoked. Otherwise
    * the invocation is dispatched to the target object.    <p>
    *
    * Concrete implementations should override this method to implement
    * their specific application logic.
    *
    * @see     org.jboss.mx.server.Invocation
    * @see     org.jboss.mx.server.MBeanInvoker
    *
    * @param   invocation  the invocation object send towards the target
    *                      resource by the invoker
    *
    * @return  return value from the target resource
    *
    * @throws InvocationException This exception wraps any exceptions thrown
    *         by either the target method of the resource object, or invocation
    *         interceptors in this interceptor chain. The target exception is
    *         unwrapped at the {@link org.jboss.mx.server.MBeanInvoker} instance.
    */
   public Object invoke(Invocation invocation) throws InvocationException
   {
      Interceptor ic = invocation.nextInterceptor();
     
      // if the invocation object does not provide us with more interceptors,
      // invoke the dispatcher that lands the invocation to its final target
      // in the resource object
      if (ic == null)
         return invocation.dispatch();
     
      // see if the next interceptor in the chain is shared
      if (ic.isShared())
      {
         // we require a common interface for all shared interceptors
         SharedInterceptor shared = (SharedInterceptor)ic;
        
         // we invoke shared interceptor it via the MBean server bus, get the
         // interceptors view to its MBean server
         MBeanServer server = shared.getMBeanServer();
        
         // And the object name the interceptor is registered under
         ObjectName name = shared.getObjectName();
        
         try
         {
            return server.invoke(
                  name, "invoke",                             
                  new Object[] { invocation },                    // args
                  new String[] { Invocation.class.getName() }     // signature
            );
         }
        
         // handle normal MBeanServer.invoke() exceptions by wrapping them
         // into Invocation exceptions. Notice that if the invoked
         // interceptor is propagating an exception back to the invoker it is
         // already wrapped as an invocation exception by the originating
         // interceptor. Since InvocationException is considered as an
         // applicationan exception by the hosting MBean server it wraps it
         // as an MBeanException.
         catch (MBeanException e)
         {
            // check if already wrapping an invocation exception
            if (e.getTargetException() instanceof InvocationException)
               throw (InvocationException)e.getTargetException();
              
            // otherwise wrap as invocation exception
            throw new InvocationException(e);
         }
        
         // anything else is an unforeseen exception, just wrap it and let
         // the invoker deal with it
         catch (Throwable t)
         {
            throw new InvocationException(t);
         }
      }
     
      // invoke non-shared interceptor directly via Java reference
      else
      {
         return ic.invoke(invocation);
      }
   }

   public String getName()
   {
      return name;
   }
  
   public boolean isShared()
   {
      return isShared;
   }
     
   public void setLogger(Logger log)
   {
      this.log = log;
   }
  
   public void init() throws Exception {}

   public void start() {}

   public void stop() throws Exception {}

   public void destroy() {}

  
   // Object overrides ----------------------------------------------

   /**
    * Returns a string representation of this interceptor instance.
    *
    * @return  string representation
    */
   public String toString()
   {
      String className = getClass().getName();
      int index        = className.lastIndexOf('.');
     
      return className.substring((index < 0) ? 0 : index) + "[name=" + name + "]";
   }
  
  
}

TOP

Related Classes of org.jboss.mx.interceptor.AbstractInterceptor

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.