class
Analyzer::Lua::Lapis
- Analyzer::Lua::Lapis
- Analyzer
- Reference
- Object
Overview
Lapis is a Lua/MoonScript web framework on top of OpenResty. Routes can be expressed in several styles:
- Method-specific calls —
app:get("/path", handler),app:post,app:put,app:delete,app:patch,app:head,app:options. - Generic
app:match(path, handler)and the namedapp:match("name", "/path", handler)form, both of which dispatch on any HTTP method. - Application-table style:
["/path"] = "handler_name"or["/path"] = function(self) ... end. - MoonScript class actions:
"/path": =>and the named form[name: "/path"]: =>.
Path parameters use :name and splats use *name, which already
match noir's URL convention so they are surfaced verbatim. Lapis
route patterns additionally carry Lua-pattern constraints
(:id[%d], :slug[%w]) and optional groups ((/page/:page)),
neither of which belong in a concrete URL — both are normalised
away. Sub-apps mounted with app:include(...) carry an
app.path = "/prefix" that every route inherits, so the prefix is
detected per file and prepended to the routes bound on that app.
Defined in:
analyzer/analyzers/lua/lapis.crConstant Summary
-
APP_PATH_RE =
/(?:^|[^A-Za-z0-9_.])([A-Za-z_]\w*)\.path\s*=\s*(['"])([^'"]*)\2/ -
APP_VAR_RE =
/(?:^|[^A-Za-z0-9_])(?:local\s+)?([A-Za-z_]\w*)\s*=\s*lapis\.Application(?:\b|:extend|\s*\()/ -
FALLBACK_METHODS =
["GET", "POST", "PUT", "DELETE", "PATCH"] -
HTTP_METHODS =
["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"] of ::String -
MOON_PATH_RE =
/@path\s*:\s*(['"])([^'"]*)\1/