⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 modelservicereader.java

📁 Sequoia ERP是一个真正的企业级开源ERP解决方案。它提供的模块包括:电子商务应用(e-commerce), POS系统(point of sales),知识管理,存货与仓库管理
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/*  * $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 + -