annotate src/luan/modules/http/LuanHandler.java @ 1643:8d751af51b9d

fix not_found_hander
author Franklin Schmidt <fschmidt@gmail.com>
date Sun, 02 Jan 2022 00:42:58 -0700
parents a37ffe2d1b14
children 5c676385284b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1171
794ddcfbee20 remove http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1170
diff changeset
1 package luan.modules.http;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
2
1231
0b75337bb91a better closing
Franklin Schmidt <fschmidt@gmail.com>
parents: 1223
diff changeset
3 import java.io.Closeable;
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
4 import java.io.Writer;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
5 import java.io.PrintWriter;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
6 import java.io.IOException;
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
7 import java.lang.ref.Reference;
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
8 import java.lang.ref.WeakReference;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
9 import java.lang.reflect.Method;
1004
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
10 import java.net.BindException;
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
11 import java.util.List;
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
12 import java.util.ArrayList;
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
13 import java.util.Set;
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
14 import java.util.Collections;
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
15 import java.util.concurrent.ConcurrentHashMap;
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
16 import java.util.concurrent.locks.ReadWriteLock;
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
17 import java.util.concurrent.locks.ReentrantReadWriteLock;
1402
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
18 import goodjava.logging.Logger;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
19 import goodjava.logging.LoggerFactory;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
20 import goodjava.webserver.Request;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
21 import goodjava.webserver.Response;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
22 import goodjava.webserver.Status;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
23 import goodjava.webserver.Server;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
24 import goodjava.webserver.Handler;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1401
diff changeset
25 import goodjava.webserver.ResponseOutputStream;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
26 import luan.Luan;
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
27 import luan.LuanTable;
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
28 import luan.LuanFunction;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
29 import luan.LuanJavaFunction;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
30 import luan.LuanException;
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
31 import luan.modules.PackageLuan;
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
32 import luan.modules.BasicLuan;
1321
307e76ccd0d6 generalize separate logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1319
diff changeset
33 import luan.modules.logging.LuanLogger;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
34
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
35
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
36 public final class LuanHandler implements Handler, Closeable {
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
37 private static final Logger logger = LoggerFactory.getLogger(LuanHandler.class);
1400
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
38
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
39 private static final Set<LuanHandler> dontGc = Collections.newSetFromMap(new ConcurrentHashMap<LuanHandler,Boolean>());
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
40
1333
25746915a241 merge Luan and LuanState
Franklin Schmidt <fschmidt@gmail.com>
parents: 1332
diff changeset
41 private final Luan luanInit;
1400
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
42 private final String domain;
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
43 private final ReadWriteLock rwLock = new ReentrantReadWriteLock();
1333
25746915a241 merge Luan and LuanState
Franklin Schmidt <fschmidt@gmail.com>
parents: 1332
diff changeset
44 private volatile Luan currentLuan;
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
45 private volatile boolean isDisabled = false;
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
46 private volatile boolean didInit;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
47
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
48 private static final Method resetLuanMethod;
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
49 private static final Method evalInRootMethod;
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
50 private static final Method disableLuanMethod;
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
51 private static final Method dontGcMethod;
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
52 static {
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
53 try {
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
54 resetLuanMethod = LuanHandler.Fns.class.getMethod( "reset_luan" );
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
55 evalInRootMethod = LuanHandler.Fns.class.getMethod( "eval_in_root", String.class );
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
56 disableLuanMethod = LuanHandler.Fns.class.getMethod( "disable_luan" );
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
57 dontGcMethod = LuanHandler.Fns.class.getMethod( "dont_gc" );
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
58 } catch(NoSuchMethodException e) {
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
59 throw new RuntimeException(e);
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
60 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
61 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
62
1400
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
63 public LuanHandler(Luan luanInit,String domain) {
1231
0b75337bb91a better closing
Franklin Schmidt <fschmidt@gmail.com>
parents: 1223
diff changeset
64 this.luanInit = luanInit;
1400
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
65 this.domain = domain;
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
66 try {
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
67 Fns fns = new Fns(this);
1283
503bde9a7c80 add luan.require() and table.call()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1267
diff changeset
68 LuanTable Http = (LuanTable)luanInit.require("luan:http/Http.luan");
1562
b89212fd04b5 remove table.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
69 if( Http.get(luanInit,"reset_luan") == null )
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
70 Http.put( luanInit, "reset_luan", new LuanJavaFunction(resetLuanMethod,fns) );
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
71 Http.put( luanInit, "eval_in_root", new LuanJavaFunction(evalInRootMethod,fns) );
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
72 Http.put( luanInit, "disable_luan", new LuanJavaFunction(disableLuanMethod,fns) );
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
73 Http.put( luanInit, "dont_gc", new LuanJavaFunction(dontGcMethod,fns) );
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
74 } catch(LuanException e) {
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
75 throw new RuntimeException(e);
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
76 }
1411
Franklin Schmidt <fschmidt@gmail.com>
parents: 1402
diff changeset
77 if( domain != null )
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
78 logger.info("new "+domain);
1592
9303bacae890 remember init.luan exception
Franklin Schmidt <fschmidt@gmail.com>
parents: 1580
diff changeset
79 newLuan();
1400
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
80 }
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
81
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1397
diff changeset
82 protected void finalize() throws Throwable {
1411
Franklin Schmidt <fschmidt@gmail.com>
parents: 1402
diff changeset
83 if( domain != null )
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
84 logger.info("gc "+domain);
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
85 }
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
86
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
87 private void init(Luan luan) throws LuanException {
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
88 if( didInit )
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
89 return;
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
90 PackageLuan.load(luan,"site:/init.luan",null);
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
91 didInit = true;
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
92 }
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
93
1592
9303bacae890 remember init.luan exception
Franklin Schmidt <fschmidt@gmail.com>
parents: 1580
diff changeset
94 private void newLuan() {
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
95 Luan luan;
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
96 synchronized(luanInit) {
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
97 luan = new Luan(luanInit);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
98 }
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
99 didInit = false;
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
100 LuanLogger.startThreadLogging(luan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
101 try {
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
102 init(luan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
103 } catch(LuanException e) {
1321
307e76ccd0d6 generalize separate logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1319
diff changeset
104 //e.printStackTrace();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
105 String err = e.getLuanStackTraceString();
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
106 logger.error(err);
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
107 } finally {
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
108 LuanLogger.endThreadLogging();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
109 }
1592
9303bacae890 remember init.luan exception
Franklin Schmidt <fschmidt@gmail.com>
parents: 1580
diff changeset
110 currentLuan = luan;
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
111 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
112
1383
a3d0d1c2ce89 add NotFound to luanhost
Franklin Schmidt <fschmidt@gmail.com>
parents: 1375
diff changeset
113 static final String NOT_FOUND = "luan-not-found";
a3d0d1c2ce89 add NotFound to luanhost
Franklin Schmidt <fschmidt@gmail.com>
parents: 1375
diff changeset
114
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
115 @Override public Response handle(Request request) {
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
116 if( isDisabled )
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
117 return null;
1643
8d751af51b9d fix not_found_hander
Franklin Schmidt <fschmidt@gmail.com>
parents: 1618
diff changeset
118 boolean notFound = request.headers.containsKey(NOT_FOUND);
8d751af51b9d fix not_found_hander
Franklin Schmidt <fschmidt@gmail.com>
parents: 1618
diff changeset
119 if( !notFound && request.path.endsWith("/") )
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
120 return null;
1643
8d751af51b9d fix not_found_hander
Franklin Schmidt <fschmidt@gmail.com>
parents: 1618
diff changeset
121 return handle( request, notFound );
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
122 }
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
123
1383
a3d0d1c2ce89 add NotFound to luanhost
Franklin Schmidt <fschmidt@gmail.com>
parents: 1375
diff changeset
124 private Response handle(Request request,boolean notFound) {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
125 Thread thread = Thread.currentThread();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
126 String oldName = thread.getName();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
127 thread.setName(request.headers.get("host")+request.path);
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
128 rwLock.readLock().lock();
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
129 LuanLogger.startThreadLogging(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
130 try {
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
131 init(currentLuan);
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
132 return service(request,notFound);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
133 } catch(LuanException e) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
134 String err = e.getLuanStackTraceString();
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
135 //System.err.println(err);
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
136 logger.error(err+"\n"+request.rawHead.trim()+"\n");
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
137 String msg = "Internel Server Error\n\n" + err;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
138 return Response.errorResponse( Status.INTERNAL_SERVER_ERROR, msg );
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
139 } finally {
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
140 LuanLogger.endThreadLogging();
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
141 rwLock.readLock().unlock();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
142 thread.setName(oldName);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
143 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
144 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
145
1231
0b75337bb91a better closing
Franklin Schmidt <fschmidt@gmail.com>
parents: 1223
diff changeset
146 public void close() {
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
147 Object obj = dontGc.remove(this);
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
148 //logger.info("close "+domain+" "+(obj!=null));
517
8dcf9e12446b add Luan.on_luan_close()
Franklin Schmidt <fschmidt@gmail.com>
parents: 494
diff changeset
149 }
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
150
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
151 public Object call_rpc(String fnName,Object... args) throws LuanException {
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
152 rwLock.readLock().lock();
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
153 LuanLogger.startThreadLogging(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
154 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
155 LuanFunction fn;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
156 Luan luan;
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
157 synchronized(currentLuan) {
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
158 LuanTable rpc = (LuanTable)currentLuan.require("luan:Rpc.luan");
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
159 LuanTable fns = (LuanTable)rpc.get(currentLuan,"functions");
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
160 fn = (LuanFunction)fns.get(currentLuan,fnName);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
161 if( fn == null )
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
162 throw new LuanException( "function not found: " + fnName );
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
163 luan = new Luan(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
164 }
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
165 return fn.call(luan,args);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
166 } finally {
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
167 LuanLogger.endThreadLogging();
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
168 rwLock.readLock().unlock();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
169 }
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
170 }
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
171
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
172 public static void start(Server server) throws Exception {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
173 try {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
174 server.start();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
175 } catch(BindException e) {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
176 throw new LuanException(e.toString());
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
177 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
178 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
179
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
180 private void reset_luan() {
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
181 new Thread() {public void run(){
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
182 rwLock.writeLock().lock();
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
183 try {
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
184 close();
1592
9303bacae890 remember init.luan exception
Franklin Schmidt <fschmidt@gmail.com>
parents: 1580
diff changeset
185 newLuan();
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
186 } finally {
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
187 rwLock.writeLock().unlock();
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
188 }
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
189 }}.start();
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
190 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
191
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
192 private void disable_luan() {
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
193 isDisabled = true;
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
194 }
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
195
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
196 private void eval_in_root(String text) throws LuanException {
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
197 synchronized(currentLuan) {
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
198 currentLuan.load(text,"<eval_in_root>",false,null).call(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
199 }
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
200 }
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
201
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
202 private void dont_gc() {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
203 dontGc.add(this);
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
204 //logger.info("dont_gc "+domain);
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
205 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
206
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
207 public static final class Fns {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
208 private final Reference<LuanHandler> ref;
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
209
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
210 private Fns(LuanHandler lh) {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
211 this.ref = new WeakReference<LuanHandler>(lh);
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
212 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
213
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
214 private LuanHandler lh() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
215 LuanHandler lh = ref.get();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
216 if( lh == null )
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
217 throw new LuanException("HTTP handler has been garbage collected");
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
218 return lh;
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
219 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
220
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
221 public void reset_luan() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
222 lh().reset_luan();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
223 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
224
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
225 public void disable_luan() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
226 lh().disable_luan();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
227 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
228
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
229 public void eval_in_root(String text) throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
230 lh().eval_in_root(text);
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
231 }
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
232
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
233 public void dont_gc() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
234 lh().dont_gc();
1004
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
235 }
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
236 }
1077
ca968ef1747a better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 800
diff changeset
237
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
238
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
239 // from HttpServicer
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
240
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
241 private Response service(Request request,boolean notFound)
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
242 throws LuanException
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
243 {
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
244 try {
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
245 if( !notFound )
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
246 return serviceLuan(request);
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
247 else
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
248 return serviceNotFound(request);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
249 } catch(LuanException e) {
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
250 return handleError(request,e);
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
251 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
252 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
253
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
254 private Response handleError(Request request,LuanException e)
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
255 throws LuanException
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
256 {
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
257 //e.printStackTrace();
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
258 Luan luan;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
259 synchronized(currentLuan) {
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
260 luan = new Luan(currentLuan);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
261 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
262 LuanTable module = (LuanTable)luan.require("luan:http/Http.luan");
1618
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
263 return (Response)module.fn(luan,"handle_error").call( luan, request, e.table(luan) );
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
264 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
265
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
266 private Response serviceLuan(Request request)
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
267 throws LuanException
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
268 {
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
269 String modName = "site:" + request.path +".luan";
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
270 LuanFunction fn;
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
271 Luan luan;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
272 synchronized(currentLuan) {
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
273 currentLuan.require("luan:http/Http.luan");
1580
2975c932864d require options
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
274 Object mod = PackageLuan.load(currentLuan,modName,null);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
275 if( mod.equals(Boolean.FALSE) )
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
276 return null;
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
277 if( !(mod instanceof LuanFunction) )
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
278 throw new LuanException( "module '"+modName+"' must return a function" );
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
279 luan = new Luan(currentLuan);
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
280 fn = (LuanFunction)mod;
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
281 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
282 LuanTable module = (LuanTable)luan.require("luan:http/Http.luan");
1618
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
283 module.fn(luan,"new_request").call(luan,request);
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
284 module.fn(luan,"new_response").call(luan);
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
285 fn.call(luan);
1618
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
286 return (Response)module.fn(luan,"finish").call(luan);
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
287 }
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
288
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
289 private Response serviceNotFound(Request request)
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
290 throws LuanException
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
291 {
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
292 LuanFunction fn;
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
293 Luan luan;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
294 synchronized(currentLuan) {
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
295 LuanTable module = (LuanTable)currentLuan.require("luan:http/Http.luan");
1618
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
296 fn = module.fn(currentLuan,"not_found_handler");
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
297 if( fn == null )
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
298 return null;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
299 luan = new Luan(currentLuan);
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
300 }
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
301 LuanTable module = (LuanTable)luan.require("luan:http/Http.luan");
1618
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
302 module.fn(luan,"new_request").call(luan,request);
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
303 module.fn(luan,"new_response").call(luan);
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
304 Object obj = Luan.first(fn.call(luan));
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
305 if( !(obj instanceof Boolean) )
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
306 throw new LuanException("not_found_handler must return boolean");
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
307 boolean handled = (Boolean)obj;
1618
a37ffe2d1b14 fix not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1615
diff changeset
308 return handled ? (Response)module.fn(luan,"finish").call(luan) : null;
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
309 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
310
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
311 }