Mercurial Hosting > luan
diff src/luan/host/run.luan @ 1185:94cf2576a922
implement WebHandler for nginx
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Wed, 21 Feb 2018 21:22:16 -0700 |
parents | src/luan/host/jetty/run.luan@0b55a1af5a44 |
children | 83c8a5a47f70 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/luan/host/run.luan Wed Feb 21 21:22:16 2018 -0700 @@ -0,0 +1,34 @@ +require "luan:logging/init.luan" -- initialize logging +local Luan = require "luan:Luan.luan" +local error = Luan.error +local do_file = Luan.do_file or error() +local ipairs = Luan.ipairs or error() +local Io = require "luan:Io.luan" +local print = Io.print or error() +local String = require "luan:String.luan" +local Hosting = require "luan:host/Hosting.luan" +local Logging = require "luan:logging/Logging.luan" +local logger = Logging.logger "run" +java() +local WebHandler = require "java:luan.host.WebHandler" +Hosting.WebHandler = WebHandler + +local here = Io.schemes.file(".").canonical().to_string() +Hosting.sites_dir = here.."/sites/" + +do_file "classpath:luan/host/main.luan" + + +-- web server + +local Server = require "java:luan.webserver.Server" +local ContentTypeHandler = require "java:luan.webserver.handlers.ContentTypeHandler" +local SafeHandler = require "java:luan.webserver.handlers.SafeHandler" + +local webHandler = WebHandler.new(Hosting.sites_dir) +local handler = webHandler +handler = ContentTypeHandler.new(handler) +handler = SafeHandler.new(handler) +local server = Server.ForAddress.new("127.0.0.1",8080,handler) +webHandler.server = server +server.start()