annotate src/luan/modules/http/LuanHandler.java @ 1185:94cf2576a922

implement WebHandler for nginx
author Franklin Schmidt <fschmidt@gmail.com>
date Wed, 21 Feb 2018 21:22:16 -0700
parents 794ddcfbee20
children ef8cd42e23d5
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
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
3 import java.io.Writer;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
4 import java.io.PrintWriter;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
5 import java.io.IOException;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
6 import java.lang.reflect.Method;
1004
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
7 import java.net.BindException;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
8 import java.util.concurrent.locks.ReadWriteLock;
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
9 import java.util.concurrent.locks.ReentrantReadWriteLock;
280
2164b4479661 log web exceptions
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents: 264
diff changeset
10 import org.slf4j.Logger;
2164b4479661 log web exceptions
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents: 264
diff changeset
11 import org.slf4j.LoggerFactory;
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
12 import luan.webserver.Request;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
13 import luan.webserver.Response;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
14 import luan.webserver.Server;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
15 import luan.webserver.Handler;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
16 import luan.webserver.Status;
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
17 import luan.webserver.ResponseOutputStream;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
18 import luan.Luan;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
19 import luan.LuanState;
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
20 import luan.LuanTable;
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
21 import luan.LuanFunction;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
22 import luan.LuanJavaFunction;
781
fbbdd369a13a rename DeepCloner to LuanCloner
Franklin Schmidt <fschmidt@gmail.com>
parents: 777
diff changeset
23 import luan.LuanCloner;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
24 import luan.LuanException;
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
25 import luan.modules.PackageLuan;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
26
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
27
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
28 public class LuanHandler implements Handler {
627
a98812908fbc add loggerRoot param to LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 531
diff changeset
29 private final Logger logger;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
30 private final ReadWriteLock lock = new ReentrantReadWriteLock();
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
31 private final LuanState luan;
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
32
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
33 public LuanHandler(LuanState luanInit,String loggerRoot) {
627
a98812908fbc add loggerRoot param to LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 531
diff changeset
34 if( loggerRoot==null )
a98812908fbc add loggerRoot param to LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 531
diff changeset
35 loggerRoot = "";
a98812908fbc add loggerRoot param to LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 531
diff changeset
36 logger = LoggerFactory.getLogger(loggerRoot+LuanHandler.class.getName());
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
37
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
38 LuanCloner cloner = new LuanCloner(LuanCloner.Type.COMPLETE);
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
39 this.luan = (LuanState)cloner.clone(luanInit);
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
40 try {
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
41 PackageLuan.load(luan,"site:/init.luan");
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
42 } catch(LuanException e) {
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
43 String err = e.getLuanStackTraceString();
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
44 logger.error(err);
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
45 }
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
46 }
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
47
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
48 @Override public Response handle(Request request) {
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
49 if( request.path.endsWith("/") )
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
50 return null;
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
51 String modName = "site:" + request.path +".luan";
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
52 return handle(request,modName);
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
53 }
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
54
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
55 Response handle(Request request,String modName) {
791
ca81307adf7c set thread name in LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 786
diff changeset
56 Thread thread = Thread.currentThread();
ca81307adf7c set thread name in LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 786
diff changeset
57 String oldName = thread.getName();
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
58 thread.setName(request.headers.get("host")+request.path);
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
59 lock.readLock().lock();
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
60 try {
1167
7e6f28c769a1 better handlers
Franklin Schmidt <fschmidt@gmail.com>
parents: 1161
diff changeset
61 Response response = HttpServicer.service(luan,request,modName);
1160
4beabb087be6 add http/impl
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
62 return response;
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
63 } catch(LuanException e) {
777
1460d297e960 add bbcode to blog example
Franklin Schmidt <fschmidt@gmail.com>
parents: 775
diff changeset
64 //e.printStackTrace();
1122
e15be31cee92 remove LuanException.getFullMessage()
Franklin Schmidt <fschmidt@gmail.com>
parents: 1080
diff changeset
65 String err = e.getLuanStackTraceString();
280
2164b4479661 log web exceptions
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents: 264
diff changeset
66 logger.error(err);
1161
Franklin Schmidt <fschmidt@gmail.com>
parents: 1160
diff changeset
67 String msg = "Internel Server Error\n\n" + err;
Franklin Schmidt <fschmidt@gmail.com>
parents: 1160
diff changeset
68 return Response.errorResponse( Status.INTERNAL_SERVER_ERROR, msg );
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
69 } finally {
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
70 lock.readLock().unlock();
791
ca81307adf7c set thread name in LuanHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 786
diff changeset
71 thread.setName(oldName);
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
72 }
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
73 }
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
74
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
75 public void close() throws IOException {
521
8a217fe5b4f3 cleaner LuanState.onClose()
Franklin Schmidt <fschmidt@gmail.com>
parents: 517
diff changeset
76 synchronized(luan) {
8a217fe5b4f3 cleaner LuanState.onClose()
Franklin Schmidt <fschmidt@gmail.com>
parents: 517
diff changeset
77 luan.close();
8a217fe5b4f3 cleaner LuanState.onClose()
Franklin Schmidt <fschmidt@gmail.com>
parents: 517
diff changeset
78 }
517
8dcf9e12446b add Luan.on_luan_close()
Franklin Schmidt <fschmidt@gmail.com>
parents: 494
diff changeset
79 }
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1171
diff changeset
80
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
81 public Object call_rpc(String fnName,Object... args) throws LuanException {
798
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
82 lock.readLock().lock();
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
83 try {
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
84 LuanFunction fn;
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
85 LuanState luan = this.luan;
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
86 synchronized(luan) {
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
87 PackageLuan.enableLoad(luan,"luan:Rpc.luan");
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
88 LuanTable rpc = (LuanTable)PackageLuan.require(luan,"luan:Rpc.luan");
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
89 LuanTable fns = (LuanTable)rpc.get(luan,"functions");
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
90 fn = (LuanFunction)fns.get(luan,fnName);
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
91 if( fn == null )
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
92 throw new LuanException( "function not found: " + fnName );
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
93 LuanCloner cloner = new LuanCloner(LuanCloner.Type.INCREMENTAL);
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
94 luan = (LuanState)cloner.clone(luan);
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
95 fn = (LuanFunction)cloner.get(fn);
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
96 }
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
97 return fn.call(luan,args);
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
98 } finally {
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
99 lock.readLock().unlock();
743
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
100 }
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
101 }
2c41f2aec92f improve Rpc and implement rpc call for local webserver
Franklin Schmidt <fschmidt@gmail.com>
parents: 693
diff changeset
102
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
103 public Object runLuan(String sourceText,String sourceName) throws LuanException {
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
104 LuanFunction fn = Luan.load(sourceText,sourceName);
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
105 synchronized(luan) {
798
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
106 LuanCloner cloner = new LuanCloner(LuanCloner.Type.INCREMENTAL);
9eccfede1094 fix cloning bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 791
diff changeset
107 LuanState luan = (LuanState)cloner.clone(this.luan);
786
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
108 return fn.call(luan);
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
109 }
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
110 }
fe63c508a177 add Http.reset_luan()
Franklin Schmidt <fschmidt@gmail.com>
parents: 785
diff changeset
111
1004
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
112 public static void start(Server server) throws Exception {
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
113 try {
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
114 server.start();
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
115 } catch(BindException e) {
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
116 throw new LuanException(e.toString());
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
117 }
3fa54d9d19cd better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 1000
diff changeset
118 }
1077
ca968ef1747a better handling of BindException
Franklin Schmidt <fschmidt@gmail.com>
parents: 800
diff changeset
119
175
bdbd4740121f finish web server
fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
parents:
diff changeset
120 }