📄 modelservicereader.java
字号:
/* * $Id: ModelServiceReader.java 7104 2006-03-29 13:57:20Z jonesde $ * * Copyright (c) 2001-2005 The Open For Business Project - www.ofbiz.org * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT * OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */package org.ofbiz.service;import java.io.IOException;import java.io.Serializable;import java.net.URL;import java.util.Collection;import java.util.Iterator;import java.util.List;import java.util.Map;import java.util.Set;import javax.xml.parsers.ParserConfigurationException;import javolution.util.FastList;import javolution.util.FastMap;import org.ofbiz.base.config.GenericConfigException;import org.ofbiz.base.config.ResourceHandler;import org.ofbiz.base.util.Debug;import org.ofbiz.base.util.GeneralException;import org.ofbiz.base.util.UtilTimer;import org.ofbiz.base.util.UtilValidate;import org.ofbiz.base.util.UtilXml;import org.ofbiz.base.util.cache.UtilCache;import org.ofbiz.entity.GenericDelegator;import org.ofbiz.entity.GenericEntityException;import org.ofbiz.entity.model.ModelEntity;import org.ofbiz.entity.model.ModelField;import org.ofbiz.entity.model.ModelFieldType;import org.apache.commons.collections.map.LinkedMap;import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.Node;import org.w3c.dom.NodeList;import org.xml.sax.SAXException;/** * Generic Service - Service Definition Reader * * @author <a href="mailto:jaz@ofbiz.org">Andy Zeneski</a> * @author <a href="mailto:jonesde@ofbiz.org">David E. Jones</a> * @version $Rev: 7104 $ * @since 2.0 */public class ModelServiceReader implements Serializable { public static final String module = ModelServiceReader.class.getName(); protected static UtilCache readersUrl = new UtilCache("service.ModelServiceReader.ByURL", 0, 0); protected static UtilCache readersLoader = new UtilCache("service.ModelServiceReader.ByResourceLoader", 0, 0); /** is either from a URL or from a ResourceLoader (through the ResourceHandler) */ protected boolean isFromURL; protected URL readerURL = null; protected ResourceHandler handler = null; protected Map modelServices = null; protected DispatchContext dctx = null; public static ModelServiceReader getModelServiceReader(URL readerURL, DispatchContext dctx) { ModelServiceReader reader = null; // if ( readersUrl.containsKey(readerURL) ) <-- this is unnecessary as it will return null below if not found reader = (ModelServiceReader) readersUrl.get(readerURL); if (reader == null) { // don't want to block here synchronized (ModelServiceReader.class) { // must check if null again as one of the blocked threads can still enter reader = (ModelServiceReader) readersUrl.get(readerURL); if (reader == null) { // if (Debug.infoOn()) Debug.logInfo("[Creating reader]: " + readerURL.toExternalForm(), module); reader = new ModelServiceReader(readerURL, dctx); readersUrl.put(readerURL, reader); } } } return reader; } public static ModelServiceReader getModelServiceReader(ResourceHandler handler, DispatchContext dctx) { ModelServiceReader reader = null; reader = (ModelServiceReader) readersLoader.get(handler); if (reader == null) { // don't want to block here synchronized (ModelServiceReader.class) { // must check if null again as one of the blocked threads can still enter reader = (ModelServiceReader) readersLoader.get(handler); if (reader == null) { // if (Debug.infoOn()) Debug.logInfo("[Creating reader]: " + handler, module); reader = new ModelServiceReader(handler, dctx); readersLoader.put(handler, reader); } } } return reader; } protected ModelServiceReader(URL readerURL, DispatchContext dctx) { this.isFromURL = true; this.readerURL = readerURL; this.handler = null; this.dctx = dctx; // preload models... getModelServices(); } protected ModelServiceReader(ResourceHandler handler, DispatchContext dctx) { this.isFromURL = false; this.readerURL = null; this.handler = handler; this.dctx = dctx; // preload models... getModelServices(); } public Map getModelServices() { if (modelServices == null) { // don't want to block here synchronized (ModelServiceReader.class) { // must check if null again as one of the blocked threads can still enter if (modelServices == null) { // now it's safe modelServices = FastMap.newInstance(); UtilTimer utilTimer = new UtilTimer(); Document document = null; if (this.isFromURL) { // utilTimer.timerString("Before getDocument in file " + readerURL); document = getDocument(readerURL); if (document == null) { modelServices = null; return null; } } else { // utilTimer.timerString("Before getDocument in " + handler); try { document = handler.getDocument(); } catch (GenericConfigException e) { Debug.logError(e, "Error getting XML document from resource", module); return null; } } if (this.isFromURL) {// utilTimer.timerString("Before getDocumentElement in file " + readerURL); } else {// utilTimer.timerString("Before getDocumentElement in " + handler); } Element docElement = document.getDocumentElement(); if (docElement == null) { modelServices = null; return null; } docElement.normalize(); int i = 0; Node curChild = docElement.getFirstChild(); if (curChild != null) { if (this.isFromURL) { utilTimer.timerString("Before start of service loop in file " + readerURL); } else { utilTimer.timerString("Before start of service loop in " + handler); } ; do { if (curChild.getNodeType() == Node.ELEMENT_NODE && "service".equals(curChild.getNodeName())) { i++; Element curService = (Element) curChild; String serviceName = UtilXml.checkEmpty(curService.getAttribute("name")); // check to see if service with same name has already been read if (modelServices.containsKey(serviceName)) { Debug.logWarning("WARNING: Service " + serviceName + " is defined more than once, " + "most recent will over-write previous definition(s)", module); } // utilTimer.timerString(" After serviceName -- " + i + " --"); ModelService service = createModelService(curService); // utilTimer.timerString(" After createModelService -- " + i + " --"); if (service != null) { modelServices.put(serviceName, service); // utilTimer.timerString(" After modelServices.put -- " + i + " --"); /* int reqIn = service.getParameterNames(ModelService.IN_PARAM, false).size(); int optIn = service.getParameterNames(ModelService.IN_PARAM, true).size() - reqIn; int reqOut = service.getParameterNames(ModelService.OUT_PARAM, false).size(); int optOut = service.getParameterNames(ModelService.OUT_PARAM, true).size() - reqOut; if (Debug.verboseOn()) { String msg = "-- getModelService: # " + i + " Loaded service: " + serviceName + " (IN) " + reqIn + "/" + optIn + " (OUT) " + reqOut + "/" + optOut; Debug.logVerbose(msg, module); } */ } else { Debug.logWarning( "-- -- SERVICE ERROR:getModelService: Could not create service for serviceName: " + serviceName, module); } } } while ((curChild = curChild.getNextSibling()) != null); } else { Debug.logWarning("No child nodes found.", module); } if (this.isFromURL) { utilTimer.timerString("Finished file " + readerURL + " - Total Services: " + i + " FINISHED"); Debug.logImportant("Loaded " + i + " Service definitions from " + readerURL, module); } else { utilTimer.timerString("Finished document in " + handler + " - Total Services: " + i + " FINISHED"); if (Debug.importantOn()) { String resourceLocation = handler.getLocation(); try {
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -