oracle.toplink.essentials.ejb.cmp3.persistence.DirectoryInsideJarURLArchive Maven / Gradle / Ivy
/*
* The contents of this file are subject to the terms
* of the Common Development and Distribution License
* (the "License"). You may not use this file except
* in compliance with the License.
*
* You can obtain a copy of the license at
* glassfish/bootstrap/legal/CDDLv1.0.txt or
* https://glassfish.dev.java.net/public/CDDLv1.0.html.
* See the License for the specific language governing
* permissions and limitations under the License.
*
* When distributing Covered Code, include this CDDL
* HEADER in each file and include the License file at
* glassfish/bootstrap/legal/CDDLv1.0.txt. If applicable,
* add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your
* own identifying information: Portions Copyright [yyyy]
* [name of copyright owner]
*
* Copyright 2006 Sun Microsystems, Inc. All rights reserved.
*/
package oracle.toplink.essentials.ejb.cmp3.persistence;
import java.net.URL;
import java.net.JarURLConnection;
import java.util.List;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.Iterator;
import java.util.logging.Logger;
import java.util.logging.Level;
import java.util.jar.JarFile;
import java.util.jar.JarEntry;
import java.io.IOException;
import java.io.InputStream;
/**
* This is an implementation of {@link Archive} which is used when container
* returns a jar: URL. e.g. jar:file:/tmp/a_ear/b.war!/WEB-INF/classes/
*
* @author [email protected]
*/
public class DirectoryInsideJarURLArchive implements Archive {
/*
* Implementation Note: This class does not have any dependency on TopLink
* or GlassFish implementation classes. Please retain this searation.
*/
private JarFile jarFile;
// URL representation of this archive
private URL rootURL;
// distance from top of the JarFile to the entry
private String relativeRootPath;
private List entries = new ArrayList();
private Logger logger;
public DirectoryInsideJarURLArchive(URL url) throws IOException {
this(url, Logger.global);
}
public DirectoryInsideJarURLArchive(URL url, Logger logger)
throws IOException {
logger.entering("DirectoryInsideJarURLArchive", "DirectoryInsideJarURLArchive", // NOI18N
new Object[]{url});
this.logger = logger;
assert(url.getProtocol().equals("jar")); // NOI18N
rootURL = url;
JarURLConnection conn =
JarURLConnection.class.cast(url.openConnection());
jarFile = conn.getJarFile();
logger.logp(Level.FINER, "DirectoryInsideJarURLArchive",
"DirectoryInsideJarURLArchive", "jarFile = {0}", jarFile);
relativeRootPath = conn.getEntryName();
init();
}
private void init() {
for(Enumeration jarEntries = jarFile.entries();
jarEntries.hasMoreElements();) {
JarEntry jarEntry = jarEntries.nextElement();
if(jarEntry.isDirectory()) {
continue;
}
String jarEntryName = jarEntry.getName();
if (relativeRootPath==null) {
entries.add(jarEntryName);
} else if (jarEntryName.startsWith(relativeRootPath)) {
entries.add(jarEntryName.substring(relativeRootPath.length()));
}
}
}
public Iterator getEntries() {
return entries.iterator();
}
public InputStream getEntry(String entryPath) throws IOException {
InputStream is = entries.contains(entryPath) ?
jarFile.getInputStream(jarFile.getEntry(relativeRootPath + entryPath)) : null;
return is;
}
public URL getEntryAsURL(String entryPath) throws IOException {
URL result = entries.contains(entryPath) ?
new URL("jar:"+rootURL+"!/"+ relativeRootPath + entryPath) : null; // NOI18N
return result;
}
public URL getRootURL() {
return rootURL;
}
}