/* * Copyright (c) 2009 Lockheed Martin Corporation * * 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.eurekastreams.server.service.actions.strategies; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.w3c.dom.Document; /** * Document creator, used by AddThemeAction. */ public class DocumentCreator { /** * Logger. */ private Log log = LogFactory.getLog(DocumentCreator.class); /** * Fetcher for the XML theme definition. */ private ResourceFetcher xmlFetcher = null; /** * Constructor. * * @param inXMLFetcher * a Strategy that will provide the source XML */ public DocumentCreator(final ResourceFetcher inXMLFetcher) { xmlFetcher = inXMLFetcher; } /** * Given a file name, returns an xml document. * * @param inFileName * the name of the file * @return an xml document. * @throws Exception * Thrown when cannot parse the xml file. */ public Document execute(final String inFileName) throws Exception { DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = dbf.newDocumentBuilder(); log.info("Fetching and parsing input stream from " + inFileName); return db.parse(xmlFetcher.getInputStream(inFileName)); } }