All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.glassfish.embed.ScatteredArchive Maven / Gradle / Ivy

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright 1997-2008 Sun Microsystems, Inc. All rights reserved.
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License. You can obtain
 * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
 * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
 * Sun designates this particular file as subject to the "Classpath" exception
 * as provided by Sun in the GPL Version 2 section of the License file that
 * accompanied this code.  If applicable, add the following below the License
 * Header, with the fields enclosed by brackets [] replaced by your own
 * identifying information: "Portions Copyrighted [year]
 * [name of copyright owner]"
 *
 * Contributor(s):
 *
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 *
 */

package org.glassfish.embed;

import  com.sun.enterprise.util.ObjectAnalyzer;
import org.glassfish.embed.impl.ReadableArchiveAdapter;
import org.glassfish.api.deployment.archive.ReadableArchive;

import java.io.*;
import java.net.*;
import java.util.*;
import java.util.jar.Manifest;

/**
 * {@link ReadableArchive} representation of an application that
 * is not assembled into the canonical WAR/JAR/RAR format.
 *
 * @author Kohsuke Kawaguchi
 * @author Byron Nevins
 */

public class ScatteredArchive extends ReadableArchiveAdapter {
    /**
     *
     * @param name Application name. Among other things, this is used by default as the context path
     *      when you deploy this scattered war file.
     * @param resources Directory where static resources like JSPs live.  WEB-INF/web.xml may be hre as well.
     * @param webXml if null, defaults to {@code WEB-INF/web.xml} under {@code resources}.
     * @param classes A Collection of classpath URLs for this application
     */
    public ScatteredArchive(String name, File resources, File webXml, Collection classes) {
        this.name = name;
        this.resources = resources;
        if(webXml==null)
            webXml = new File(resources,"WEB-INF/web.xml");
        this.webXml = webXml;
        this.classpath = classes;
    }

    /**
     * Get the classpath URLs
     * @return A read-only copy of the classpath URL Collection
     */
    public Iterable getClassPath() {
        return Collections.unmodifiableCollection(classpath);
    }

    /**
     *
     * @return The resources directory
     */
    public File getResourcesDir() {
        return resources;
    }


    ///////////////////////////////////////////////////////////////////////////
    //////      public methods that implement the Archive interface
    ///////////////////////////////////////////////////////////////////////////

  /**
     * Returns the InputStream for the given entry name
     * The file name must be relative to the root of the module.
     *
     * @param name the file name relative to the root of the module.
     * @return the InputStream for the given entry name or null if not found.
     */
    
    public InputStream getEntry(String name) throws IOException {
        File f = getFile(name);
        if(f.exists())  return new FileInputStream(f);
        return null;
    }
   /**
     * Returns whether or not a file by that name exists
     * The file name must be relative to the root of the module.
     *
     * @param name the file name relative to the root of the module.
     * @return does the file exist?
     */

    public boolean exists(String name) throws IOException {
        return getFile(name).exists();
    }

   /**
     * Returns an enumeration of the module file entries.  All elements
     * in the enumeration are of type String.  Each String represents a
     * file name relative to the root of the module.
     * 

Currently under construction * @return an enumeration of the archive file entries. */ public Enumeration entries() { // TODO: abstraction breakage. We need file-level abstraction for archive // and then more structured abstraction. return EMPTY_ENUMERATOR; } /** * Returns the manifest information for this archive * @return the manifest info */ public Manifest getManifest() throws IOException { // TODO: we can support manifest. // for now I'm not doing this because it seems like the value of this is limited for webapps. return null; } /** * Returns the path used to create or open the underlying archive * *

* TODO: abstraction breakage: * Several callers, most notably {@link DeploymentContext#getSourceDir()} * implementation, assumes that this URI is an URL, and in fact file URL. * *

* If this needs to be URL, use of {@link URI} is misleading. And furthermore, * if its needs to be a file URL, this should be {@link File}. * * @return the path for this archive. */ public URI getURI() { return resources.toURI(); } /** * Returns the name of the archive. *

* Implementations should not return null. * @return the name of the archive */ public String getName() { return name; } /** * Returns an enumeration of the module file entries with the * specified prefix. All elements in the enumeration are of * type String. Each String represents a file name relative * to the root of the module. *

Currently Not Supported * @param prefix the prefix of entries to be included * @return an enumeration of the archive file entries. * @throws UnsupportedOperationException always */ public Enumeration entries(String s) { throw new UnsupportedOperationException(unsupported("entries(String)")); } public String toString() { return ObjectAnalyzer.toString(this); } /////////////////////////////////////////////////////////////////////////// ////// End of public API ////////////////////////////////// /////////////////////////////////////////////////////////////////////////// /** * Maps the resource within the war into physical file. * *

* This method creates an illusion that we actually have a fully assembled war, * when in reality we don't. The illusion is partial because we can't * emulate WEB-INF/classes and WEB-INF/lib. * * @param name Relative path from within the canonical war format. * @return concrete location. */ private File getFile(String name) { if(name.equals("WEB-INF/web.xml")) return webXml; return new File(resources, name); } private String unsupported(String s) { s = getClass().getName() + "." + s; s += " is not supported yet."; return s; } /////////////////////////////////////////////////////////////////////////// private final File resources; // Static resources, JSP, etc. private final File webXml; // Location of web.xml private final Collection classpath; // Classes and jar files private final String name; private static final Enumeration EMPTY_ENUMERATOR = new Vector().elements(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy