annotate src/luan/modules/http/LuanHandler.java @ 1615:38894708bade

better init.luan exception handling
author Franklin Schmidt <fschmidt@gmail.com>
date Thu, 03 Jun 2021 18:00:49 -0600
parents 9303bacae890
children a37ffe2d1b14
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;
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
118 if( request.path.endsWith("/") )
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
119 return null;
1383
a3d0d1c2ce89 add NotFound to luanhost
Franklin Schmidt <fschmidt@gmail.com>
parents: 1375
diff changeset
120 return handle( request, request.headers.containsKey(NOT_FOUND) );
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
121 }
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
122
1383
a3d0d1c2ce89 add NotFound to luanhost
Franklin Schmidt <fschmidt@gmail.com>
parents: 1375
diff changeset
123 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
124 Thread thread = Thread.currentThread();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
125 String oldName = thread.getName();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
126 thread.setName(request.headers.get("host")+request.path);
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
127 rwLock.readLock().lock();
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
128 LuanLogger.startThreadLogging(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
129 try {
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
130 init(currentLuan);
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
131 return service(request,notFound);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
132 } catch(LuanException e) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
133 String err = e.getLuanStackTraceString();
1615
38894708bade better init.luan exception handling
Franklin Schmidt <fschmidt@gmail.com>
parents: 1592
diff changeset
134 //System.err.println(err);
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
135 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
136 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
137 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
138 } finally {
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
139 LuanLogger.endThreadLogging();
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
140 rwLock.readLock().unlock();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
141 thread.setName(oldName);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
142 }
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
1231
0b75337bb91a better closing
Franklin Schmidt <fschmidt@gmail.com>
parents: 1223
diff changeset
145 public void close() {
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
146 Object obj = dontGc.remove(this);
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
147 //logger.info("close "+domain+" "+(obj!=null));
517
8dcf9e12446b add Luan.on_luan_close()
Franklin Schmidt <fschmidt@gmail.com>
parents: 494
diff changeset
148 }
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
149
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
150 public Object call_rpc(String fnName,Object... args) throws LuanException {
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
151 rwLock.readLock().lock();
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
152 LuanLogger.startThreadLogging(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
153 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
154 LuanFunction fn;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
155 Luan luan;
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
156 synchronized(currentLuan) {
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
157 LuanTable rpc = (LuanTable)currentLuan.require("luan:Rpc.luan");
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
158 LuanTable fns = (LuanTable)rpc.get(currentLuan,"functions");
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
159 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
160 if( fn == null )
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
161 throw new LuanException( "function not found: " + fnName );
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
162 luan = new Luan(currentLuan);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
163 }
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
164 return fn.call(luan,args);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
165 } finally {
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
166 LuanLogger.endThreadLogging();
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
167 rwLock.readLock().unlock();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
168 }
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
169 }
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
170
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
171 public static void start(Server server) throws Exception {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
172 try {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
173 server.start();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
174 } catch(BindException e) {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
175 throw new LuanException(e.toString());
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
176 }
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 private void reset_luan() {
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
180 new Thread() {public void run(){
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
181 rwLock.writeLock().lock();
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
182 try {
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
183 close();
1592
9303bacae890 remember init.luan exception
Franklin Schmidt <fschmidt@gmail.com>
parents: 1580
diff changeset
184 newLuan();
1360
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
185 } finally {
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
186 rwLock.writeLock().unlock();
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
187 }
ee0f0e6c89a0 fix reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1359
diff changeset
188 }}.start();
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
189 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
190
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
191 private void disable_luan() {
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
192 isDisabled = true;
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
193 }
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
194
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
195 private void eval_in_root(String text) throws LuanException {
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
196 synchronized(currentLuan) {
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
197 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
198 }
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
199 }
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
200
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
201 private void dont_gc() {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
202 dontGc.add(this);
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1434
diff changeset
203 //logger.info("dont_gc "+domain);
1401
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
204 }
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 public static final class Fns {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
207 private final Reference<LuanHandler> ref;
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
208
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
209 private Fns(LuanHandler lh) {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
210 this.ref = new WeakReference<LuanHandler>(lh);
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
211 }
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 private LuanHandler lh() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
214 LuanHandler lh = ref.get();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
215 if( lh == null )
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
216 throw new LuanException("HTTP handler has been garbage collected");
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
217 return lh;
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
218 }
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 public void reset_luan() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
221 lh().reset_luan();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
222 }
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 public void disable_luan() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
225 lh().disable_luan();
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
226 }
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 public void eval_in_root(String text) throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
229 lh().eval_in_root(text);
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
230 }
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 public void dont_gc() throws LuanException {
ef1620aa99cb fix gc issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
233 lh().dont_gc();
1004
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
234 }
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
235 }
1077
ca968ef1747a better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 800
diff changeset
236
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
237
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
238 // from HttpServicer
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
239
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
240 private Response service(Request request,boolean notFound)
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
241 throws LuanException
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
242 {
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
243 try {
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
244 if( !notFound )
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
245 return serviceLuan(request);
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
246 else
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
247 return serviceNotFound(request);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
248 } catch(LuanException e) {
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
249 return handleError(request,e);
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
250 }
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 private Response handleError(Request request,LuanException e)
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
254 throws LuanException
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
255 {
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
256 //e.printStackTrace();
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
257 Luan luan;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
258 synchronized(currentLuan) {
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
259 luan = new Luan(currentLuan);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
260 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
261 LuanTable module = (LuanTable)luan.require("luan:http/Http.luan");
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
262 return (Response)module.fn("handle_error").call( luan, request, e.table(luan) );
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
263 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
264
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
265 private Response serviceLuan(Request request)
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
266 throws LuanException
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
267 {
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
268 String modName = "site:" + request.path +".luan";
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
269 LuanFunction fn;
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
270 Luan luan;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
271 synchronized(currentLuan) {
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
272 currentLuan.require("luan:http/Http.luan");
1580
2975c932864d require options
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
273 Object mod = PackageLuan.load(currentLuan,modName,null);
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
274 if( mod.equals(Boolean.FALSE) )
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
275 return null;
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
276 if( !(mod instanceof LuanFunction) )
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
277 throw new LuanException( "module '"+modName+"' must return a function" );
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
278 luan = new Luan(currentLuan);
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
279 fn = (LuanFunction)mod;
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
280 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
281 LuanTable module = (LuanTable)luan.require("luan:http/Http.luan");
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
282 module.fn("new_request").call(luan,request);
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
283 module.fn("new_response").call(luan);
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
284 fn.call(luan);
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
285 return (Response)module.fn("finish").call(luan);
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
286 }
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
287
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
288 private Response serviceNotFound(Request request)
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
289 throws LuanException
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
290 {
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
291 LuanFunction fn;
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
292 Luan luan;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
293 synchronized(currentLuan) {
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
294 LuanTable module = (LuanTable)currentLuan.require("luan:http/Http.luan");
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
295 fn = module.fn("not_found_handler");
1359
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
296 if( fn == null )
Franklin Schmidt <fschmidt@gmail.com>
parents: 1358
diff changeset
297 return null;
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
298 luan = new Luan(currentLuan);
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
299 }
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
300 LuanTable module = (LuanTable)luan.require("luan:http/Http.luan");
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
301 module.fn("new_request").call(luan,request);
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
302 module.fn("new_response").call(luan);
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
303 Object obj = Luan.first(fn.call(luan));
1358
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
304 if( !(obj instanceof Boolean) )
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
305 throw new LuanException("not_found_handler must return boolean");
1d31c1f3ea30 better not_found_handler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1351
diff changeset
306 boolean handled = (Boolean)obj;
1563
8fbcc4747091 remove LuanFunction.luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1562
diff changeset
307 return handled ? (Response)module.fn("finish").call(luan) : null;
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
308 }
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
309
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
310 }