/*
* IronJacamar, a Java EE Connector Architecture implementation
* Copyright 2014, 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 Eclipse Public License 1.0 as
* published by the Free Software Foundation.
*
* 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 Eclipse
* Public License for more details.
*
* You should have received a copy of the Eclipse 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.ironjacamar.common.api.metadata.spec;
import org.ironjacamar.common.api.metadata.CopyableMetaData;
import org.ironjacamar.common.api.metadata.ValidatableMetadata;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
*
* A Connector.
*
* @author <a href="stefano.maestri@ironjacamar.org">Stefano Maestri</a>
*
*/
public interface Connector
extends
IdDecoratedMetadata,
ValidatableMetadata,
MergeableMetadata<Connector>,
CopyableMetaData<Connector>
{
/**
* Get the vendorName.
*
* @return the vendorName.
*/
public XsdString getVendorName();
/**
* Get the eisType.
*
* @return the eisType.
*/
public XsdString getEisType();
/**
* Get the license.
*
* @return the license.
*/
public LicenseType getLicense();
/**
* Get the resourceadapter.
*
* @return the resourceadapter.
*/
public ResourceAdapter getResourceadapter();
/**
* @return resourceadapterVersion
*/
public XsdString getResourceadapterVersion();
/**
* @return description
*/
public List<LocalizedXsdString> getDescriptions();
/**
* @return displayName
*/
public List<LocalizedXsdString> getDisplayNames();
/**
* @return icon
*/
public List<Icon> getIcons();
/**
* Get the version.
*
* @return the version.
*/
public Version getVersion();
/**
* @return requiredWorkContext
*/
public List<String> getRequiredWorkContexts();
/**
* @return moduleName
*/
public String getModuleName();
/**
* @return metadataComplete
*/
public boolean isMetadataComplete();
/**
*
* A Version enumeration
*
* @author <a href="stefano.maestri@ironjacamar.org">Stefano Maestri</a>
*
*/
public enum Version
{
/**
* Unknown
*/
UNKNOWN(null),
/**
* 1.0
*/
V_10("1.0"),
/**
* 1.5
*/
V_15("1.5"),
/**
* 1.6
*/
V_16("1.6"),
/**
* 1.7
*/
V_17("1.7");
private String name;
/**
* Constructor
* @param name a name
*/
Version(String name)
{
this.name = name;
}
/**
* Get the name
* @return The value
*/
public String getLocalName()
{
return name;
}
/**
* {@inheritDoc}
*/
public String toString()
{
return name;
}
private static final Map<String, Version> MAP;
static
{
final Map<String, Version> map = new HashMap<String, Version>();
for (Version element : values())
{
final String name = element.getLocalName();
if (name != null)
map.put(name, element);
}
MAP = map;
}
/**
* Set the value
* @param v The name
* @return The value
*/
Version value(String v)
{
name = v;
return this;
}
/**
*
* Static method to get enum instance given localName XsdString
*
* @param localName a XsdString used as localname (typically tag name as defined in xsd)
* @return the enum instance
*/
public static Version forName(String localName)
{
final Version element = MAP.get(localName);
return element == null ? UNKNOWN.value(localName) : element;
}
}
}