diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2014-12-03 15:17:05 +0100 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2015-01-08 16:26:20 +0100 |
commit | 1bb4822dca6113f73e3bc89e2acf15935e6f8e92 (patch) | |
tree | 35e16f100466e4e00657199b38bb3d87d52bf73f /modules/rpc | |
parent | 9edd0e46c3f880727738ce8ca6ff1c8b85f99ef4 (diff) |
Rework LuCI build system
* Rename subdirectories to their repective OpenWrt package names
* Make each LuCI module its own standalone package
* Deploy a shared luci.mk which is used by each module Makefile
Signed-off-by: Jo-Philipp Wich <jow@openwrt.org>
Diffstat (limited to 'modules/rpc')
-rw-r--r-- | modules/rpc/Makefile | 2 | ||||
-rw-r--r-- | modules/rpc/luasrc/controller/rpc.lua | 166 | ||||
-rw-r--r-- | modules/rpc/luasrc/jsonrpc.lua | 94 | ||||
-rw-r--r-- | modules/rpc/luasrc/jsonrpcbind/uci.lua | 94 |
4 files changed, 0 insertions, 356 deletions
diff --git a/modules/rpc/Makefile b/modules/rpc/Makefile deleted file mode 100644 index 81a96f6a83..0000000000 --- a/modules/rpc/Makefile +++ /dev/null @@ -1,2 +0,0 @@ -include ../../build/config.mk -include ../../build/module.mk
\ No newline at end of file diff --git a/modules/rpc/luasrc/controller/rpc.lua b/modules/rpc/luasrc/controller/rpc.lua deleted file mode 100644 index 359184c744..0000000000 --- a/modules/rpc/luasrc/controller/rpc.lua +++ /dev/null @@ -1,166 +0,0 @@ ---[[ -LuCI - Lua Configuration Interface - -Copyright 2008 Steven Barth <steven@midlink.org> -Copyright 2008 Jo-Philipp Wich <xm@leipzig.freifunk.net> - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -$Id$ -]]-- - -local require = require -local pairs = pairs -local print = print -local pcall = pcall -local table = table - -module "luci.controller.rpc" - -function index() - local function authenticator(validator, accs) - local auth = luci.http.formvalue("auth", true) - if auth then -- if authentication token was given - local sdat = luci.sauth.read(auth) - if sdat then -- if given token is valid - if sdat.user and luci.util.contains(accs, sdat.user) then - return sdat.user, auth - end - end - end - luci.http.status(403, "Forbidden") - end - - local rpc = node("rpc") - rpc.sysauth = "root" - rpc.sysauth_authenticator = authenticator - rpc.notemplate = true - - entry({"rpc", "uci"}, call("rpc_uci")) - entry({"rpc", "fs"}, call("rpc_fs")) - entry({"rpc", "sys"}, call("rpc_sys")) - entry({"rpc", "ipkg"}, call("rpc_ipkg")) - entry({"rpc", "auth"}, call("rpc_auth")).sysauth = false -end - -function rpc_auth() - local jsonrpc = require "luci.jsonrpc" - local sauth = require "luci.sauth" - local http = require "luci.http" - local sys = require "luci.sys" - local ltn12 = require "luci.ltn12" - local util = require "luci.util" - - local loginstat - - local server = {} - server.challenge = function(user, pass) - local sid, token, secret - - if sys.user.checkpasswd(user, pass) then - sid = sys.uniqueid(16) - token = sys.uniqueid(16) - secret = sys.uniqueid(16) - - http.header("Set-Cookie", "sysauth=" .. sid.."; path=/") - sauth.reap() - sauth.write(sid, { - user=user, - token=token, - secret=secret - }) - end - - return sid and {sid=sid, token=token, secret=secret} - end - - server.login = function(...) - local challenge = server.challenge(...) - return challenge and challenge.sid - end - - http.prepare_content("application/json") - ltn12.pump.all(jsonrpc.handle(server, http.source()), http.write) -end - -function rpc_uci() - if not pcall(require, "luci.model.uci") then - luci.http.status(404, "Not Found") - return nil - end - local uci = require "luci.jsonrpcbind.uci" - local jsonrpc = require "luci.jsonrpc" - local http = require "luci.http" - local ltn12 = require "luci.ltn12" - - http.prepare_content("application/json") - ltn12.pump.all(jsonrpc.handle(uci, http.source()), http.write) -end - -function rpc_fs() - local util = require "luci.util" - local io = require "io" - local fs2 = util.clone(require "nixio.fs") - local jsonrpc = require "luci.jsonrpc" - local http = require "luci.http" - local ltn12 = require "luci.ltn12" - - function fs2.readfile(filename) - local stat, mime = pcall(require, "mime") - if not stat then - error("Base64 support not available. Please install LuaSocket.") - end - - local fp = io.open(filename) - if not fp then - return nil - end - - local output = {} - local sink = ltn12.sink.table(output) - local source = ltn12.source.chain(ltn12.source.file(fp), mime.encode("base64")) - return ltn12.pump.all(source, sink) and table.concat(output) - end - - function fs2.writefile(filename, data) - local stat, mime = pcall(require, "mime") - if not stat then - error("Base64 support not available. Please install LuaSocket.") - end - - local file = io.open(filename, "w") - local sink = file and ltn12.sink.chain(mime.decode("base64"), ltn12.sink.file(file)) - return sink and ltn12.pump.all(ltn12.source.string(data), sink) or false - end - - http.prepare_content("application/json") - ltn12.pump.all(jsonrpc.handle(fs2, http.source()), http.write) -end - -function rpc_sys() - local sys = require "luci.sys" - local jsonrpc = require "luci.jsonrpc" - local http = require "luci.http" - local ltn12 = require "luci.ltn12" - - http.prepare_content("application/json") - ltn12.pump.all(jsonrpc.handle(sys, http.source()), http.write) -end - -function rpc_ipkg() - if not pcall(require, "luci.model.ipkg") then - luci.http.status(404, "Not Found") - return nil - end - local ipkg = require "luci.model.ipkg" - local jsonrpc = require "luci.jsonrpc" - local http = require "luci.http" - local ltn12 = require "luci.ltn12" - - http.prepare_content("application/json") - ltn12.pump.all(jsonrpc.handle(ipkg, http.source()), http.write) -end diff --git a/modules/rpc/luasrc/jsonrpc.lua b/modules/rpc/luasrc/jsonrpc.lua deleted file mode 100644 index 71c95d549b..0000000000 --- a/modules/rpc/luasrc/jsonrpc.lua +++ /dev/null @@ -1,94 +0,0 @@ ---[[ -LuCI - Lua Configuration Interface - -Copyright 2008 Steven Barth <steven@midlink.org> -Copyright 2008 Jo-Philipp Wich <xm@leipzig.freifunk.net> - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -$Id$ -]]-- - -module("luci.jsonrpc", package.seeall) -require "luci.json" - -function resolve(mod, method) - local path = luci.util.split(method, ".") - - for j=1, #path-1 do - if not type(mod) == "table" then - break - end - mod = rawget(mod, path[j]) - if not mod then - break - end - end - mod = type(mod) == "table" and rawget(mod, path[#path]) or nil - if type(mod) == "function" then - return mod - end -end - -function handle(tbl, rawsource, ...) - local decoder = luci.json.Decoder() - local stat = luci.ltn12.pump.all(rawsource, decoder:sink()) - local json = decoder:get() - local response - local success = false - - if stat then - if type(json.method) == "string" - and (not json.params or type(json.params) == "table") then - local method = resolve(tbl, json.method) - if method then - response = reply(json.jsonrpc, json.id, - proxy(method, unpack(json.params or {}))) - else - response = reply(json.jsonrpc, json.id, - nil, {code=-32601, message="Method not found."}) - end - else - response = reply(json.jsonrpc, json.id, - nil, {code=-32600, message="Invalid request."}) - end - else - response = reply("2.0", nil, - nil, {code=-32700, message="Parse error."}) - end - - return luci.json.Encoder(response, ...):source() -end - -function reply(jsonrpc, id, res, err) - require "luci.json" - id = id or luci.json.null - - -- 1.0 compatibility - if jsonrpc ~= "2.0" then - jsonrpc = nil - res = res or luci.json.null - err = err or luci.json.null - end - - return {id=id, result=res, error=err, jsonrpc=jsonrpc} -end - -function proxy(method, ...) - 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 - if #res <= 1 then - return res[1] or luci.json.null - else - return res - end - end -end diff --git a/modules/rpc/luasrc/jsonrpcbind/uci.lua b/modules/rpc/luasrc/jsonrpcbind/uci.lua deleted file mode 100644 index 195398674f..0000000000 --- a/modules/rpc/luasrc/jsonrpcbind/uci.lua +++ /dev/null @@ -1,94 +0,0 @@ ---[[ -LuCI - Lua Configuration Interface - -Copyright 2008 Steven Barth <steven@midlink.org> -Copyright 2008 Jo-Philipp Wich <xm@leipzig.freifunk.net> - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - -http://www.apache.org/licenses/LICENSE-2.0 - -$Id$ -]]-- - -local uci = require "luci.model.uci".cursor() -local ucis = require "luci.model.uci".cursor_state() -local table = require "table" - - -module "luci.jsonrpcbind.uci" -_M, _PACKAGE, _NAME = nil, nil, nil - -function add(config, ...) - uci:load(config) - local stat = uci:add(config, ...) - return uci:save(config) and stat -end - -function apply(config) - return uci:apply(config) -end - -function changes(...) - return uci:changes(...) -end - -function commit(config) - return uci:load(config) and uci:commit(config) -end - -function delete(config, ...) - uci:load(config) - return uci:delete(config, ...) and uci:save(config) -end - -function delete_all(config, ...) - uci:load(config) - return uci:delete_all(config, ...) and uci:save(config) -end - -function foreach(config, stype) - uci:load(config) - local sections = {} - - return uci:foreach(config, stype, function(section) - table.insert(sections, section) - end) and sections -end - -function get(config, ...) - uci:load(config) - return uci:get(config, ...) -end - -function get_all(config, ...) - uci:load(config) - return uci:get_all(config, ...) -end - -function get_state(config, ...) - ucis:load(config) - return ucis:get(config, ...) -end - -function revert(config) - return uci:load(config) and uci:revert(config) -end - -function section(config, ...) - uci:load(config) - return uci:section(config, ...) and uci:save(config) -end - -function set(config, ...) - uci:load(config) - return uci:set(config, ...) and uci:save(config) -end - -function tset(config, ...) - uci:load(config) - return uci:tset(config, ...) and uci:save(config) -end - |