diff src/luan/webserver/handlers/FileHandler.java @ 1167:7e6f28c769a1

better handlers
author Franklin Schmidt <fschmidt@gmail.com>
date Thu, 08 Feb 2018 19:06:31 -0700
parents 668f29bc52ea
children 312e4cadd508
line wrap: on
line diff
--- a/src/luan/webserver/handlers/FileHandler.java	Thu Feb 08 02:22:51 2018 -0700
+++ b/src/luan/webserver/handlers/FileHandler.java	Thu Feb 08 19:06:31 2018 -0700
@@ -14,9 +14,8 @@
 import luan.webserver.ResponseOutputStream;
 
 
-public final class FileHandler implements Handler {
-	public boolean showDirs = true;
-	private final File dir;
+public class FileHandler implements Handler {
+	final File dir;
 
 	public FileHandler() {
 		this(".");
@@ -35,40 +34,18 @@
 	public Response handle(Request request) {
 		try {
 			File file = new File(dir,request.path);
-			if( file.isFile() ) {
-				Response response = new Response();
-				response.body = new Response.Body( file.length(), new FileInputStream(file) );
-				return response;
-			}
-			if( request.path.endsWith("/") && file.isDirectory() && showDirs ) {
-				DateFormat fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss zzz");
-				Response response = new Response();
-				response.headers.put( "content-type", "text/html; charset=utf-8" );
-				Writer writer = new OutputStreamWriter( new ResponseOutputStream(response) );
-				writer.write( "<!doctype html><html>" );
-				writer.write( "<head><style>td{padding: 2px 8px}</style></head>" );
-				writer.write( "<body>" );
-				writer.write( "<h1>Directory: "+request.path+"</h1>" );
-				writer.write( "<table border=0>" );
-				for( File child : file.listFiles() ) {
-					String name = child.getName();
-					if( child.isDirectory() )
-						name += '/';
-					writer.write( "<tr>" );
-					writer.write( "<td><a href='"+name+"'>"+name+"</a></td>" );
-					writer.write( "<td>"+child.length()+" bytes</td>" );
-					writer.write( "<td>"+fmt.format(new Date(child.lastModified()))+"</td>" );
-					writer.write( "</tr>" );
-				}
-				writer.write( "</table>" );
-				writer.write( "</body>" );
-				writer.write( "</html>" );
-				writer.close();
-				return response;
-			}
-			return null;
+			return handle(request,file);
 		} catch(IOException e) {
 			throw new RuntimeException(e);
 		}
 	}
+
+	Response handle(Request request,File file) throws IOException {
+		if( file.isFile() ) {
+			Response response = new Response();
+			response.body = new Response.Body( file.length(), new FileInputStream(file) );
+			return response;
+		}
+		return null;
+	}
 }