summaryrefslogtreecommitdiffhomepage
path: root/modules/rpc/luasrc/jsonrpc.lua
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2008-08-22 22:13:54 +0000
committerSteven Barth <steven@midlink.org>2008-08-22 22:13:54 +0000
commit3bcab661283d5b9886e46d6bcdab0e756b044997 (patch)
treef54e9021438e8c7a28abf238f07279c3198620cd /modules/rpc/luasrc/jsonrpc.lua
parent69cab40a9aa145adcba2ca41841884109452774e (diff)
RPC initial authentication API completed
Diffstat (limited to 'modules/rpc/luasrc/jsonrpc.lua')
-rw-r--r--modules/rpc/luasrc/jsonrpc.lua13
1 files changed, 9 insertions, 4 deletions
diff --git a/modules/rpc/luasrc/jsonrpc.lua b/modules/rpc/luasrc/jsonrpc.lua
index 61524476a..84a7f7056 100644
--- a/modules/rpc/luasrc/jsonrpc.lua
+++ b/modules/rpc/luasrc/jsonrpc.lua
@@ -14,9 +14,10 @@ $Id$
]]--
module("luci.jsonrpc", package.seeall)
+require "luci.json"
function resolve(mod, method)
- local path = luci.util.split(value, ".")
+ local path = luci.util.split(method, ".")
for j=1, #path-1 do
if not type(mod) == "table" then
@@ -43,7 +44,7 @@ function handle(tbl, rawdata)
and (not json.params or type(json.params) == "table") then
if tbl[json.method] then
response = reply(json.jsonrpc, json.id,
- proxy(resolve(tbl, json.method), unpack(json.params)))
+ proxy(resolve(tbl, json.method), unpack(json.params or {})))
else
response = reply(json.jsonrpc, json.id,
nil, {code=-32601, message="Method not found."})
@@ -75,12 +76,16 @@ function reply(jsonrpc, id, res, err)
end
function proxy(method, ...)
- local res = {luci.util.copcall(method, unpack(params))}
+ local res = {luci.util.copcall(method, ...)}
local stat = table.remove(res, 1)
if not stat then
return nil, {code=-32602, message="Invalid params.", data=table.remove(res, 1)}
else
- return (#res <= 1) and res[1] or res
+ if #res <= 1 then
+ return res[1] or luci.json.Null
+ else
+ return res
+ end
end
end \ No newline at end of file