Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* JBoss, Home of Professional Open Source.
* Copyright 2010, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.as.server.deployment.module;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.lang.reflect.UndeclaredThrowableException;
import java.net.MalformedURLException;
import java.net.URL;
import java.security.CodeSource;
import java.security.PrivilegedAction;
import java.security.PrivilegedActionException;
import java.security.PrivilegedExceptionAction;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import java.util.jar.Manifest;
import org.jboss.as.server.ServerMessages;
import org.jboss.modules.AbstractResourceLoader;
import org.jboss.modules.ClassSpec;
import org.jboss.modules.IterableResourceLoader;
import org.jboss.modules.PackageSpec;
import org.jboss.modules.PathUtils;
import org.jboss.modules.Resource;
import org.jboss.modules.filter.PathFilter;
import org.jboss.modules.filter.PathFilters;
import org.jboss.vfs.VFS;
import org.jboss.vfs.VFSUtils;
import org.jboss.vfs.VirtualFile;
import org.jboss.vfs.VirtualFileFilter;
import org.jboss.vfs.VirtualFilePermission;
import org.jboss.vfs.VisitorAttributes;
import org.jboss.vfs.util.FilterVirtualFileVisitor;
import org.wildfly.security.manager.WildFlySecurityManager;
import static java.security.AccessController.doPrivileged;
/**
* Resource loader capable of loading resources from VFS archives.
*
* @author John Bailey
* @author [email protected]
*/
public class VFSResourceLoader extends AbstractResourceLoader implements IterableResourceLoader {
private final VirtualFile root;
private final String rootName;
private final Manifest manifest;
private final URL rootUrl;
/**
* Construct new instance.
*
* @param rootName The module root name
* @param root The root virtual file
* @throws IOException if the manifest could not be read or the root URL is invalid
*/
public VFSResourceLoader(final String rootName, final VirtualFile root) throws IOException {
this(rootName, root, false);
}
/**
* Construct new instance.
*
* @param rootName The module root name
* @param root The root virtual file
* @param usePhysicalCodeSource {@code true} to use the physical root URL for code sources, {@code false} to use the VFS URL
* @throws IOException if the manifest could not be read or the root URL is invalid
*/
public VFSResourceLoader(final String rootName, final VirtualFile root, final boolean usePhysicalCodeSource) throws IOException {
final SecurityManager sm = System.getSecurityManager();
final boolean checking = WildFlySecurityManager.isChecking();
if (checking) {
sm.checkPermission(new VirtualFilePermission(root.getPathName(), "read"));
}
this.root = root;
this.rootName = rootName;
try {
manifest = checking ? doPrivileged(new PrivilegedExceptionAction() {
public Manifest run() throws IOException {
return VFSUtils.getManifest(root);
}
}) : VFSUtils.getManifest(root);
} catch (PrivilegedActionException pe) {
try {
throw pe.getException();
} catch (IOException | RuntimeException e) {
throw e;
} catch (Exception e) {
throw new UndeclaredThrowableException(e);
}
}
rootUrl = usePhysicalCodeSource ? VFSUtils.getRootURL(root) : root.asFileURL();
}
/** {@inheritDoc} */
public ClassSpec getClassSpec(final String name) throws IOException {
try {
return doPrivileged(new PrivilegedExceptionAction() {
public ClassSpec run() throws Exception {
final VirtualFile file = root.getChild(name);
if (!file.exists()) {
return null;
}
final long size = file.getSize();
final ClassSpec spec = new ClassSpec();
synchronized (VFSResourceLoader.this) {
final InputStream is = file.openStream();
try {
if (size <= Integer.MAX_VALUE) {
final int castSize = (int) size;
byte[] bytes = new byte[castSize];
int a = 0, res;
while ((res = is.read(bytes, a, castSize - a)) > 0) {
a += res;
}
// consume remainder so that cert check doesn't fail in case of wonky JARs
while (is.read() != -1) {}
// done
is.close();
spec.setBytes(bytes);
spec.setCodeSource(new CodeSource(rootUrl, file.getCodeSigners()));
return spec;
} else {
throw ServerMessages.MESSAGES.resourceTooLarge();
}
} finally {
VFSUtils.safeClose(is);
}
}
}
});
} catch (PrivilegedActionException pe) {
try {
throw pe.getException();
} catch (IOException | Error | RuntimeException e) {
throw e;
} catch (Exception e) {
throw new UndeclaredThrowableException(e);
}
}
}
/** {@inheritDoc} */
public PackageSpec getPackageSpec(final String name) throws IOException {
return getPackageSpec(name, this.manifest, this.rootUrl);
}
/** {@inheritDoc} */
public String getLibrary(final String name) {
return null;
}
/** {@inheritDoc} */
public String getRootName() {
return rootName;
}
/** {@inheritDoc} */
public PathFilter getExportFilter() {
return PathFilters.acceptAll();
}
/** {@inheritDoc} */
public Resource getResource(final String name) {
return doPrivileged(new PrivilegedAction() {
public Resource run() {
try {
final VirtualFile file = root.getChild(PathUtils.canonicalize(name));
if (!file.exists()) {
return null;
}
return new VFSEntryResource(file.getPathNameRelativeTo(root), file, file.toURL());
} catch (MalformedURLException e) {
// must be invalid...? (todo: check this out)
return null;
}
}
});
}
/** {@inheritDoc} */
public Collection getPaths() {
final List index = new ArrayList();
// First check for an index file
final VirtualFile indexFile = VFS.getChild(root.getPathName() + ".index");
if (indexFile.exists()) {
try {
final BufferedReader r = new BufferedReader(new InputStreamReader(indexFile.openStream()));
try {
String s;
while ((s = r.readLine()) != null) {
index.add(s.trim());
}
return index;
} finally {
// if exception is thrown, undo index creation
r.close();
}
} catch (IOException e) {
index.clear();
}
}
FilterVirtualFileVisitor visitor = new FilterVirtualFileVisitor(new VirtualFileFilter() {
@Override
public boolean accepts(VirtualFile file) {
return file.isDirectory();
}
}, VisitorAttributes.RECURSE);
try {
root.visit(visitor);
} catch (IOException e) {
index.clear();
}
index.add("");
for (VirtualFile dir : visitor.getMatched()) {
index.add(dir.getPathNameRelativeTo(root));
}
return index;
}
@Override
public Iterator iterateResources(String startPath, boolean recursive) {
VirtualFile child = root.getChild(startPath);
if (startPath.length() > 1 && child == root) {
return Collections.emptySet().iterator();
}
VirtualFileFilter filter = new VirtualFileFilter() {
@Override
public boolean accepts(VirtualFile file) {
return file.isFile();
}
};
final Iterator children;
try {
children = (recursive ? child.getChildrenRecursively(filter) : child.getChildren(filter)).iterator();
} catch (IOException ex) {
throw new IllegalStateException(ex);
}
return new Iterator() {
@Override
public boolean hasNext() {
return children.hasNext();
}
@Override
public Resource next() {
VirtualFile file = children.next();
URL fileURL;
try {
fileURL = file.toURL();
} catch (MalformedURLException ex) {
throw new IllegalStateException(ex);
}
return new VFSEntryResource(file.getPathNameRelativeTo(root), file, fileURL);
}
@Override
public void remove() {
throw new UnsupportedOperationException();
}
};
}
static class VFSEntryResource implements Resource {
private final String name;
private final VirtualFile entry;
private final URL resourceURL;
VFSEntryResource(final String name, final VirtualFile entry, final URL resourceURL) {
this.name = name;
this.entry = entry;
this.resourceURL = resourceURL;
}
public String getName() {
return name;
}
public URL getURL() {
return resourceURL;
}
public InputStream openStream() throws IOException {
return entry.openStream();
}
public long getSize() {
final long size = entry.getSize();
return size == -1 ? 0 : size;
}
}
}