Package org.jboss.jca.common.metadata.ra.ra10

Source Code of org.jboss.jca.common.metadata.ra.ra10.ResourceAdapter10Impl

/*
* IronJacamar, a Java EE Connector Architecture implementation
* Copyright 2008, Red Hat Inc, and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.jca.common.metadata.ra.ra10;

import org.jboss.jca.common.CommonBundle;
import org.jboss.jca.common.api.metadata.CopyUtil;
import org.jboss.jca.common.api.metadata.CopyableMetaData;
import org.jboss.jca.common.api.metadata.MergeUtil;
import org.jboss.jca.common.api.metadata.common.TransactionSupportEnum;
import org.jboss.jca.common.api.metadata.ra.AuthenticationMechanism;
import org.jboss.jca.common.api.metadata.ra.ConfigProperty;
import org.jboss.jca.common.api.metadata.ra.ConnectionDefinition.Tag;
import org.jboss.jca.common.api.metadata.ra.MergeableMetadata;
import org.jboss.jca.common.api.metadata.ra.SecurityPermission;
import org.jboss.jca.common.api.metadata.ra.XsdString;
import org.jboss.jca.common.api.metadata.ra.ra10.ResourceAdapter10;
import org.jboss.jca.common.api.validator.ValidateException;
import org.jboss.jca.common.metadata.ra.common.AbstractResourceAdapetrImpl;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

import org.jboss.logging.Messages;

/**
* @author <a href="mailto:stefano.maestri@jboss.org">Stefano Maestri</a>
*
*/
public class ResourceAdapter10Impl extends AbstractResourceAdapetrImpl implements ResourceAdapter10
{

   /** The serialVersionUID */
   private static final long serialVersionUID = 6841574517370539456L;

   /** The bundle */
   private static CommonBundle bundle = Messages.getBundle(CommonBundle.class);

   private final XsdString managedConnectionFactoryClass;

   private final XsdString connectionFactoryInterface;

   private final XsdString connectionFactoryImplClass;

   private final XsdString connectionInterface;

   private final XsdString connectionImplClass;

   private TransactionSupportEnum transactionSupport;

   private final String transactionSupportId;

   private final ArrayList<AuthenticationMechanism> authenticationMechanism;

   private final Boolean reauthenticationSupport;

   private final String reauthenticationSupportId;

   private final ArrayList<SecurityPermission> securityPermissions;

   private final String id;

   /**
   *
   * Create a new ResourceAdapter10.
   *
   * @param managedConnectionFactoryClass class name
   * @param connectionFactoryInterface interface name
   * @param connectionFactoryImplClass class name
   * @param connectionInterface interface name
   * @param connectionImplClass class name
   * @param transactionSupport how transactions are supported
   * @param authenticationMechanism how authentication is performed
   * @param configProperties list of configs
   * @param reauthenticationSupport true if reautentication is supported
   * @param securityPermissions what security permissions are supported
   * @param id the id attribute in xml file
   * @param transactionSupportId transaction support element ID
   * @param reauthenticationSupportId reauthentication support element ID
   */
   public ResourceAdapter10Impl(XsdString managedConnectionFactoryClass, XsdString connectionFactoryInterface,
      XsdString connectionFactoryImplClass, XsdString connectionInterface, XsdString connectionImplClass,
      TransactionSupportEnum transactionSupport, List<AuthenticationMechanism> authenticationMechanism,
      List<ConfigProperty> configProperties, Boolean reauthenticationSupport,
      List<SecurityPermission> securityPermissions, String id, String transactionSupportId,
      String reauthenticationSupportId)
   {
      super();
      this.managedConnectionFactoryClass = managedConnectionFactoryClass;
      if (!XsdString.isNull(this.managedConnectionFactoryClass))
         this.managedConnectionFactoryClass.setTag(Tag.MANAGEDCONNECTIONFACTORY_CLASS.toString());
      this.connectionFactoryInterface = connectionFactoryInterface;
      if (!XsdString.isNull(this.connectionFactoryInterface))
         this.connectionFactoryInterface.setTag(Tag.CONNECTIONFACTORY_INTERFACE.toString());
      this.connectionFactoryImplClass = connectionFactoryImplClass;
      if (!XsdString.isNull(this.connectionFactoryImplClass))
         this.connectionFactoryImplClass.setTag(Tag.CONNECTIONFACTORY_IMPL_CLASS.toString());
      this.connectionInterface = connectionInterface;
      if (!XsdString.isNull(this.connectionInterface))
         this.connectionInterface.setTag(Tag.CONNECTION_INTERFACE.toString());
      this.connectionImplClass = connectionImplClass;
      if (!XsdString.isNull(this.connectionImplClass))
         this.connectionImplClass.setTag(Tag.CONNECTION_IMPL_CLASS.toString());
      this.transactionSupport = transactionSupport;
      if (authenticationMechanism != null)
      {
         this.authenticationMechanism = new ArrayList<AuthenticationMechanism>(authenticationMechanism.size());
         this.authenticationMechanism.addAll(authenticationMechanism);
      }
      else
      {
         this.authenticationMechanism = new ArrayList<AuthenticationMechanism>(0);
      }
      if (configProperties != null)
      {
         this.configProperties = new ArrayList<ConfigProperty>(configProperties.size());
         this.configProperties.addAll(configProperties);
      }
      else
      {
         this.configProperties = new ArrayList<ConfigProperty>(0);
      }
      this.reauthenticationSupport = reauthenticationSupport;
      if (securityPermissions != null)
      {
         this.securityPermissions = new ArrayList<SecurityPermission>(securityPermissions.size());
         this.securityPermissions.addAll(securityPermissions);
      }
      else
      {
         this.securityPermissions = new ArrayList<SecurityPermission>(0);
      }
      this.id = id;
      this.transactionSupportId = transactionSupportId;
      this.reauthenticationSupportId = reauthenticationSupportId;
   }

   /**
   *
   * Create a new ResourceAdapter10.
   *
   * @param managedConnectionFactoryClass class name
   * @param connectionFactoryInterface interface name
   * @param connectionFactoryImplClass class name
   * @param connectionInterface interface name
   * @param connectionImplClass class name
   * @param transactionSupport how transactions are supported
   * @param authenticationMechanism how authentication is performed
   * @param configProperties list of configs
   * @param reauthenticationSupport true if reautentication is supported
   * @param securityPermissions what security permissions are supported
   * @param id the id attribute in xml file
   */
   public ResourceAdapter10Impl(XsdString managedConnectionFactoryClass, XsdString connectionFactoryInterface,
      XsdString connectionFactoryImplClass, XsdString connectionInterface, XsdString connectionImplClass,
      TransactionSupportEnum transactionSupport, List<AuthenticationMechanism> authenticationMechanism,
      List<ConfigProperty> configProperties, Boolean reauthenticationSupport,
      List<SecurityPermission> securityPermissions, String id)
   {
      this(managedConnectionFactoryClass, connectionFactoryInterface, connectionFactoryImplClass, connectionInterface,
           connectionImplClass, transactionSupport, authenticationMechanism, configProperties, reauthenticationSupport,
           securityPermissions, id, null, null);
   }

   /**
    * Get the managedConnectionFactoryClass.
    *
    * @return the managedConnectionFactoryClass.
    */
   @Override
   public XsdString getManagedConnectionFactoryClass()
   {
      return managedConnectionFactoryClass;
   }

   /**
    * Get the connectionFactoryInterface.
    *
    * @return the connectionFactoryInterface.
    */
   @Override
   public XsdString getConnectionFactoryInterface()
   {
      return connectionFactoryInterface;
   }

   /**
    * Get the connectionFactoryImplClass.
    *
    * @return the connectionFactoryImplClass.
    */
   @Override
   public XsdString getConnectionFactoryImplClass()
   {
      return connectionFactoryImplClass;
   }

   /**
    * Get the connectionInterface.
    *
    * @return the connectionInterface.
    */
   @Override
   public XsdString getConnectionInterface()
   {
      return connectionInterface;
   }

   /**
    * Get the connectionImplClass.
    *
    * @return the connectionImplClass.
    */
   @Override
   public XsdString getConnectionImplClass()
   {
      return connectionImplClass;
   }

   /**
    * Get the transactionSupport.
    *
    * @return the transactionSupport.
    */
   @Override
   public synchronized TransactionSupportEnum getTransactionSupport()
   {
      return transactionSupport;
   }

   /**
    *
    * force transactionSupport to the new value
    * This method is thread safe
    *
    * @param newTransactionSupport the new value
    */
   public synchronized void forceNewTrasactionSupport(TransactionSupportEnum newTransactionSupport)
   {
      this.transactionSupport = newTransactionSupport;
   }

   /**
    * Get the authenticationMechanism.
    *
    * @return the authenticationMechanism.
    */
   @Override
   public List<AuthenticationMechanism> getAuthenticationMechanisms()
   {
      return authenticationMechanism == null ? null : Collections.unmodifiableList(authenticationMechanism);
   }

   /**
    * Get the reauthenticationSupport.
    *
    * @return the reauthenticationSupport.
    */
   @Override
   public Boolean getReauthenticationSupport()
   {
      return reauthenticationSupport;
   }

   /**
    * Get the securityPermission.
    *
    * @return the securityPermission.
    */
   @Override
   public List<SecurityPermission> getSecurityPermissions()
   {
      return securityPermissions == null ? null : Collections.unmodifiableList(securityPermissions);
   }

   /**
    * Get the id.
    *
    * @return the id.
    */
   @Override
   public String getId()
   {
      return id;
   }

   /**
    * Get the transactionSupportId.
    *
    * @return the transactionSupportId.
    */
   public String getTransactionSupportId()
   {
      return transactionSupportId;
   }

   /**
    * Get the reauthenticationSupportId.
    *
    * @return the reauthenticationSupportId.
    */
   public String getReauthenticationSupportId()
   {
      return reauthenticationSupportId;
   }

   @Override
   public int hashCode()
   {
      final int prime = 31;
      int result = 1;
      result = prime * result + ((authenticationMechanism == null) ? 0 : authenticationMechanism.hashCode());
      result = prime * result + ((configProperties == null) ? 0 : configProperties.hashCode());
      result = prime * result + ((connectionFactoryImplClass == null) ? 0 : connectionFactoryImplClass.hashCode());
      result = prime * result + ((connectionFactoryInterface == null) ? 0 : connectionFactoryInterface.hashCode());
      result = prime * result + ((connectionImplClass == null) ? 0 : connectionImplClass.hashCode());
      result = prime * result + ((connectionInterface == null) ? 0 : connectionInterface.hashCode());
      result = prime * result + ((id == null) ? 0 : id.hashCode());
      result = prime * result + ((reauthenticationSupportId == null) ? 0 : reauthenticationSupportId.hashCode());
      result = prime * result + ((transactionSupportId == null) ? 0 : transactionSupportId.hashCode());
      result = prime * result +
               ((managedConnectionFactoryClass == null) ? 0 : managedConnectionFactoryClass.hashCode());
      result = prime * result + ((reauthenticationSupport == null) ? 0 : reauthenticationSupport.hashCode());
      result = prime * result + ((securityPermissions == null) ? 0 : securityPermissions.hashCode());
      result = prime * result + ((transactionSupport == null) ? 0 : transactionSupport.hashCode());
      return result;
   }

   @Override
   public boolean equals(Object obj)
   {
      if (this == obj)
         return true;
      if (obj == null)
         return false;
      if (!(obj instanceof ResourceAdapter10Impl))
         return false;
      ResourceAdapter10Impl other = (ResourceAdapter10Impl) obj;
      if (authenticationMechanism == null)
      {
         if (other.authenticationMechanism != null)
            return false;
      }
      else if (!authenticationMechanism.equals(other.authenticationMechanism))
         return false;
      if (configProperties == null)
      {
         if (other.configProperties != null)
            return false;
      }
      else if (!configProperties.equals(other.configProperties))
         return false;
      if (connectionFactoryImplClass == null)
      {
         if (other.connectionFactoryImplClass != null)
            return false;
      }
      else if (!connectionFactoryImplClass.equals(other.connectionFactoryImplClass))
         return false;
      if (connectionFactoryInterface == null)
      {
         if (other.connectionFactoryInterface != null)
            return false;
      }
      else if (!connectionFactoryInterface.equals(other.connectionFactoryInterface))
         return false;
      if (connectionImplClass == null)
      {
         if (other.connectionImplClass != null)
            return false;
      }
      else if (!connectionImplClass.equals(other.connectionImplClass))
         return false;
      if (connectionInterface == null)
      {
         if (other.connectionInterface != null)
            return false;
      }
      else if (!connectionInterface.equals(other.connectionInterface))
         return false;
      if (id == null)
      {
         if (other.id != null)
            return false;
      }
      else if (!id.equals(other.id))
         return false;
      if (reauthenticationSupportId == null)
      {
         if (other.reauthenticationSupportId != null)
            return false;
      }
      else if (!reauthenticationSupportId.equals(other.reauthenticationSupportId))
         return false;
      if (transactionSupportId == null)
      {
         if (other.transactionSupportId != null)
            return false;
      }
      else if (!transactionSupportId.equals(other.transactionSupportId))
         return false;
      if (managedConnectionFactoryClass == null)
      {
         if (other.managedConnectionFactoryClass != null)
            return false;
      }
      else if (!managedConnectionFactoryClass.equals(other.managedConnectionFactoryClass))
         return false;
      if (reauthenticationSupport == null)
      {
         if (other.reauthenticationSupport != null)
            return false;
      }
      else if (!reauthenticationSupport.equals(other.reauthenticationSupport))
         return false;
      if (securityPermissions == null)
      {
         if (other.securityPermissions != null)
            return false;
      }
      else if (!securityPermissions.equals(other.securityPermissions))
         return false;
      if (transactionSupport != other.transactionSupport)
         return false;
      return true;
   }

   @Override
   public String toString()
   {
      StringBuilder sb = new StringBuilder(1024);
      sb.append("<").append("resourceadapter");
      if (id != null)
         sb.append(" " + ResourceAdapter10.Attribute.ID + "=\"" + id + "\"");
      sb.append(">");

      sb.append(managedConnectionFactoryClass);

      sb.append(connectionFactoryInterface);

      sb.append(connectionFactoryImplClass);

      sb.append(connectionInterface);

      sb.append(connectionImplClass);

      sb.append("<" + Tag.TRANSACTION_SUPPORT)
         .append(transactionSupportId == null ? "" : " id=\"" + transactionSupportId + "\"").append(">");
      sb.append(transactionSupport);
      sb.append("</" + Tag.TRANSACTION_SUPPORT + ">");

      if (configProperties != null)
      {
         for (ConfigProperty cp : configProperties)
         {
            sb.append(cp);
         }
      }

      if (authenticationMechanism != null)
      {
         for (AuthenticationMechanism am : authenticationMechanism)
         {
            sb.append(am);
         }
      }

      if (reauthenticationSupport != null)
      {
         sb.append("<" + Tag.REAUTHENTICATION_SUPPORT)
            .append(reauthenticationSupportId == null ? "" : " id=\"" + reauthenticationSupportId + "\"").append(">");
         sb.append(reauthenticationSupport);
         sb.append("</" + Tag.REAUTHENTICATION_SUPPORT + ">");
      }

      if (securityPermissions != null)
      {
         for (SecurityPermission sp : securityPermissions)
         {
            sb.append(sp);
         }
      }

      sb.append("</").append("resourceadapter").append(">");

      return sb.toString();
   }

   @Override
   public void validate() throws ValidateException
   {
      if (this.getManagedConnectionFactoryClass() == null ||
          this.getManagedConnectionFactoryClass().getValue() == null ||
          this.getManagedConnectionFactoryClass().getValue().trim().equals(""))
      {

         throw new ValidateException(bundle.missingValue("managed-connection-factory-class"));
      }

   }

   @Override
   public CopyableMetaData copy()
   {
      return new ResourceAdapter10Impl(CopyUtil.clone(managedConnectionFactoryClass),
                                       CopyUtil.clone(connectionFactoryInterface),
                                       CopyUtil.clone(connectionFactoryImplClass), CopyUtil.clone(connectionInterface),
                                       CopyUtil.clone(connectionImplClass), transactionSupport,
                                       CopyUtil.cloneList(authenticationMechanism),
                                       CopyUtil.cloneList(configProperties), reauthenticationSupport,
                                       CopyUtil.cloneList(securityPermissions), CopyUtil.cloneString(id),
                                       CopyUtil.cloneString(transactionSupportId),
                                       CopyUtil.cloneString(reauthenticationSupportId));
   }

   @Override
   public ResourceAdapter10 merge(MergeableMetadata<?> jmd) throws Exception
   {
      if (jmd instanceof ResourceAdapter10Impl)
      {
         ResourceAdapter10Impl inputMD = (ResourceAdapter10Impl) jmd;
         List<ConfigProperty> newconfigProperties = MergeUtil
            .mergeList(this.configProperties, inputMD.configProperties);
         XsdString newManagedConnectionFactoryClass = XsdString.isNull(this.managedConnectionFactoryClass)
            ? inputMD.managedConnectionFactoryClass
            : this.managedConnectionFactoryClass;
         XsdString newconnectionInterface = XsdString.isNull(this.connectionInterface)
            ? inputMD.connectionInterface
            : this.connectionInterface;
         List<AuthenticationMechanism> newauthenticationMechanism = MergeUtil.mergeList(this.authenticationMechanism,
            inputMD.authenticationMechanism);
         Boolean newreauthenticationSupport = this.reauthenticationSupport == null
            ? inputMD.reauthenticationSupport
            : this.reauthenticationSupport;
         TransactionSupportEnum newtransactionSupport = this.transactionSupport == null
            ? inputMD.transactionSupport
            : this.transactionSupport;
         XsdString newconnectionImplClass = XsdString.isNull(this.connectionImplClass)
            ? inputMD.connectionImplClass
            : this.connectionImplClass;
         XsdString newConnectionFactoryInterface = XsdString.isNull(this.connectionFactoryInterface)
            ? inputMD.connectionFactoryInterface
            : this.connectionFactoryInterface;
         List<SecurityPermission> newsecurityPermissions = MergeUtil.mergeList(this.securityPermissions,
            inputMD.securityPermissions);
         XsdString newconnectionFactoryImplClass = XsdString.isNull(this.connectionFactoryImplClass)
            ? inputMD.connectionFactoryImplClass
            : this.connectionFactoryImplClass;
         return new ResourceAdapter10Impl(newManagedConnectionFactoryClass, newConnectionFactoryInterface,
                                          newconnectionFactoryImplClass, newconnectionInterface,
                                          newconnectionImplClass, newtransactionSupport, newauthenticationMechanism,
                                          newconfigProperties, newreauthenticationSupport, newsecurityPermissions,
                                          null);
      }
      else
      {
         return this;
      }
   }
}
TOP

Related Classes of org.jboss.jca.common.metadata.ra.ra10.ResourceAdapter10Impl

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.