This is a Heroku buildpack for Lua apps.
It comes bundled with Lua 5.1 and LuaRocks 2.0.7.1.
Read a tutorial at http://leafo.net/posts/lua_on_heroku.html.
Create an app with the buildpack:
$ stackato push --buildpack https://github.com/dkulchenko/stackato-buildpack-lua -n
In order to describe the dependencies of you application you must create a rockspec for it.
The first file found that matches *.rockpsec
in the root directory will be
used. Don't put multiple ones in the root directory otherwise it might get
confused.
The buildpack only looks at the dependency information. Meaning you don't have to follow the entire rockspec specification. Minimally, your rockspec could look something like this:
-- my_app.rockspec
dependencies = {
"xavante >= 2.2.1",
"http://moonscript.org/rocks/moonscript-dev-1.src.rock",
"cosmo"
}
As shown above, if you want to include external rockspec or rock files by URL you can place them in the dependencies table. (This is not supported by LuaRocks, only by this buildpack).
This file must exist, even if you have no dependencies. The rockspec is parsed in prepare.moon.
The buildpack installs the dependencies to packages/
and Lua to bin/lua
.
The bin/
directory is added to the PATH
on initial install so you can run
Lua directly.
Additionally, LUA_PATH
and LUA_CPATH
environment variables are set to point
to where the dependencies are installed so you can require
them with no extra
work.
Use Xavante for a quick web server:
-- web.lua
require "xavante"
port = ...
xavante.HTTP {
server = { host = "*", port = tonumber(port) },
defaultHost = {
rules = {
{
match = ".",
with = function(req, res)
res.headers["Content-type"] = "text/html"
res.content = "hello world, the time is: " .. os.date()
return res
end
}
}
}
}
xavante.start()
Tell Stackato to spawn your web server by creating a file called Procfile
:
web: lua web.lua $PORT
If you were using the first incarnation of this buildpack the paths were not
set automatically. In order to upgrade your app use heroku config
to
manually set the config vars described in the release script.