You are viewing a plain text version of this content. The canonical link for it is here.
Posted to scm@geronimo.apache.org by ge...@apache.org on 2011/09/10 17:51:42 UTC
svn commit: r1167545 -
/geronimo/server/trunk/plugins/uddi/uddi-war-repackage/src/main/java/org/apache/juddi/config/Install.java
Author: genspring
Date: Sat Sep 10 15:51:42 2011
New Revision: 1167545
URL: http://svn.apache.org/viewvc?rev=1167545&view=rev
Log:
use "if (name.startsWith(basePath)&& name.endsWith(FILE_PUBLISHER))" to check the entry in bundle to determine if it's valid publishers.
Added:
geronimo/server/trunk/plugins/uddi/uddi-war-repackage/src/main/java/org/apache/juddi/config/Install.java
Added: geronimo/server/trunk/plugins/uddi/uddi-war-repackage/src/main/java/org/apache/juddi/config/Install.java
URL: http://svn.apache.org/viewvc/geronimo/server/trunk/plugins/uddi/uddi-war-repackage/src/main/java/org/apache/juddi/config/Install.java?rev=1167545&view=auto
==============================================================================
--- geronimo/server/trunk/plugins/uddi/uddi-war-repackage/src/main/java/org/apache/juddi/config/Install.java (added)
+++ geronimo/server/trunk/plugins/uddi/uddi-war-repackage/src/main/java/org/apache/juddi/config/Install.java Sat Sep 10 15:51:42 2011
@@ -0,0 +1,676 @@
+/*
+ * Copyright 2001-2008 The Apache Software Foundation.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+package org.apache.juddi.config;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.StringReader;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.Enumeration;
+import java.util.List;
+import java.util.StringTokenizer;
+import java.util.UUID;
+import java.util.jar.JarEntry;
+import java.util.jar.JarFile;
+
+import javax.persistence.EntityManager;
+import javax.persistence.EntityTransaction;
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Unmarshaller;
+import javax.xml.transform.stream.StreamSource;
+
+import org.apache.commons.configuration.Configuration;
+import org.apache.commons.configuration.ConfigurationException;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.apache.juddi.ClassUtil;
+import org.apache.juddi.api.impl.UDDIInquiryImpl;
+import org.apache.juddi.keygen.KeyGenerator;
+import org.apache.juddi.mapping.MappingApiToModel;
+import org.apache.juddi.model.UddiEntityPublisher;
+import org.apache.juddi.v3.error.ErrorMessage;
+import org.apache.juddi.v3.error.FatalErrorException;
+import org.apache.juddi.v3.error.InvalidKeyPassedException;
+import org.apache.juddi.v3.error.KeyUnavailableException;
+import org.apache.juddi.v3.error.ValueNotAllowedException;
+import org.apache.juddi.validation.ValidatePublish;
+import org.apache.juddi.validation.ValidateUDDIKey;
+import org.uddi.api_v3.SaveTModel;
+import org.uddi.api_v3.TModel;
+import org.uddi.v3_service.DispositionReportFaultMessage;
+
+/**
+ * @author <a href="mailto:jfaath@apache.org">Jeff Faath</a>
+ */
+public class Install {
+
+ public static final String FILE_BUSINESSENTITY = "_BusinessEntity.xml";
+ public static final String FILE_PUBLISHER = "_Publisher.xml";
+ public static final String FILE_TMODELKEYGEN = "_tModelKeyGen.xml";
+ public static final String FILE_TMODELS = "_tModels.xml";
+
+ public static final String FILE_PERSISTENCE = "persistence.xml";
+ public static final String JUDDI_INSTALL_DATA_DIR = "juddi_install_data/";
+ public static final String JUDDI_CUSTOM_INSTALL_DATA_DIR = "juddi_custom_install_data/";
+ public static Log log = LogFactory.getLog(Install.class);
+
+ protected static void install(Configuration config) throws JAXBException, DispositionReportFaultMessage, IOException, ConfigurationException {
+
+ EntityManager em = PersistenceManager.getEntityManager();
+ EntityTransaction tx = em.getTransaction();
+
+ UddiEntityPublisher rootPublisher = null;
+
+ try {
+ tx.begin();
+ boolean seedAlways = config.getBoolean("juddi.seed.always", false);
+ boolean alreadyInstalled = alreadyInstalled(config);
+ if (!seedAlways && alreadyInstalled)
+ new FatalErrorException(new ErrorMessage("errors.install.AlreadyInstalled"));
+
+
+ String rootPublisherStr = config.getString(Property.JUDDI_ROOT_PUBLISHER);
+ String fileRootTModelKeygen = rootPublisherStr + FILE_TMODELKEYGEN;
+ TModel rootTModelKeyGen = (TModel)buildInstallEntity(fileRootTModelKeygen, "org.uddi.api_v3", config);
+ String fileRootBusinessEntity = rootPublisherStr + FILE_BUSINESSENTITY;
+ org.uddi.api_v3.BusinessEntity rootBusinessEntity = (org.uddi.api_v3.BusinessEntity)buildInstallEntity(fileRootBusinessEntity, "org.uddi.api_v3",config);
+
+ String rootPartition = getRootPartition(rootTModelKeyGen);
+ String nodeId = getNodeId(rootBusinessEntity.getBusinessKey(), rootPartition);
+
+ String fileRootPublisher = rootPublisherStr + FILE_PUBLISHER;
+ if (!alreadyInstalled) {
+ log.info("Loading the root Publisher from file " + fileRootPublisher);
+
+ rootPublisher = installPublisher(em, fileRootPublisher, config);
+ installRootPublisherKeyGen(em, rootTModelKeyGen, rootPartition, rootPublisher, nodeId);
+ rootBusinessEntity.setBusinessKey(nodeId);
+ installBusinessEntity(true, em, rootBusinessEntity, rootPublisher, rootPartition, config);
+ } else {
+ log.debug("juddi.seed.always reapplies all seed files except for the root data.");
+ }
+
+ List<String> juddiPublishers = getPublishers(config);
+ for (String publisherStr : juddiPublishers) {
+ String filePublisher = publisherStr + FILE_PUBLISHER;
+ String fileTModelKeygen = publisherStr + FILE_TMODELKEYGEN;
+ TModel tModelKeyGen = (TModel)buildInstallEntity(fileTModelKeygen, "org.uddi.api_v3", config);
+ String fileBusinessEntity = publisherStr + FILE_BUSINESSENTITY;
+ org.uddi.api_v3.BusinessEntity businessEntity = (org.uddi.api_v3.BusinessEntity)buildInstallEntity(fileBusinessEntity, "org.uddi.api_v3",config);
+ UddiEntityPublisher publisher = installPublisher(em, filePublisher, config);
+ if (publisher==null) {
+ throw new ConfigurationException("File " + filePublisher + " not found.");
+ } else {
+ if (tModelKeyGen!=null) installPublisherKeyGen(em, tModelKeyGen, publisher, nodeId);
+ if (businessEntity!=null) installBusinessEntity(false, em, businessEntity, publisher, null, config);
+ String fileTModels = publisherStr + FILE_TMODELS;
+ installSaveTModel(em, fileTModels, publisher, nodeId, config);
+ }
+ }
+
+ tx.commit();
+ }
+ catch(DispositionReportFaultMessage dr) {
+ log .error(dr.getMessage(),dr);
+ tx.rollback();
+ throw dr;
+ }
+ catch (JAXBException je) {
+ log .error(je.getMessage(),je);
+ tx.rollback();
+ throw je;
+ }
+ catch (IOException ie) {
+ log .error(ie.getMessage(),ie);
+ tx.rollback();
+ throw ie;
+ } finally {
+ if (tx.isActive()) {
+ tx.rollback();
+ }
+ em.close();
+ }
+ }
+
+ protected static void uninstall() {
+ // Close the open emf, open a new one with Persistence.create...(String, Map) and overwrite the property that handles the table
+ // generation. The persistence.xml file will have to be read in to determine which property
+ // to overwrite. The property will be specific to the provider.
+ // Hibernate: <property name="hibernate.hbm2ddl.auto" value="update"/> ->use "create-drop" or just "drop"?
+ // OpenJPA: openjpa.jdbc.SynchronizeMappings=buildSchema(SchemaAction='add,deleteTableContents')
+ // etc...(find more)
+ // Then close this emf. Question: is the original emf reusable or will closing it cause problems?
+
+ }
+
+ /**
+ * Checks if there is a database with a root publisher. If it is not found
+ * an
+ *
+ * @param config
+ * @return true if it finds a database with the root publisher in it.
+ * @throws ConfigurationException
+ */
+ protected static boolean alreadyInstalled(Configuration config) throws ConfigurationException {
+
+ String rootPublisherStr = config.getString(Property.JUDDI_ROOT_PUBLISHER);
+ org.apache.juddi.model.Publisher publisher = null;
+ int numberOfTries=0;
+ while (numberOfTries++ < 100) {
+ EntityManager em = PersistenceManager.getEntityManager();
+ EntityTransaction tx = em.getTransaction();
+ try {
+ tx.begin();
+ publisher = em.find(org.apache.juddi.model.Publisher.class, rootPublisherStr);
+ tx.commit();
+ } finally {
+ if (tx.isActive()) {
+ tx.rollback();
+ }
+ em.close();
+ }
+ if (publisher != null) return true;
+
+ if (config.getBoolean(Property.JUDDI_LOAD_INSTALL_DATA,Property.DEFAULT_LOAD_INSTALL_DATA)) {
+ log.debug("Install data not yet installed.");
+ return false;
+ } else {
+ try {
+ log.info("Install data not yet installed.");
+ log.info("Going to sleep and retry...");
+ Thread.sleep(1000l);
+ } catch (InterruptedException e) {
+ log.error(e.getMessage(),e);
+ }
+ }
+ }
+ throw new ConfigurationException("Could not load the Root node data. Please check for errors.");
+ }
+
+ protected static String getRootPartition(TModel rootTModelKeyGen) throws JAXBException, IOException, DispositionReportFaultMessage {
+ String result = rootTModelKeyGen.getTModelKey().substring(0, rootTModelKeyGen.getTModelKey().lastIndexOf(KeyGenerator.PARTITION_SEPARATOR));
+
+ if (result == null || result.length() == 0)
+ throw new InvalidKeyPassedException(new ErrorMessage("errors.invalidkey.MalformedKey", result));
+
+ // Must validate the root partition. The first component should be a domain key and the any following
+ // tokens should be a valid KSS.
+ result = result.trim();
+ if (result.endsWith(KeyGenerator.PARTITION_SEPARATOR) || result.startsWith(KeyGenerator.PARTITION_SEPARATOR))
+ throw new InvalidKeyPassedException(new ErrorMessage("errors.invalidkey.MalformedKey", result));
+
+ StringTokenizer tokenizer = new StringTokenizer(result.toLowerCase(), KeyGenerator.PARTITION_SEPARATOR);
+ for(int count = 0; tokenizer.hasMoreTokens(); count++) {
+ String nextToken = tokenizer.nextToken();
+
+ if (count == 0) {
+ if(!ValidateUDDIKey.isValidDomainKey(nextToken))
+ throw new InvalidKeyPassedException(new ErrorMessage("errors.invalidkey.MalformedKey", result));
+ }
+ else {
+ if (!ValidateUDDIKey.isValidKSS(nextToken))
+ throw new InvalidKeyPassedException(new ErrorMessage("errors.invalidkey.MalformedKey", result));
+ }
+ }
+
+ return result;
+ }
+
+ protected static String getNodeId(String userNodeId, String rootPartition) throws DispositionReportFaultMessage {
+
+ String result = userNodeId;
+ if (result == null || result.length() == 0) {
+ result = rootPartition + KeyGenerator.PARTITION_SEPARATOR + UUID.randomUUID();
+ }
+ else {
+ ValidateUDDIKey.validateUDDIv3Key(result);
+ String keyPartition = result.substring(0, result.lastIndexOf(KeyGenerator.PARTITION_SEPARATOR));
+ if (!rootPartition.equalsIgnoreCase(keyPartition))
+ throw new KeyUnavailableException(new ErrorMessage("errors.keyunavailable.BadPartition", userNodeId));
+ }
+ return result;
+ }
+
+
+
+ private static String installBusinessEntity(boolean isRoot, EntityManager em, org.uddi.api_v3.BusinessEntity rootBusinessEntity,
+ UddiEntityPublisher rootPublisher, String rootPartition, Configuration config)
+ throws JAXBException, DispositionReportFaultMessage, IOException {
+
+ if (isRoot) validateRootBusinessEntity(rootBusinessEntity, rootPublisher, rootPartition, config);
+
+ org.apache.juddi.model.BusinessEntity modelBusinessEntity = new org.apache.juddi.model.BusinessEntity();
+ MappingApiToModel.mapBusinessEntity(rootBusinessEntity, modelBusinessEntity);
+
+ modelBusinessEntity.setAuthorizedName(rootPublisher.getAuthorizedName());
+
+ Date now = new Date();
+ modelBusinessEntity.setCreated(now);
+ modelBusinessEntity.setModified(now);
+ modelBusinessEntity.setModifiedIncludingChildren(now);
+ modelBusinessEntity.setNodeId(modelBusinessEntity.getEntityKey());
+
+ for (org.apache.juddi.model.BusinessService service : modelBusinessEntity.getBusinessServices()) {
+ service.setAuthorizedName(rootPublisher.getAuthorizedName());
+
+ service.setCreated(now);
+ service.setModified(now);
+ service.setModifiedIncludingChildren(now);
+ service.setNodeId(modelBusinessEntity.getEntityKey());
+
+ for (org.apache.juddi.model.BindingTemplate binding : service.getBindingTemplates()) {
+ binding.setAuthorizedName(rootPublisher.getAuthorizedName());
+
+ binding.setCreated(now);
+ binding.setModified(now);
+ binding.setModifiedIncludingChildren(now);
+ binding.setNodeId(modelBusinessEntity.getEntityKey());
+ }
+ }
+
+
+ em.persist(modelBusinessEntity);
+
+ return modelBusinessEntity.getEntityKey();
+
+ }
+
+
+ // A watered down version of ValidatePublish's validateBusinessEntity, designed for the specific condition that this is run upon the initial
+ // jUDDI install.
+ private static void validateRootBusinessEntity(org.uddi.api_v3.BusinessEntity businessEntity, UddiEntityPublisher rootPublisher,
+ String rootPartition, Configuration config)
+ throws DispositionReportFaultMessage {
+
+ // A supplied businessService can't be null
+ if (businessEntity == null)
+ throw new ValueNotAllowedException(new ErrorMessage("errors.businessentity.NullInput"));
+
+ // The business key should already be set to the previously calculated and validated nodeId. This validation is unnecessary but kept for
+ // symmetry with the other entity validations.
+ String entityKey = businessEntity.getBusinessKey();
+ if (entityKey == null || entityKey.length() == 0) {
+ entityKey = rootPartition + KeyGenerator.PARTITION_SEPARATOR + UUID.randomUUID();
+ businessEntity.setBusinessKey(entityKey);
+ }
+ else {
+ // Per section 4.4: keys must be case-folded
+ entityKey = entityKey.toLowerCase();
+ businessEntity.setBusinessKey(entityKey);
+
+ ValidateUDDIKey.validateUDDIv3Key(entityKey);
+ String keyPartition = entityKey.substring(0, entityKey.lastIndexOf(KeyGenerator.PARTITION_SEPARATOR));
+ if (!rootPartition.equalsIgnoreCase(keyPartition))
+ throw new KeyUnavailableException(new ErrorMessage("errors.keyunavailable.BadPartition", entityKey));
+ }
+
+ ValidatePublish validatePublish = new ValidatePublish(rootPublisher);
+
+ validatePublish.validateNames(businessEntity.getName());
+ validatePublish.validateDiscoveryUrls(businessEntity.getDiscoveryURLs());
+ validatePublish.validateContacts(businessEntity.getContacts());
+ validatePublish.validateCategoryBag(businessEntity.getCategoryBag(),config);
+ validatePublish.validateIdentifierBag(businessEntity.getIdentifierBag(),config);
+
+ org.uddi.api_v3.BusinessServices businessServices = businessEntity.getBusinessServices();
+ if (businessServices != null) {
+ List<org.uddi.api_v3.BusinessService> businessServiceList = businessServices.getBusinessService();
+ if (businessServiceList == null || businessServiceList.size() == 0)
+ throw new ValueNotAllowedException(new ErrorMessage("errors.businessservices.NoInput"));
+
+ for (org.uddi.api_v3.BusinessService businessService : businessServiceList) {
+ validateRootBusinessService(businessService, businessEntity, rootPublisher, rootPartition, config);
+ }
+ }
+
+ }
+
+ // A watered down version of ValidatePublish's validateBusinessService, designed for the specific condition that this is run upon the initial
+ // jUDDI install.
+ private static void validateRootBusinessService(org.uddi.api_v3.BusinessService businessService, org.uddi.api_v3.BusinessEntity parent,
+ UddiEntityPublisher rootPublisher, String rootPartition, Configuration config)
+ throws DispositionReportFaultMessage {
+
+ // A supplied businessService can't be null
+ if (businessService == null)
+ throw new ValueNotAllowedException(new ErrorMessage("errors.businessservice.NullInput"));
+
+ // A business key doesn't have to be provided, but if it is, it should match the parent business's key
+ String parentKey = businessService.getBusinessKey();
+ if (parentKey != null && parentKey.length()> 0) {
+ if (!parentKey.equalsIgnoreCase(parent.getBusinessKey()))
+ throw new InvalidKeyPassedException(new ErrorMessage("errors.invalidkey.ParentBusinessNotFound", parentKey));
+ }
+
+ // Retrieve the service's passed key
+ String entityKey = businessService.getServiceKey();
+ if (entityKey == null || entityKey.length() == 0) {
+ entityKey = rootPartition + KeyGenerator.PARTITION_SEPARATOR + UUID.randomUUID();
+ businessService.setServiceKey(entityKey);
+ }
+ else {
+ // Per section 4.4: keys must be case-folded
+ entityKey = entityKey.toLowerCase();
+ businessService.setServiceKey(entityKey);
+
+ ValidateUDDIKey.validateUDDIv3Key(entityKey);
+ String keyPartition = entityKey.substring(0, entityKey.lastIndexOf(KeyGenerator.PARTITION_SEPARATOR));
+ if (!rootPartition.equalsIgnoreCase(keyPartition))
+ throw new KeyUnavailableException(new ErrorMessage("errors.keyunavailable.BadPartition", entityKey));
+ }
+
+ ValidatePublish validatePublish = new ValidatePublish(rootPublisher);
+
+ validatePublish.validateNames(businessService.getName());
+ validatePublish.validateCategoryBag(businessService.getCategoryBag(), config);
+
+ org.uddi.api_v3.BindingTemplates bindingTemplates = businessService.getBindingTemplates();
+ if (bindingTemplates != null) {
+ List<org.uddi.api_v3.BindingTemplate> bindingTemplateList = bindingTemplates.getBindingTemplate();
+ if (bindingTemplateList == null || bindingTemplateList.size() == 0)
+ throw new ValueNotAllowedException(new ErrorMessage("errors.bindingtemplates.NoInput"));
+
+ for (org.uddi.api_v3.BindingTemplate bindingTemplate : bindingTemplateList) {
+ validateRootBindingTemplate(bindingTemplate, businessService, rootPublisher, rootPartition, config);
+ }
+ }
+ }
+
+ // A watered down version of ValidatePublish's validatBindingTemplate, designed for the specific condition that this is run upon the initial
+ // jUDDI install.
+ private static void validateRootBindingTemplate(org.uddi.api_v3.BindingTemplate bindingTemplate, org.uddi.api_v3.BusinessService parent,
+ UddiEntityPublisher rootPublisher, String rootPartition, Configuration config)
+ throws DispositionReportFaultMessage {
+
+ // A supplied businessService can't be null
+ if (bindingTemplate == null)
+ throw new ValueNotAllowedException(new ErrorMessage("errors.bindingtemplate.NullInput"));
+
+ // A service key doesn't have to be provided, but if it is, it should match the parent service's key
+ String parentKey = bindingTemplate.getServiceKey();
+ if (parentKey != null && parentKey.length()> 0) {
+ if (!parentKey.equalsIgnoreCase(parent.getServiceKey()))
+ throw new InvalidKeyPassedException(new ErrorMessage("errors.invalidkey.ParentServiceNotFound", parentKey));
+ }
+
+ // Retrieve the service's passed key
+ String entityKey = bindingTemplate.getBindingKey();
+ if (entityKey == null || entityKey.length() == 0) {
+ entityKey = rootPartition + KeyGenerator.PARTITION_SEPARATOR + UUID.randomUUID();
+ bindingTemplate.setBindingKey(entityKey);
+ }
+ else {
+ // Per section 4.4: keys must be case-folded
+ entityKey = entityKey.toLowerCase();
+ bindingTemplate.setBindingKey(entityKey);
+
+ ValidateUDDIKey.validateUDDIv3Key(entityKey);
+ String keyPartition = entityKey.substring(0, entityKey.lastIndexOf(KeyGenerator.PARTITION_SEPARATOR));
+ if (!rootPartition.equalsIgnoreCase(keyPartition))
+ throw new KeyUnavailableException(new ErrorMessage("errors.keyunavailable.BadPartition", entityKey));
+ }
+
+ ValidatePublish validatePublish = new ValidatePublish(rootPublisher);
+
+ validatePublish.validateCategoryBag(bindingTemplate.getCategoryBag(), config);
+ validatePublish.validateTModelInstanceDetails(bindingTemplate.getTModelInstanceDetails());
+
+ }
+
+
+
+
+ private static void installTModels(EntityManager em, List<org.uddi.api_v3.TModel> apiTModelList, UddiEntityPublisher publisher, String nodeId) throws DispositionReportFaultMessage {
+ if (apiTModelList != null) {
+ for (org.uddi.api_v3.TModel apiTModel : apiTModelList) {
+ String tModelKey = apiTModel.getTModelKey();
+
+ if (tModelKey.toUpperCase().endsWith(KeyGenerator.KEYGENERATOR_SUFFIX.toUpperCase())) {
+ installPublisherKeyGen(em, apiTModel, publisher, nodeId);
+ }
+ else {
+ org.apache.juddi.model.Tmodel modelTModel = new org.apache.juddi.model.Tmodel();
+ apiTModel.setTModelKey(apiTModel.getTModelKey().toLowerCase());
+
+ MappingApiToModel.mapTModel(apiTModel, modelTModel);
+
+ modelTModel.setAuthorizedName(publisher.getAuthorizedName());
+
+ Date now = new Date();
+ modelTModel.setCreated(now);
+ modelTModel.setModified(now);
+ modelTModel.setModifiedIncludingChildren(now);
+ modelTModel.setNodeId(nodeId);
+
+ em.persist(modelTModel);
+ }
+
+ }
+ }
+
+ }
+
+ private static void installRootPublisherKeyGen(EntityManager em, TModel rootTModelKeyGen, String rootPartition, UddiEntityPublisher publisher, String nodeId)
+ throws DispositionReportFaultMessage {
+
+ rootTModelKeyGen.setTModelKey(rootPartition + KeyGenerator.PARTITION_SEPARATOR + KeyGenerator.KEYGENERATOR_SUFFIX);
+
+ installPublisherKeyGen(em, rootTModelKeyGen, publisher, nodeId);
+ }
+
+ private static void installPublisherKeyGen(EntityManager em, TModel apiTModel, UddiEntityPublisher publisher, String nodeId) throws DispositionReportFaultMessage {
+
+ org.apache.juddi.model.Tmodel modelTModel = new org.apache.juddi.model.Tmodel();
+ MappingApiToModel.mapTModel(apiTModel, modelTModel);
+
+ modelTModel.setAuthorizedName(publisher.getAuthorizedName());
+
+ Date now = new Date();
+ modelTModel.setCreated(now);
+ modelTModel.setModified(now);
+ modelTModel.setModifiedIncludingChildren(now);
+ modelTModel.setNodeId(nodeId);
+
+ em.persist(modelTModel);
+
+ }
+
+ private static List<String> getPublishers(Configuration config) throws ConfigurationException {
+ List<String> publishers = new ArrayList<String>();
+ String basePath = JUDDI_CUSTOM_INSTALL_DATA_DIR;
+ URL url = ClassUtil.getResource(JUDDI_CUSTOM_INSTALL_DATA_DIR, Install.class);
+ if (url==null) {
+ url = ClassUtil.getResource(JUDDI_INSTALL_DATA_DIR, Install.class);
+ basePath = JUDDI_INSTALL_DATA_DIR;
+ }
+
+ String path = null;
+ if ("vfsfile".equals(url.getProtocol())) {
+ try {
+ path = url.toURI().getPath() ;
+ } catch (URISyntaxException e) {
+ throw new ConfigurationException(e);
+ }
+ } else {
+ path = url.getPath();
+ }
+
+ File dir = new File(path);
+ String rootPublisherStr = config.getString(Property.JUDDI_ROOT_PUBLISHER);
+ if (dir.exists()) {
+ log.debug("Discovering the Publisher XML data files in directory: " + path);
+ File[] files = dir.listFiles(new PublisherFileFilter());
+ for (File f : files)
+ {
+ String publisher = f.getName().substring(0,f.getName().indexOf(FILE_PUBLISHER));
+ if (! rootPublisherStr.equalsIgnoreCase(publisher)) {
+ publishers.add(publisher);
+ }
+ }
+ } else {
+ String[] paths = {};
+ Enumeration<JarEntry> en = null;
+ try {
+
+ if (path.indexOf("!") > 0) {
+ paths = path.split("!");
+ en = new JarFile(new File(new URI(paths[0]))).entries();
+ } else {
+ // Handle Windows / jboss-5.1.0 case
+ if (path.indexOf(".jar") > 0) {
+ paths = path.split(".jar");
+ paths[0] = paths[0] + ".jar";
+ en = new JarFile(new File(paths[0])).entries();
+ }
+ }
+ if (paths.length > 0) {
+ log.debug("Discovering the Publisher XML data files in jar: " + paths[0]);
+ while (en.hasMoreElements()) {
+ String name = en.nextElement().getName();
+ if (name.startsWith(basePath)&& name.endsWith(FILE_PUBLISHER)) {
+ log.debug("Found publisher file=" + name);
+ String publisher = name.substring(basePath.length(),name.indexOf(FILE_PUBLISHER));
+ if (! rootPublisherStr.equalsIgnoreCase(publisher)) {
+ publishers.add(publisher);
+ }
+ }
+ }
+ } else {
+ log.info("No custom configuration files where found in " + path);
+ }
+ } catch (IOException e) {
+ throw new ConfigurationException(e);
+ } catch (URISyntaxException e) {
+ throw new ConfigurationException(e);
+ }
+ }
+ return publishers;
+ }
+
+ private static Object buildInstallEntity(final String fileName, String packageName, Configuration config) throws JAXBException, IOException, ConfigurationException {
+ InputStream resourceStream = null;
+
+ // First try the custom install directory
+ URL url = ClassUtil.getResource(JUDDI_CUSTOM_INSTALL_DATA_DIR + fileName, Install.class);
+ if (url != null) resourceStream = url.openStream();
+
+ // If the custom install directory doesn't exist, then use the standard install directory where the resource is guaranteed to exist.
+ if (resourceStream == null) {
+ url = ClassUtil.getResource(JUDDI_INSTALL_DATA_DIR + fileName, Install.class);
+ if (url != null) {
+ resourceStream = url.openStream();
+ }
+ // If file still does not exist then return null;
+ if (url ==null || resourceStream == null) {
+ if (fileName.endsWith(FILE_PUBLISHER)) {
+ throw new ConfigurationException("Could not locate " + JUDDI_INSTALL_DATA_DIR + fileName);
+ } else {
+ log.debug("Could not locate: " + url);
+ }
+ return null;
+ }
+ }
+ log.info("Loading the content of file: " + url);
+ StringBuilder xml = new StringBuilder();
+ byte[] b = new byte[4096];
+ for (int n; (n = resourceStream.read(b)) != -1;) {
+ xml.append(new String(b, 0, n));
+ }
+ log.debug("inserting: " + xml.toString());
+ StringReader reader = new StringReader(xml.toString());
+
+ JAXBContext jc = JAXBContext.newInstance(packageName);
+ Unmarshaller unmarshaller = jc.createUnmarshaller();
+ Object obj = ((JAXBElement<?>)unmarshaller.unmarshal(new StreamSource(reader))).getValue();
+ return obj;
+ }
+
+ /**
+ * Public convenience method that allows one to retrieve the node business entity (perhaps to display during an install process, or even to
+ * initiate the install process).
+ *
+ * @param businessKey
+ * @return BusinessEntity Object
+ * @throws DispositionReportFaultMessage
+ */
+ public static org.uddi.api_v3.BusinessEntity getNodeBusinessEntity(String businessKey) throws DispositionReportFaultMessage {
+ UDDIInquiryImpl inquiry = new UDDIInquiryImpl();
+
+ org.uddi.api_v3.GetBusinessDetail gbd = new org.uddi.api_v3.GetBusinessDetail();
+ gbd.getBusinessKey().add(businessKey);
+
+ org.uddi.api_v3.BusinessDetail bd = inquiry.getBusinessDetail(gbd);
+ if (bd != null) {
+ List<org.uddi.api_v3.BusinessEntity> beList = bd.getBusinessEntity();
+ if (beList != null && beList.size() > 0)
+ return beList.get(0);
+ }
+
+ return new org.uddi.api_v3.BusinessEntity();
+ }
+
+ /**
+ * Public convenience method that allows one to install additional TModels via a SaveTModel structure.
+ *
+ * @param em - the entity manager to a juddi model
+ * @param fileName - name of SaveTModel xml file
+ * @param publisher - the publisher structure that owns the tModels
+ * @param nodeId - the node id of the custodial node
+ * @throws JAXBException
+ * @throws DispositionReportFaultMessage
+ * @throws IOException
+ * @throws ConfigurationException
+ */
+ public static void installSaveTModel(EntityManager em, String fileName, UddiEntityPublisher publisher, String nodeId, Configuration config)
+ throws JAXBException, DispositionReportFaultMessage, IOException, ConfigurationException {
+
+ SaveTModel apiSaveTModel = (SaveTModel)buildInstallEntity(fileName, "org.uddi.api_v3", config);
+ if (apiSaveTModel!=null) installTModels(em, apiSaveTModel.getTModel(), publisher, nodeId);
+ }
+
+ /**
+ * Public convenience method that allows one to install additional Publishers via a Publisher structure.
+ *
+ * @param em - the entity manager to the juddi model
+ * @param fileName - name of Publisher xml file
+ * @return UddiEntityPublisher object, can be any UDDIEntity
+ * @throws JAXBException
+ * @throws DispositionReportFaultMessage
+ * @throws IOException
+ * @throws ConfigurationException
+ */
+ public static UddiEntityPublisher installPublisher(EntityManager em, String fileName, Configuration config)
+ throws JAXBException, DispositionReportFaultMessage, IOException, ConfigurationException {
+
+ org.apache.juddi.api_v3.Publisher apiPub = (org.apache.juddi.api_v3.Publisher)buildInstallEntity(fileName, "org.apache.juddi.api_v3", config);
+ if (apiPub==null) return null;
+ org.apache.juddi.model.Publisher modelPub = new org.apache.juddi.model.Publisher();
+ MappingApiToModel.mapPublisher(apiPub, modelPub);
+ em.persist(modelPub);
+ return modelPub;
+ }
+
+
+}