annotate src/luan/host/WebHandler.java @ 1608:f7e3adae4907

add BasicAuthHandler
author Franklin Schmidt <fschmidt@gmail.com>
date Sat, 01 May 2021 19:52:56 -0600
parents fa066aaa068c
children 07be5015159d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1182
diff changeset
1 package luan.host;
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
2
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
3 import java.io.File;
1501
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
4 import java.io.IOException;
1402
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
5 import goodjava.logging.Logger;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
6 import goodjava.logging.LoggerFactory;
1501
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
7 import goodjava.io.IoUtils;
1402
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
8 import goodjava.webserver.Handler;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
9 import goodjava.webserver.Request;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
10 import goodjava.webserver.Response;
27efb1fcbcb5 move luan.lib to goodjava
Franklin Schmidt <fschmidt@gmail.com>
parents: 1400
diff changeset
11 import goodjava.webserver.handlers.DomainHandler;
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
12 import goodjava.webserver.handlers.IndexHandler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
13 import goodjava.webserver.handlers.ListHandler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
14 import goodjava.webserver.handlers.ContentTypeHandler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
15 import goodjava.webserver.handlers.SafeHandler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
16 import goodjava.webserver.handlers.LogHandler;
1602
55d7b60c074d add DirHandler to WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1600
diff changeset
17 import goodjava.webserver.handlers.FileHandler;
55d7b60c074d add DirHandler to WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1600
diff changeset
18 import goodjava.webserver.handlers.DirHandler;
1607
fa066aaa068c nginx caching
Franklin Schmidt <fschmidt@gmail.com>
parents: 1605
diff changeset
19 import goodjava.webserver.handlers.HeadersHandler;
1608
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
20 import goodjava.webserver.handlers.BasicAuthHandler;
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
21 import goodjava.webserver.handlers.RegexHandler;
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
22 import luan.Luan;
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
23 import luan.LuanException;
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
24 import luan.LuanTable;
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
25 import luan.LuanFunction;
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
26 import luan.LuanClosure;
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
27 import luan.LuanRuntimeException;
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1182
diff changeset
28 import luan.modules.http.LuanHandler;
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
29 import luan.modules.http.NotFound;
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1425
diff changeset
30 import luan.modules.logging.LuanLogger;
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
31
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
32
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1182
diff changeset
33 public class WebHandler implements Handler {
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
34 private static final Logger logger = LoggerFactory.getLogger(WebHandler.class);
1600
8a717f0b7f45 add DailyRollingFileAppender.deleteAfter
Franklin Schmidt <fschmidt@gmail.com>
parents: 1599
diff changeset
35 private static final long days30 = 1000L*60*60*24*30;
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
36
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
37 private static final class MyHandler implements Handler {
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
38 private final Handler handler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
39 final LuanHandler luanHandler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
40
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
41 MyHandler(Handler handler,LuanHandler luanHandler) {
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
42 this.handler = handler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
43 this.luanHandler = luanHandler;
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
44 }
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
45
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
46 @Override public Response handle(Request request) {
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
47 return handler.handle(request);
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
48 }
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
49 }
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
50
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
51 private static final DomainHandler.Factory factory = new DomainHandler.Factory() {
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
52 public Handler newHandler(String domain) {
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
53 File dir = new File(sitesDir,domain);
1400
221eedb0f54e fix inner class gc bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1392
diff changeset
54 if( !dir.exists() )
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
55 return null;
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
56 String dirStr = dir.toString();
1230
034f2a0b3915 better gc
Franklin Schmidt <fschmidt@gmail.com>
parents: 1203
diff changeset
57
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
58 String logDir = dirStr + "/site/private/local/logs/web";
1501
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
59 try {
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
60 IoUtils.mkdirs(new File(logDir));
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
61 } catch(IOException e) {
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
62 throw new RuntimeException(e);
Franklin Schmidt <fschmidt@gmail.com>
parents: 1454
diff changeset
63 }
1230
034f2a0b3915 better gc
Franklin Schmidt <fschmidt@gmail.com>
parents: 1203
diff changeset
64
1333
25746915a241 merge Luan and LuanState
Franklin Schmidt <fschmidt@gmail.com>
parents: 1332
diff changeset
65 Luan luan = new Luan();
1608
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
66 String password;
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
67 LuanLogger.startThreadLogging(luan);
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
68 try {
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
69 LuanFunction fn = Luan.loadClasspath(luan,"luan/host/init.luan");
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
70 fn.call(luan,dirStr,domain);
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
71 LuanTable Io = (LuanTable)luan.require("luan:Io.luan");
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
72 password = (String)Io.get(luan,"password");
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
73 if( password==null ) throw new NullPointerException();
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
74 } catch(LuanException e) {
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
75 throw new LuanRuntimeException(e);
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
76 } finally {
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
77 LuanLogger.endThreadLogging();
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
78 }
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
79 security(luan,dirStr);
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
80 LuanHandler luanHandler = new LuanHandler(luan,domain);
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
81
1605
ef9d96aeb541 use FileHandler in WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1602
diff changeset
82 FileHandler fileHandler = new FileHandler(dirStr+"/site/");
ef9d96aeb541 use FileHandler in WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1602
diff changeset
83 Handler handler = new ListHandler( luanHandler, fileHandler );
1607
fa066aaa068c nginx caching
Franklin Schmidt <fschmidt@gmail.com>
parents: 1605
diff changeset
84 handler = new ContentTypeHandler(handler);
1605
ef9d96aeb541 use FileHandler in WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1602
diff changeset
85 handler = new IndexHandler(handler);
ef9d96aeb541 use FileHandler in WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1602
diff changeset
86 DirHandler dirHandler = new DirHandler(fileHandler);
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
87 Handler notFoundHander = new NotFound(luanHandler);
1607
fa066aaa068c nginx caching
Franklin Schmidt <fschmidt@gmail.com>
parents: 1605
diff changeset
88 notFoundHander = new ContentTypeHandler(notFoundHander);
1602
55d7b60c074d add DirHandler to WebHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1600
diff changeset
89 handler = new ListHandler( handler, dirHandler, notFoundHander );
1608
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
90 Handler auth = new BasicAuthHandler(handler,"Private","admin",password);
f7e3adae4907 add BasicAuthHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1607
diff changeset
91 handler = new RegexHandler("^/private/",auth,handler);
1607
fa066aaa068c nginx caching
Franklin Schmidt <fschmidt@gmail.com>
parents: 1605
diff changeset
92 handler = new HeadersHandler(handler);
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
93 handler = new SafeHandler(handler);
1600
8a717f0b7f45 add DailyRollingFileAppender.deleteAfter
Franklin Schmidt <fschmidt@gmail.com>
parents: 1599
diff changeset
94 handler = new LogHandler(handler,LogHandler.dirLogger(new File(logDir),days30));
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
95
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
96 return new MyHandler(handler,luanHandler);
1230
034f2a0b3915 better gc
Franklin Schmidt <fschmidt@gmail.com>
parents: 1203
diff changeset
97 }
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
98 };
1230
034f2a0b3915 better gc
Franklin Schmidt <fschmidt@gmail.com>
parents: 1203
diff changeset
99
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
100 public static String securityPassword = "password"; // change for security
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
101 private static final DomainHandler domainHandler = new DomainHandler(factory);
1202
d3a3ca116e42 gc site instances
Franklin Schmidt <fschmidt@gmail.com>
parents: 1187
diff changeset
102 private static String sitesDir = null;
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
103
1185
94cf2576a922 implement WebHandler for nginx
Franklin Schmidt <fschmidt@gmail.com>
parents: 1182
diff changeset
104 public WebHandler(String dir) {
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
105 if( sitesDir != null )
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
106 throw new RuntimeException("already set");
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
107 if( !new File(dir).exists() )
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
108 throw new RuntimeException();
1230
034f2a0b3915 better gc
Franklin Schmidt <fschmidt@gmail.com>
parents: 1203
diff changeset
109 sitesDir = dir;
1454
219f2b937f2b remove log4j
Franklin Schmidt <fschmidt@gmail.com>
parents: 1425
diff changeset
110 LuanLogger.initThreadLogging();
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
111 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
112
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
113 @Override public Response handle(Request request) {
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
114 return domainHandler.handle(request);
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
115 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
116
1578
c922446f53aa immutable threading
Franklin Schmidt <fschmidt@gmail.com>
parents: 1563
diff changeset
117 public static Object callSite(String domain,String fnName,Object... args) throws LuanException {
1598
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
118 MyHandler handler = (MyHandler)domainHandler.getHandler(domain);
c78d6a4e2d9a web logging
Franklin Schmidt <fschmidt@gmail.com>
parents: 1578
diff changeset
119 return handler.luanHandler.call_rpc(fnName,args);
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
120 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
121
1315
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
122 public static void removeHandler(String domain) {
5763597ca5c0 add DomainHandler
Franklin Schmidt <fschmidt@gmail.com>
parents: 1314
diff changeset
123 domainHandler.removeHandler(domain);
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
124 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
125
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
126 public static void loadHandler(String domain) throws LuanException {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
127 try {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
128 domainHandler.getHandler(domain);
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
129 } catch(LuanRuntimeException e) {
1335
e0cf0d108a77 major cleanup
Franklin Schmidt <fschmidt@gmail.com>
parents: 1333
diff changeset
130 throw (LuanException)e.getCause();
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
131 }
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
132 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
133
1333
25746915a241 merge Luan and LuanState
Franklin Schmidt <fschmidt@gmail.com>
parents: 1332
diff changeset
134 private static final void security(Luan luan,String dir) {
1174
bdf27aa2a65c fix luanhost security bug
Franklin Schmidt <fschmidt@gmail.com>
parents: 1136
diff changeset
135 final String siteUri = "file:" + dir + "/site";
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
136 Luan.Security security = new Luan.Security() {
1333
25746915a241 merge Luan and LuanState
Franklin Schmidt <fschmidt@gmail.com>
parents: 1332
diff changeset
137 public void check(Luan luan,LuanClosure closure,String op,Object... args)
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
138 throws LuanException
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
139 {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
140 if( op.equals("uri") ) {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
141 String name = (String)args[0];
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
142 if( name.startsWith("file:") ) {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
143 if( name.contains("..") )
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
144 throw new LuanException("Security violation - '"+name+"' contains '..'");
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
145 if( !(name.equals(siteUri) || name.startsWith(siteUri+"/")) )
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
146 throw new LuanException("Security violation - '"+name+"' outside of site dir");
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
147 }
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
148 else if( name.startsWith("classpath:luan/host/") ) {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
149 throw new LuanException("Security violation");
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
150 }
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
151 else if( name.startsWith("os:") || name.startsWith("bash:") ) {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
152 throw new LuanException("Security violation");
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
153 }
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
154 } else {
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
155 String name = closure.sourceName;
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
156 if( !(
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
157 name.startsWith("luan:")
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
158 || name.startsWith("classpath:")
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
159 || name.matches("^file:[^/]+$")
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
160 ) )
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
161 throw new LuanException("Security violation - only luan:* modules can load Java");
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
162 if( name.equals("luan:logging/Logging") )
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
163 throw new LuanException("Security violation - cannot reload Logging");
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
164 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
165 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
166 };
1330
f41919741100 fix security
Franklin Schmidt <fschmidt@gmail.com>
parents: 1321
diff changeset
167 Luan.setSecurity(luan,security);
1135
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
168 }
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
169
707a5d874f3e add luan.host
Franklin Schmidt <fschmidt@gmail.com>
parents:
diff changeset
170 }