/* * 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; } } }