annotate src/luan/modules/http/LuanHandler.java @ 1332:11b7e11f9ed5

cleaner logging
author Franklin Schmidt <fschmidt@gmail.com>
date Tue, 12 Feb 2019 21:50:26 -0700
parents 307e76ccd0d6
children 25746915a241
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;
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
13 import java.util.concurrent.locks.ReadWriteLock;
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
14 import java.util.concurrent.locks.ReentrantReadWriteLock;
1332
11b7e11f9ed5 cleaner logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
15 import org.slf4j.Logger;
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
16 import luan.webserver.Request;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
17 import luan.webserver.Response;
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
18 import luan.webserver.Status;
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
19 import luan.webserver.Server;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
20 import luan.webserver.Handler;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
21 import luan.webserver.ResponseOutputStream;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
22 import luan.Luan;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
23 import luan.LuanState;
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
24 import luan.LuanTable;
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
25 import luan.LuanFunction;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
26 import luan.LuanJavaFunction;
781
fbbdd369a13a rename DeepCloner to LuanCloner
Franklin Schmidt <fschmidt@gmail.com>
parents: 777
diff changeset
27 import luan.LuanCloner;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
28 import luan.LuanException;
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
29 import luan.modules.PackageLuan;
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
30 import luan.modules.BasicLuan;
1321
307e76ccd0d6 generalize separate logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1319
diff changeset
31 import luan.modules.logging.LuanLogger;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
32
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
33
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
34 public final class LuanHandler implements Handler, LuanState.OnClose {
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
35 private final LuanState luanInit;
627
a98812908fbc add loggerRoot param to LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 531
diff changeset
36 private final Logger logger;
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
37 private final ReadWriteLock lock = new ReentrantReadWriteLock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
38 private final List<Reference<Closeable>> onClose = new ArrayList<Reference<Closeable>>();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
39 private volatile LuanState currentLuan;
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
40 private volatile boolean isDisabled = false;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
41
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
42 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
43 private static final Method evalInRootMethod;
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
44 private static final Method disableLuanMethod;
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
45 static {
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
46 try {
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
47 resetLuanMethod = LuanHandler.class.getMethod( "reset_luan" );
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
48 evalInRootMethod = LuanHandler.class.getMethod( "eval_in_root", String.class );
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
49 disableLuanMethod = LuanHandler.class.getMethod( "disable_luan" );
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
50 } catch(NoSuchMethodException e) {
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
51 throw new RuntimeException(e);
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
52 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
53 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
54
1321
307e76ccd0d6 generalize separate logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1319
diff changeset
55 public LuanHandler(LuanState luanInit) {
1231
0b75337bb91a better closing
Franklin Schmidt <fschmidt@gmail.com>
parents: 1223
diff changeset
56 this.luanInit = luanInit;
1321
307e76ccd0d6 generalize separate logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1319
diff changeset
57 this.logger = LuanLogger.getLogger(luanInit,LuanHandler.class.getName());
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
58 try {
1283
503bde9a7c80 add luan.require() and table.call()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1267
diff changeset
59 LuanTable Http = (LuanTable)luanInit.require("luan:http/Http.luan");
503bde9a7c80 add luan.require() and table.call()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1267
diff changeset
60 Http.put( "reset_luan", new LuanJavaFunction(resetLuanMethod,this) );
503bde9a7c80 add luan.require() and table.call()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1267
diff changeset
61 Http.put( "eval_in_root", new LuanJavaFunction(evalInRootMethod,this) );
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
62 Http.put( "disable_luan", new LuanJavaFunction(disableLuanMethod,this) );
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
63 } catch(LuanException e) {
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
64 throw new RuntimeException(e);
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
65 }
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
66 currentLuan = newLuan();
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
67 }
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
68
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
69 private LuanState newLuan() {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
70 LuanCloner cloner = new LuanCloner(LuanCloner.Type.COMPLETE);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
71 LuanState luan = (LuanState)cloner.clone(luanInit);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
72 luan.onClose = this;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
73 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
74 PackageLuan.load(luan,"site:/init.luan");
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
75 } catch(LuanException e) {
1321
307e76ccd0d6 generalize separate logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1319
diff changeset
76 //e.printStackTrace();
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
77 String err = e.getLuanStackTraceString();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
78 logger.error(err);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
79 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
80 return luan;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
81 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
82
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
83 /*
1257
e38f5869e9df don't reset in send_redirect and other improvements
Franklin Schmidt <fschmidt@gmail.com>
parents: 1256
diff changeset
84 public LuanState getLuan() {
e38f5869e9df don't reset in send_redirect and other improvements
Franklin Schmidt <fschmidt@gmail.com>
parents: 1256
diff changeset
85 return luan;
e38f5869e9df don't reset in send_redirect and other improvements
Franklin Schmidt <fschmidt@gmail.com>
parents: 1256
diff changeset
86 }
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
87 */
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
88 @Override public Response handle(Request request) {
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
89 if( isDisabled )
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
90 return null;
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
91 if( request.path.endsWith("/") )
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
92 return null;
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
93 String modName = "site:" + request.path +".luan";
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
94 return handle(request,modName);
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
95 }
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
96
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
97 Response handle(Request request,String modName) {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
98 Thread thread = Thread.currentThread();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
99 String oldName = thread.getName();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
100 thread.setName(request.headers.get("host")+request.path);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
101 lock.readLock().lock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
102 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
103 return HttpServicer.service(currentLuan,request,modName);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
104 } catch(LuanException e) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
105 String err = e.getLuanStackTraceString();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
106 logger.error(err+"\n"+request.rawHead.trim()+"\n");
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
107 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
108 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
109 } finally {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
110 lock.readLock().unlock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
111 thread.setName(oldName);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
112 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
113 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
114
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
115 public void onClose(Closeable c) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
116 synchronized(onClose) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
117 onClose.add(new WeakReference<Closeable>(c));
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
118 }
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
119 }
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
120
1231
0b75337bb91a better closing
Franklin Schmidt <fschmidt@gmail.com>
parents: 1223
diff changeset
121 public void close() {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
122 synchronized(onClose) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
123 for( Reference<Closeable> ref : onClose ) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
124 Closeable c = ref.get();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
125 if( c != null ) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
126 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
127 c.close();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
128 } catch(IOException e) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
129 logger.error(c.toString(),e);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
130 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
131 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
132 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
133 onClose.clear();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
134 }
517
8dcf9e12446b add Luan.on_luan_close()
Franklin Schmidt <fschmidt@gmail.com>
parents: 494
diff changeset
135 }
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
136
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
137 public Object call_rpc(String fnName,Object... args) throws LuanException {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
138 lock.readLock().lock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
139 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
140 LuanFunction fn;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
141 LuanState luan = currentLuan;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
142 synchronized(luan) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
143 PackageLuan.enableLoad(luan,"luan:Rpc.luan");
1283
503bde9a7c80 add luan.require() and table.call()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1267
diff changeset
144 LuanTable rpc = (LuanTable)luan.require("luan:Rpc.luan");
1267
9fa8b8389578 add LuanTable.luan;
Franklin Schmidt <fschmidt@gmail.com>
parents: 1265
diff changeset
145 LuanTable fns = (LuanTable)rpc.get("functions");
9fa8b8389578 add LuanTable.luan;
Franklin Schmidt <fschmidt@gmail.com>
parents: 1265
diff changeset
146 fn = (LuanFunction)fns.get(fnName);
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
147 if( fn == null )
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
148 throw new LuanException( "function not found: " + fnName );
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
149 LuanCloner cloner = new LuanCloner(LuanCloner.Type.INCREMENTAL);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
150 luan = (LuanState)cloner.clone(luan);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
151 fn = (LuanFunction)cloner.get(fn);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
152 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
153 return fn.call(luan,args);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
154 } finally {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
155 lock.readLock().unlock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
156 }
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
157 }
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
158
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
159 public void reset_luan() {
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
160 new Thread() {
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
161 public void run() {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
162 lock.writeLock().lock();
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
163 try {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
164 close();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
165 currentLuan = newLuan();
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
166 } finally {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
167 lock.writeLock().unlock();
1264
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
168 }
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
169 }
d41997776788 fix onClose issues
Franklin Schmidt <fschmidt@gmail.com>
parents: 1263
diff changeset
170 }.start();
1186
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
171 }
ef8cd42e23d5 add back reset_luan
Franklin Schmidt <fschmidt@gmail.com>
parents: 1185
diff changeset
172
1319
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
173 public void disable_luan() {
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
174 isDisabled = true;
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
175 }
f7355714742f add Http.disable_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1283
diff changeset
176
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
177 public Object runLuan(String sourceText,String sourceName) throws LuanException {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
178 lock.readLock().lock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
179 try {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
180 LuanFunction fn = Luan.load(sourceText,sourceName);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
181 LuanState luan = currentLuan;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
182 synchronized(luan) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
183 LuanCloner cloner = new LuanCloner(LuanCloner.Type.INCREMENTAL);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
184 LuanState luan2 = (LuanState)cloner.clone(luan);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
185 return fn.call(luan2);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
186 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
187 } finally {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
188 lock.readLock().unlock();
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
189 }
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
190 }
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
191
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
192 public void eval_in_root(String text) throws LuanException {
1265
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
193 LuanState oldLuan = currentLuan;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
194 LuanState luan;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
195 synchronized(oldLuan) {
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
196 LuanCloner cloner = new LuanCloner(LuanCloner.Type.COMPLETE);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
197 luan = (LuanState)cloner.clone(oldLuan);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
198 }
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
199 luan.onClose = this;
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
200 BasicLuan.load(text,"<eval_in_root>",null).call(luan);
3f4644246e39 LuanHandler cleanup and add Server.serve_for_proxy
Franklin Schmidt <fschmidt@gmail.com>
parents: 1264
diff changeset
201 currentLuan = luan;
1263
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
202 }
382c444a6c77 add Http.eval_in_root and Http.handle_error
Franklin Schmidt <fschmidt@gmail.com>
parents: 1257
diff changeset
203
1004
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
204 public static void start(Server server) throws Exception {
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
205 try {
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
206 server.start();
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
207 } catch(BindException e) {
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
208 throw new LuanException(e.toString());
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
209 }
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
210 }
1077
ca968ef1747a better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 800
diff changeset
211
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
212 }