diff --git a/README.md b/README.md index 45fa9cb..5f5cd9b 100644 --- a/README.md +++ b/README.md @@ -136,7 +136,7 @@ http { local ok, errmsg = r:execute( ngx.var.request_method, - ngx.var.request_uri, + ngx.var.uri, ngx.req.get_uri_args(), -- all these parameters ngx.req.get_post_args(), -- will be merged in order {other_arg = 1}) -- into a single "params" table diff --git a/router.lua b/router.lua index 3ca9a28..30c2d8b 100644 --- a/router.lua +++ b/router.lua @@ -32,18 +32,25 @@ local router = { local COLON_BYTE = string.byte(':', 1) local WILDCARD_BYTE = string.byte('*', 1) local HTTP_METHODS = {'get', 'post', 'put', 'patch', 'delete', 'trace', 'connect', 'options', 'head'} +local STR_STR_MATCH_SLASH = "[^/.]+" +local STR_STR_SPLIT_SLASH = "([^/]+)(.*)" +local STR_LEAF = "LEAF" +local STR_TABLE = "table" +local STR_STRING = "string" +local STR_ALL_METHODS = "get post put patch delete trace connect options head" +local STR_ANY = "any" local function match_one_path(node, path, f) - for token in path:gmatch("[^/.]+") do + for token in path:gmatch(STR_STR_MATCH_SLASH) do node[token] = node[token] or {} node = node[token] end - node["LEAF"] = f + node[STR_LEAF] = f end local function resolve(path, node, params) - local _, _, current_token, rest = path:find("([^/.]+)(.*)") - if not current_token then return node["LEAF"], params end + local _, _, current_token, rest = path:find(STR_STR_SPLIT_SLASH) + if not current_token then return node[STR_LEAF], params end for child_token, child_node in pairs(node) do if child_token == current_token then @@ -65,7 +72,7 @@ local function resolve(path, node, params) elseif child_token:byte(1) == WILDCARD_BYTE then -- it's a * local param_name = child_token:sub(2) params[param_name] = current_token .. rest - return node[child_token]["LEAF"], params + return node[child_token][STR_LEAF], params end end @@ -73,7 +80,7 @@ local function resolve(path, node, params) end local function merge(destination, origin, visited) - if type(origin) ~= 'table' then return origin end + if type(origin) ~= STR_TABLE then return origin end if visited[origin] then return visited[origin] end if destination == nil then destination = {} end @@ -114,7 +121,7 @@ function Router:execute(method, path, ...) end function Router:match(method, path, fun) - if type(method) == 'string' then -- always make the method to table. + if type(method) == STR_STRING then -- always make the method to table. method = {[method] = {[path] = fun}} end for m, routes in pairs(method) do @@ -131,7 +138,7 @@ for _,method in ipairs(HTTP_METHODS) do end -- end end -Router['any'] = function(self, path, f) -- match any method +Router[STR_ANY] = function(self, path, f) -- match any method for _,method in ipairs(HTTP_METHODS) do self:match(method:upper(), path, function(params) return f(params, method) end) end diff --git a/spec/router_spec.lua b/spec/router_spec.lua index a35fb77..246b2c2 100644 --- a/spec/router_spec.lua +++ b/spec/router_spec.lua @@ -41,12 +41,6 @@ describe("Router", function() assert.same(dummy.params, {id="2"}) end) - it("supports an extension on a param", function() - r:match("GET", "/foo/:id.json", write_dummy) - - r:execute("GET", "/foo/1.json") - assert.same(dummy.params, {id="1"}) - end) end) describe('when first param is a table', function() @@ -83,15 +77,6 @@ describe("Router", function() assert.same(dummy.params, {id="2"}) end) - it("supports an extension on a param", function() - r:match({ - GET = { - ["/foo/:id.json"] = write_dummy - } - }) - r:execute("GET", "/foo/1.json") - assert.same(dummy.params, {id="1"}) - end) end) end) @@ -139,13 +124,13 @@ describe("Router", function() it("gets url params with an extension", function() local f, params = r:resolve("GET", "/s/21.json") assert.equals(type(f), 'function') - assert.same(params, {id = "21"}) + assert.same(params, {id = "21.json"}) end) it("posts url params with an extension", function() local f, params = r:resolve("POST", "/s/21.json") assert.equals(type(f), 'function') - assert.same(params, {id = "21"}) + assert.same(params, {id = "21.json"}) end) it("gets with backtracking over url params", function() @@ -194,7 +179,7 @@ describe("Router", function() it("runs the specified function with a url param with an extension", function() r:execute("GET", "/s/21.json") - assert.same(dummy.params, {id = '21'}) + assert.same(dummy.params, {id = '21.json'}) end) it("runs the specified function with a url param in a post", function() @@ -204,7 +189,7 @@ describe("Router", function() it("runs the specified function with a url param in a post with an extension", function() r:execute("POST", "/s/21.json") - assert.same(dummy.params, {id = '21'}) + assert.same(dummy.params, {id = '21.json'}) end) describe('when given extra parameters', function()