summaryrefslogtreecommitdiffhomepage
path: root/modules/base/luasrc/controller
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2014-06-11 13:29:05 +0000
committerJo-Philipp Wich <jow@openwrt.org>2014-06-11 13:29:05 +0000
commit7043c30e0e55bbbfacdddf97619b6bae96d20ddb (patch)
treeece3254350b3ba01ba3135caed2364cc7ca7804c /modules/base/luasrc/controller
parentbbb44cf245c11bc0c1d59e836007c9e8c3bfa209 (diff)
build: introduce luci-base
Merges libs/core, libs/ipkg, libs/web, libs/sys, libs/sgi-cgi, libs/sgi-uhttpd, modules/admin-core, themes/base and protcols/core into modules/base and renames luci-lib-core to luci-base.
Diffstat (limited to 'modules/base/luasrc/controller')
-rw-r--r--modules/base/luasrc/controller/admin/servicectl.lua60
1 files changed, 60 insertions, 0 deletions
diff --git a/modules/base/luasrc/controller/admin/servicectl.lua b/modules/base/luasrc/controller/admin/servicectl.lua
new file mode 100644
index 0000000000..753d2c77f1
--- /dev/null
+++ b/modules/base/luasrc/controller/admin/servicectl.lua
@@ -0,0 +1,60 @@
+--[[
+LuCI - Lua Configuration Interface
+
+Copyright 2010 Jo-Philipp Wich <xm@subsignal.org>
+
+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.admin.servicectl", package.seeall)
+
+function index()
+ entry({"servicectl"}, alias("servicectl", "status")).sysauth = "root"
+ entry({"servicectl", "status"}, call("action_status")).leaf = true
+ entry({"servicectl", "restart"}, call("action_restart")).leaf = true
+end
+
+function action_status()
+ local data = nixio.fs.readfile("/var/run/luci-reload-status")
+ if data then
+ luci.http.write("/etc/config/")
+ luci.http.write(data)
+ else
+ luci.http.write("finish")
+ end
+end
+
+function action_restart(args)
+ local uci = require "luci.model.uci".cursor()
+ if args then
+ local service
+ local services = { }
+
+ for service in args:gmatch("[%w_-]+") do
+ services[#services+1] = service
+ end
+
+ local command = uci:apply(services, true)
+ if nixio.fork() == 0 then
+ local i = nixio.open("/dev/null", "r")
+ local o = nixio.open("/dev/null", "w")
+
+ nixio.dup(i, nixio.stdin)
+ nixio.dup(o, nixio.stdout)
+
+ i:close()
+ o:close()
+
+ nixio.exec("/bin/sh", unpack(command))
+ else
+ luci.http.write("OK")
+ os.exit(0)
+ end
+ end
+end