org.jboss.jca.common.metadata.spec.AuthenticationMechanismImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ironjacamar-common-impl Show documentation
Show all versions of ironjacamar-common-impl Show documentation
IronJacamar is an implementation of the Java EE Connector Architecture 1.6 specification
/*
* 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.spec;
import org.jboss.jca.common.api.metadata.CopyUtil;
import org.jboss.jca.common.api.metadata.CopyableMetaData;
import org.jboss.jca.common.api.metadata.spec.AuthenticationMechanism;
import org.jboss.jca.common.api.metadata.spec.CredentialInterfaceEnum;
import org.jboss.jca.common.api.metadata.spec.LocalizedXsdString;
import org.jboss.jca.common.api.metadata.spec.XsdString;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* An AuthenticationMechanism implementation
* @author Stefano Maestri
* @author Jesper Pedersen
*/
public class AuthenticationMechanismImpl implements AuthenticationMechanism
{
private static final long serialVersionUID = 1L;
private List description;
private XsdString authenticationMechanismType;
private CredentialInterfaceEnum credentialInterface;
private String id;
private String cIId;
/**
* Constructor
* @param description description attribute in xml
* @param authenticationMechanismType specifies type of an authentication mechanism.
The example values are:
BasicPassword
Kerbv5
Any additional security mechanisms are outside the
scope of the Connector architecture specification.
* @param credentialInterface enumeration representing credentialInterface.
* @param id xml ID
* @param cid credential interface id
*/
public AuthenticationMechanismImpl(List description, XsdString authenticationMechanismType,
CredentialInterfaceEnum credentialInterface, String id, String cid)
{
if (description != null)
{
this.description = new ArrayList(description);
for (LocalizedXsdString d: this.description)
d.setTag(XML.AuthenticationMechanismTag.DESCRIPTION.toString());
}
else
{
this.description = new ArrayList(0);
}
this.authenticationMechanismType = authenticationMechanismType;
if (!XsdString.isNull(this.authenticationMechanismType))
this.authenticationMechanismType.
setTag(XML.AuthenticationMechanismTag.AUTHENTICATION_MECHANISM_TYPE.toString());
this.credentialInterface = credentialInterface;
this.id = id;
this.cIId = cid;
}
/**
* {@inheritDoc}
*/
public List getDescriptions()
{
return Collections.unmodifiableList(description);
}
/**
* {@inheritDoc}
*/
public XsdString getAuthenticationMechanismType()
{
return authenticationMechanismType;
}
/**
* {@inheritDoc}
*/
public CredentialInterfaceEnum getCredentialInterface()
{
return credentialInterface;
}
/**
* {@inheritDoc}
*/
public String getId()
{
return id;
}
/**
* {@inheritDoc}
*/
public String getCredentialInterfaceId()
{
return cIId;
}
/**
* {@inheritDoc}
*/
public CopyableMetaData copy()
{
return new AuthenticationMechanismImpl(CopyUtil.cloneList(description),
CopyUtil.clone(authenticationMechanismType), credentialInterface, CopyUtil.cloneString(id),
CopyUtil.cloneString(cIId));
}
/**
* {@inheritDoc}
*/
public int hashCode()
{
final int prime = 31;
int result = 1;
result = prime * result + ((authenticationMechanismType == null) ? 0 : authenticationMechanismType.hashCode());
result = prime * result + ((credentialInterface == null) ? 0 : credentialInterface.hashCode());
result = prime * result + ((description == null) ? 0 : description.hashCode());
result = prime * result + ((id == null) ? 0 : id.hashCode());
result = prime * result + ((cIId == null) ? 0 : cIId.hashCode());
return result;
}
/**
* {@inheritDoc}
*/
public boolean equals(Object obj)
{
if (this == obj)
{
return true;
}
if (obj == null)
{
return false;
}
if (!(obj instanceof AuthenticationMechanismImpl))
{
return false;
}
AuthenticationMechanismImpl other = (AuthenticationMechanismImpl) obj;
if (authenticationMechanismType == null)
{
if (other.authenticationMechanismType != null)
{
return false;
}
}
else if (!authenticationMechanismType.equals(other.authenticationMechanismType))
{
return false;
}
if (credentialInterface != other.credentialInterface)
{
return false;
}
if (description == null)
{
if (other.description != null)
{
return false;
}
}
else if (!description.equals(other.description))
{
return false;
}
if (id == null)
{
if (other.id != null)
{
return false;
}
}
else if (!id.equals(other.id))
{
return false;
}
if (cIId == null)
{
if (other.cIId != null)
{
return false;
}
}
else if (!cIId.equals(other.cIId))
{
return false;
}
return true;
}
/**
* {@inheritDoc}
*/
public String toString()
{
StringBuilder sb = new StringBuilder(1024);
sb.append("");
if (description != null)
{
for (LocalizedXsdString s : description)
sb.append(s);
}
sb.append(authenticationMechanismType);
sb.append("<").append(XML.AuthenticationMechanismTag.CREDENTIAL_INTERFACE)
.append(cIId == null ? "" : " id=\"" + cIId + "\"").append(">");
sb.append(credentialInterface);
sb.append("").append(XML.AuthenticationMechanismTag.CREDENTIAL_INTERFACE).append(">");
sb.append(" ");
return sb.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy