package org.jboss.services.deployment;
import java.io.File;
import java.io.IOException;
import java.net.URL;
import org.jboss.logging.Logger;
import org.jboss.system.server.ServerConfig;
import org.jboss.system.server.ServerConfigLocator;
import org.jboss.util.file.Files;
public final class LibraryManager
{
private static final Logger log = Logger.getLogger(LibraryManager.class);
private static final LibraryManager INSTANCE = new LibraryManager();
File serverLibDir;
File serverTmpDir;
private LibraryManager()
{
ServerConfig config = ServerConfigLocator.locate();
URL serverLibURL = config.getServerLibraryURL();
if (serverLibURL != null && serverLibURL.getProtocol().startsWith("file"))
{
this.serverLibDir = new File(serverLibURL.getFile());
this.serverTmpDir = config.getServerTempDir();
log.debug("Using serverLibDir: " + this.serverLibDir);
log.debug("Using serverTmpDir: " + this.serverTmpDir);
}
else
{
log.info("Cannot manage remote serverLibraryURL: " + serverLibURL);
}
}
public static LibraryManager getInstance()
{
return INSTANCE;
}
public boolean uploadLibrary(URL src, String filename)
{
if (src != null)
{
log.debug("Uploading from URL: " + src);
if (filename == null || filename.equals(""))
{
filename = (new File(src.getPath())).getName();
log.debug("Null or empty target filename, using basename: " + filename);
}
else
{
log.debug("Using target filename: " + filename);
}
File target = new File(this.serverLibDir, filename);
if (!target.exists())
{
try
{
Files.copy(src, target);
return true; }
catch (IOException e)
{
log.warn("Could not upload target library: " + filename, e);
}
}
else
{
log.warn("Target library exists: " + filename);
}
}
else
{
log.warn("Null src URL");
}
return false;
}
}