From d1710f7e0c85a9b92de938fae3ef2602741f86d9 Mon Sep 17 00:00:00 2001 From: Jo-Philipp Wich Date: Tue, 20 Dec 2011 19:05:17 +0000 Subject: [PATCH] luci-0.10: merge r8127 and r8128 --- libs/core/luasrc/model/uci.lua | 11 +++++++---- .../admin-core/luasrc/controller/admin/servicectl.lua | 19 ++++++++++--------- 2 files changed, 17 insertions(+), 13 deletions(-) diff --git a/libs/core/luasrc/model/uci.lua b/libs/core/luasrc/model/uci.lua index e42856bd5..a39456304 100644 --- a/libs/core/luasrc/model/uci.lua +++ b/libs/core/luasrc/model/uci.lua @@ -32,7 +32,7 @@ local table = require "table" local setmetatable, rawget, rawset = setmetatable, rawget, rawset local require, getmetatable = require, getmetatable local error, pairs, ipairs = error, pairs, ipairs -local type, tostring, tonumber = type, tostring, tonumber +local type, tostring, tonumber, unpack = type, tostring, tonumber, unpack --- LuCI UCI model library. -- The typical workflow for UCI is: Get a cursor instance from the @@ -69,9 +69,12 @@ local Cursor = getmetatable(inst) -- @param command Don't apply only return the command function Cursor.apply(self, configlist, command) configlist = self:_affected(configlist) - local reloadcmd = "/sbin/luci-reload " .. table.concat(configlist, " ") - - return command and reloadcmd or os.execute(reloadcmd .. " >/dev/null 2>&1") + if command then + return { "/sbin/luci-reload", unpack(configlist) } + else + return os.execute("/sbin/luci-reload %s >/dev/null 2>&1" + % table.concat(configlist, " ")) + end end diff --git a/modules/admin-core/luasrc/controller/admin/servicectl.lua b/modules/admin-core/luasrc/controller/admin/servicectl.lua index ccd54da76..68a59364c 100644 --- a/modules/admin-core/luasrc/controller/admin/servicectl.lua +++ b/modules/admin-core/luasrc/controller/admin/servicectl.lua @@ -15,12 +15,9 @@ $Id$ module("luci.controller.admin.servicectl", package.seeall) function index() - luci.i18n.loadc("base") - local i18n = luci.i18n.translate - - entry({"servicectl"}, alias("servicectl", "status"), nil, 1).sysauth = "root" - entry({"servicectl", "status"}, call("action_status"), nil, 2).leaf = true - entry({"servicectl", "restart"}, call("action_restart"), nil, 3).leaf = true + 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() @@ -34,14 +31,18 @@ function action_status() end function action_restart() - if luci.dispatcher.context.requestpath[3] then + local uci = require "luci.model.uci".cursor() + local rqp = luci.dispatcher.context.requestpath + + if rqp[3] then local service local services = { } - for service in luci.dispatcher.context.requestpath[3]:gmatch("[%w_-]+") do + for service in rqp[3]: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") @@ -52,7 +53,7 @@ function action_restart() i:close() o:close() - nixio.exec("/bin/sh", "/sbin/luci-reload", unpack(services)) + nixio.exec("/bin/sh", unpack(command)) else luci.http.write("OK") os.exit(0) -- 2.11.0