package mircoders.servlet;
+import java.io.BufferedReader;
+import java.io.BufferedWriter;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.FilenameFilter;
-import java.io.StringReader;
import java.io.StringWriter;
+import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
-import java.util.Vector;
+
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import mir.servlet.ServletModule;
import mir.servlet.ServletModuleExc;
import mir.servlet.ServletModuleFailure;
-import mir.util.FileFunctions;
+import mir.util.FileRoutines;
import mir.util.HTTPRequestParser;
import mir.util.StringRoutines;
import mir.util.URLBuilder;
* in the config file.
*
* @author $Author: zapata $
- * @version $Revision: 1.13 $ $Date: 2003/05/08 02:43:42 $
+ * @version $Revision: 1.13.2.10 $ $Date: 2005/08/21 17:09:24 $
*
*/
private class FileEditDirectory {
private String name;
- private FileFunctions.RegExpFileFilter filter;
+ private FileRoutines.RegExpFileFilter filter;
private File rootDirectory;
private boolean recursive;
public FileEditDirectory(String aName, String aRootDirectory, String aFilter, boolean aRecursive) {
name = aName;
rootDirectory = new File(aRootDirectory);
- filter = new FileFunctions.RegExpFileFilter(aFilter);
+ filter = new FileRoutines.RegExpFileFilter(aFilter);
recursive = aRecursive;
}
return name;
}
- public FileFunctions.RegExpFileFilter getFilter() {
+ public FileRoutines.RegExpFileFilter getFilter() {
return filter;
}
logger = new LoggerWrapper("ServletModule.FileEdit");
directories = new HashMap();
- directoryNames = new Vector();
+ directoryNames = new ArrayList();
String settings[] = configuration.getStringArray("ServletModule.FileEdit.Configuration");
String setting = settings[i].trim();
if (setting.length() > 0) {
- List parts = StringRoutines.splitString(setting, ":");
+ List parts = StringRoutines.splitStringWithEscape(setting, ':', '\\');
if (parts.size() != 4) {
logger.error("config error: " + settings[i] + ", 4 parts expected");
}
}
}
- dirFilter = new FileFunctions.DirectoryFilter();
-
- templateListString =configuration.getString("ServletModule.FileEdit.ListTemplate");
- templateObjektString =configuration.getString("ServletModule.FileEdit.ObjektTemplate");
- templateConfirmString =configuration.getString("ServletModule.FileEdit.ConfirmTemplate");
+ dirFilter = new FileRoutines.DirectoryFilter();
}
public List getEntries() {
}
}
+ /**
+ * Called when an edited file is saved by the user
+ */
public void update(HttpServletRequest aRequest, HttpServletResponse aResponse) throws ServletModuleExc
{
HTTPRequestParser requestParser = new HTTPRequestParser(aRequest);
String filename = requestParser.getParameter("filename");
String subDirectory = requestParser.getParameter("subdirectory");
- String text = requestParser.getParameter("text");
+ String text =
+ StringRoutines.performRegularExpressionReplacement(
+ requestParser.getParameter("text"),
+ "\r\n",
+ System.getProperty("line.separator"));
FileEditDirectory directory = getDirectory(aRequest);
try {
File f = new File(new File(directory.getRootDirectory(), subDirectory), filename);
if (validateDirectory(directory, f)) {
- StringReader in = new StringReader(text);
FileWriter out = new FileWriter(f);
+ try {
+ out.write(text.toCharArray());
+ }
+ finally {
+ out.close();
+ }
- int c;
- while ( (c = in.read()) != -1)
- out.write(c);
- in.close();
- out.close();
-
+ logAdminUsage(aRequest, f.getAbsolutePath(), "object modified");
+/*
+ MirGlobal.getChangeEngine().getTracker().addChange(f.getCanonicalPath());
+*/
editFile(directory, filename, subDirectory, aRequest, aResponse);
}
}
public void listSubDirectory(FileEditDirectory aDirectory, String aSubDirectory, HttpServletRequest aRequest, HttpServletResponse aResponse) throws ServletModuleExc
{
try {
- Map responseData = ServletHelper.makeGenerationData(aResponse, new Locale[] { getLocale(aRequest), getFallbackLocale(aRequest)});
+ Map responseData = ServletHelper.makeGenerationData(aRequest, aResponse, new Locale[] { getLocale(aRequest), getFallbackLocale(aRequest)});
File dir = new File(aDirectory.getRootDirectory(), aSubDirectory);
if (!validateDirectory(aDirectory, dir) || !dir.isDirectory()) {
aSubDirectory = "";
}
- responseData.put("filelist", FileFunctions.getDirectoryContentsAsList(dir, aDirectory.getFilter()));
+ responseData.put("filelist", FileRoutines.getDirectoryContentsAsList(dir, aDirectory.getFilter()));
if (aDirectory.getRecursive()) {
- List dirs = new Vector();
+ List dirs = new ArrayList();
if (!dir.getCanonicalPath().equals(aDirectory.getRootDirectory().getCanonicalPath()))
responseData.put("updir", new File(aSubDirectory).getParent());
- dirs.addAll(FileFunctions.getDirectoryContentsAsList(dir, dirFilter));
+ dirs.addAll(FileRoutines.getDirectoryContentsAsList(dir, dirFilter));
responseData.put("dirlist", dirs);
}
responseData.put("subdirectory", aSubDirectory);
responseData.put("entry", aDirectory.getName());
- ServletHelper.generateResponse(aResponse.getWriter(), responseData, templateListString);
+ ServletHelper.generateResponse(aResponse.getWriter(), responseData, listGenerator);
}
catch (Throwable e) {
throw new ServletModuleFailure(e);
}
}
- public void editFile(FileEditDirectory aDirectory, String aFileName, String aSubDirectory, HttpServletRequest aRequest, HttpServletResponse aResponse) throws ServletModuleExc
- {
+ public void editFile(FileEditDirectory aDirectory, String aFileName, String aSubDirectory, HttpServletRequest aRequest, HttpServletResponse aResponse) throws ServletModuleExc {
try {
File f = new File(new File(aDirectory.getRootDirectory(), aSubDirectory), aFileName);
listSubDirectory(aDirectory, "", aRequest, aResponse);
}
else {
- Map responseData = ServletHelper.makeGenerationData(aResponse, new Locale[] { getLocale(aRequest), getFallbackLocale(aRequest)});
+ Map responseData = ServletHelper.makeGenerationData(aRequest, aResponse, new Locale[] { getLocale(aRequest), getFallbackLocale(aRequest)});
URLBuilder urlBuilder = new URLBuilder();
urlBuilder.setValue("module", "FileEdit");
urlBuilder.setValue("directory", "");
urlBuilder.setValue("subdirectory", aSubDirectory);
- FileReader in = new FileReader(f);
- StringWriter out = new StringWriter();
+ BufferedReader in = new BufferedReader(new FileReader(f));
+ StringWriter textout = new StringWriter();
+ BufferedWriter out = new BufferedWriter(textout);
- int c;
- while ( (c = in.read()) != -1)
- out.write(c);
+ // TODO read array
+ char[] c = new char[4096];
+ int read;
+ while ((read=in.read(c)) != -1) {
+ out.write(c, 0, read);
+ }
in.close();
out.close();
responseData.put("entry", aDirectory.getName());
- responseData.put("text", out.toString());
+ responseData.put("text", textout.toString());
responseData.put("filename", aFileName);
responseData.put("subdirectory", aSubDirectory);
responseData.put("returnurl", urlBuilder.getQuery());
- ServletHelper.generateResponse(aResponse.getWriter(), responseData, templateObjektString);
+ ServletHelper.generateResponse(aResponse.getWriter(), responseData, editGenerator);
}
}
catch (Throwable e) {