summaryrefslogtreecommitdiffhomepage
path: root/modules/rpc/luasrc/controller/rpc.lua
blob: a004d0dd9257d2b66fc16888852200cf9e88f438 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
--[[
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.controller.rpc", package.seeall)

function index()
	local function authenticator(validator, accs)
		local args = luci.dispatcher.context.args
		if args and #args > 0 then
			local user = luci.sauth.read(args[1])
			if user and luci.util.contains(accs, user) then
				return user
			end
		end
		luci.http.status(403, "Forbidden")
	end
	
	uci = entry({"rpc", "uci"}, call("rpc_uci"))
	uci.sysauth = "root"
	uci.sysauth_authenticator = authenticator
	uci.leaf = true
	
	uci = entry({"rpc", "auth"}, call("rpc_auth"))
end

function rpc_auth()
	require "luci.jsonrpc"
	require "luci.sauth"
	
	luci.http.setfilehandler()
	
	local loginstat
	
	local server = {}
	server.login = function(user, pass)
		local sid
		
		if luci.sys.user.checkpasswd(user, pass) then
			sid = luci.sys.uniqueid(16)
			luci.http.header("Set-Cookie", "sysauth=" .. sid.."; path=/")
			luci.sauth.write(sid, user)
		end
		
		return sid
	end
	
	luci.http.prepare_content("application/json")
	luci.http.write(luci.jsonrpc.handle(server, luci.http.content()))
	
	return loginstat
end

function rpc_uci()
	
end