Mercurial Hosting > luan
changeset 1831:8f9ae295bf6a
add Hosted.authorize
| author | Franklin Schmidt <fschmidt@gmail.com> | 
|---|---|
| date | Thu, 26 Sep 2024 15:07:45 -0600 | 
| parents | d72a52232f79 | 
| children | d55c3eaf21d7 | 
| files | src/luan/host/WebHandler.java src/luan/host/init.luan | 
| diffstat | 2 files changed, 47 insertions(+), 21 deletions(-) [+] | 
line wrap: on
 line diff
--- a/src/luan/host/WebHandler.java Tue Sep 24 17:17:57 2024 -0600 +++ b/src/luan/host/WebHandler.java Thu Sep 26 15:07:45 2024 -0600 @@ -7,6 +7,8 @@ import java.lang.ref.WeakReference; import java.lang.reflect.Method; import java.util.Set; +import java.util.Map; +import java.util.LinkedHashMap; import java.util.Collections; import java.util.concurrent.ConcurrentHashMap; import goodjava.logging.Logger; @@ -66,7 +68,37 @@ } } + private static final class AuthInfo { + String realm; + String username; + String password; + Handler auth; + } + public static final class AuthDomain { + final Map<String,AuthInfo> authMap = new LinkedHashMap<String,AuthInfo>(); + + public void authorize(String path_ptn,String realm,String username,String password) { + AuthInfo info = new AuthInfo(); + info.realm = realm; + info.username = username; + info.password = password; + authMap.put(path_ptn,info); + } + } + + private static final Method dontGcMethod; + private static final Method authorize; + static { + try { + dontGcMethod = WebHandler.Fns.class.getMethod( "dont_gc" ); + authorize = WebHandler.AuthDomain.class.getMethod( "authorize", String.class, String.class, String.class, String.class ); + } catch(NoSuchMethodException e) { + throw new RuntimeException(e); + } + } + private static final DomainHandler.Factory factory = new DomainHandler.Factory() { + public Handler newHandler(String domain) { File dir = new File(sitesDir,domain); if( !dir.exists() ) @@ -80,27 +112,22 @@ throw new RuntimeException(e); } + AuthDomain authDomain = new AuthDomain(); + Fns fns = new Fns(); Luan luan = new Luan(); - String password; LuanLogger.startThreadLogging(luan); try { + LuanTable Hosted = (LuanTable)luan.require("luan:host/Hosted.luan"); + Hosted.put( luan, "authorize", new LuanJavaFunction(authorize,authDomain) ); LuanFunction fn = Luan.loadClasspath(luan,"luan/host/init.luan"); fn.call(luan,dirStr,domain); - LuanTable Io = (LuanTable)luan.require("luan:Io.luan"); - password = (String)Io.get(luan,"password"); - if( password==null ) throw new NullPointerException(); + LuanTable Http = (LuanTable)luan.require("luan:http/Http.luan"); + Http.put( luan, "dont_gc", new LuanJavaFunction(dontGcMethod,fns) ); } catch(LuanException e) { throw new LuanRuntimeException(e); } finally { LuanLogger.endThreadLogging(); } - Fns fns = new Fns(); - try { - LuanTable Http = (LuanTable)luan.require("luan:http/Http.luan"); - Http.put( luan, "dont_gc", new LuanJavaFunction(dontGcMethod,fns) ); - } catch(LuanException e) { - throw new RuntimeException(e); - } security(luan,dirStr); LuanHandler luanHandler = new LuanHandler(luan,domain); @@ -112,8 +139,14 @@ Handler notFoundHander = new NotFound(luanHandler); notFoundHander = new ContentTypeHandler(notFoundHander); handler = new ListHandler( handler, dirHandler, notFoundHander ); - Handler auth = new BasicAuthHandler(handler,"Private","admin",password); - handler = new RegexHandler("^/private/",auth,handler); + for( AuthInfo info : authDomain.authMap.values() ) { + info.auth = new BasicAuthHandler(handler,info.realm,info.username,info.password); + } + for( Map.Entry<String,AuthInfo> entry : authDomain.authMap.entrySet() ) { + String path_ptn = entry.getKey(); + AuthInfo info = entry.getValue(); + handler = new RegexHandler(path_ptn,info.auth,handler); + } handler = new HeadersHandler(handler); handler = new SafeHandler(handler); handler = new LogHandler(handler,LogHandler.dirLogger(new File(logDir),days30)); @@ -212,14 +245,6 @@ private static final Set<MyHandler> dontGc = Collections.newSetFromMap(new ConcurrentHashMap<MyHandler,Boolean>()); - private static final Method dontGcMethod; - static { - try { - dontGcMethod = WebHandler.Fns.class.getMethod( "dont_gc" ); - } catch(NoSuchMethodException e) { - throw new RuntimeException(e); - } - } public static final class Fns { private Reference<MyHandler> ref = null; private boolean dont = false;
