Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bakins/stardust
Simple OpenResty web framework
https://github.com/bakins/stardust
Last synced: 3 months ago
JSON representation
Simple OpenResty web framework
- Host: GitHub
- URL: https://github.com/bakins/stardust
- Owner: bakins
- License: apache-2.0
- Created: 2013-06-13T20:43:28.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2013-07-09T12:18:35.000Z (over 11 years ago)
- Last Synced: 2024-02-13T21:45:58.687Z (12 months ago)
- Language: Lua
- Homepage: http://bakins.github.io/stardust/
- Size: 297 KB
- Stars: 8
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-resty - Ziggy Stardust
README
Ziggy Stardust
==========Ziggy Stardust (or just "stardust") is a simple nginx/Lua framework inspired by
[Sinatra](http://www.sinatrarb.com/),
[Express](http://expressjs.com/), and
[Mercury](https://github.com/nrk/mercury).It is currently in development and is little more than a toy. It may
eat your data and crash your computer.Sample
------
The easiest way to explain stardust is to show an example.local stardust = require "stardust"
local router = require "stardust.router"
local app = stardust.new()
local r = router.new()
app:use(r)
r:get("%.txt?$",
function(req, res)
res.body = "hello, it seems you requested " .. req.path
end
)
function _M.run(ngx)
return app:run(ngx)
endreturn _M
And the add something like this to your nginx virtual server config:location / {
content_by_lua 'return require("redis").run(ngx)';
}
There are more examples in the `examples` directory.# Concepts Building Blocks #
The modules are documented using
[ldoc](http://stevedonovan.github.com/ldoc/). Check that for the
"real" documentation.## Core ##
Lua module `stardust`The core of stardust doesn't do much. It is used to create and run and
app. It is also used to register middleware for an app.## Middleware ##
Middleware is where the actual work happens. Here's and extremely
simple example of creating and using middleware:
local app = stardust.new()
local r = router.new()
app:use(r)
app:use(function(req, res)
res.body = string.upper(res.body)
end
r:get("%.txt?$",
function(req, res)
res.body = "hello, it seems you requested " .. req.path
end
)
In this example, the body of the response will be converted to
uppercase. The middleware can live in a module or be created "on the
fly" -- stardust doesn't care, it just needs to be a function that
accepts a request and a response. Middleware should generally return
`nil` . (Still figuring out when/how we want middleware to be able to
halt the request/response both for failure and success.)
In case you didn't notice, the router is just middleware. Middleware
is ran in the order it is registered using the `use` method.
## Router ##
Lua module `stardust.router`
The router is fairly simple and currently uses Lua string patterns to
match routes. The routes are ran in order and the first match wins.
## Request ##
Lua module `stardust.request`A request is generally read-only and is a thin wrapper around an HTTP
request as used by nginx. See the modules docs for the "fields."## Response ##
Lua module `stardust.response`Basically a table that has fields:
* status - HTTP status code. defaults to 200
* headers - Lua table of HTTP response headers
* body - table or string of the actual response bodyAll of these are read/write.