X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fluci.git;a=blobdiff_plain;f=modules%2Fadmin-full%2Fluasrc%2Fmodel%2Fcbi%2Fadmin_system%2Fsystem.lua;h=f6826c090b998da8f2667692319051e2ebaee1af;hp=260bac17696b659da3dffa4000274eaa35c96404;hb=819fa18e163ab4f29f5978be80f892b6c883e518;hpb=94836433e5a181bb0b3568bdb358f31a1b4f3e5f diff --git a/modules/admin-full/luasrc/model/cbi/admin_system/system.lua b/modules/admin-full/luasrc/model/cbi/admin_system/system.lua index 260bac176..f6826c090 100644 --- a/modules/admin-full/luasrc/model/cbi/admin_system/system.lua +++ b/modules/admin-full/luasrc/model/cbi/admin_system/system.lua @@ -2,6 +2,7 @@ LuCI - Lua Configuration Interface Copyright 2008 Steven Barth +Copyright 2011 Jo-Philipp Wich Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. @@ -11,29 +12,254 @@ You may obtain a copy of the License at $Id$ ]]-- -require("luci.http.protocol.date") -m = Map("system", translate("system"), translate("a_s_desc")) +require("luci.sys") +require("luci.sys.zoneinfo") +require("luci.tools.webadmin") +require("luci.fs") +require("luci.config") -s = m:section(TypedSection, "system", "") +m = Map("system", translate("System"), translate("Here you can configure the basic aspects of your device like its hostname or the timezone.")) +m:chain("luci") + +local has_rdate = false + +m.uci:foreach("system", "rdate", + function() + has_rdate = true + return false + end) + + +s = m:section(TypedSection, "system", translate("System Properties")) s.anonymous = true +s.addremove = false + +s:tab("general", translate("General Settings")) +s:tab("logging", translate("Logging")) +s:tab("language", translate("Language and Style")) + + +-- +-- System Properties +-- + +local system, model, memtotal, memcached, membuffers, memfree = luci.sys.sysinfo() +local uptime = luci.sys.uptime() + +s:taboption("general", DummyValue, "_system", translate("System")).value = system +s:taboption("general", DummyValue, "_cpu", translate("Processor")).value = model + +s:taboption("general", DummyValue, "_kernel", translate("Kernel")).value = + luci.util.exec("uname -r") or "?" + +local load1, load5, load15 = luci.sys.loadavg() +s:taboption("general", DummyValue, "_la", translate("Load")).value = + string.format("%.2f, %.2f, %.2f", load1, load5, load15) + +s:taboption("general", DummyValue, "_memtotal", translate("Memory")).value = + string.format("%.2f MB (%.0f%% %s, %.0f%% %s, %.0f%% %s)", + tonumber(memtotal) / 1024, + 100 * memcached / memtotal, + tostring(translate("cached")), + 100 * membuffers / memtotal, + tostring(translate("buffered")), + 100 * memfree / memtotal, + tostring(translate("free")) +) + +s:taboption("general", DummyValue, "_systime", translate("Local Time")).value = + os.date("%c") + +s:taboption("general", DummyValue, "_uptime", translate("Uptime")).value = + luci.tools.webadmin.date_format(tonumber(uptime)) + +hn = s:taboption("general", Value, "hostname", translate("Hostname")) +hn.datatype = "hostname" +function hn.write(self, section, value) + Value.write(self, section, value) + luci.sys.hostname(value) +end + + +tz = s:taboption("general", ListValue, "zonename", translate("Timezone")) +tz:value("UTC") + +for i, zone in ipairs(luci.sys.zoneinfo.TZ) do + tz:value(zone[1]) +end + +function tz.write(self, section, value) + local function lookup_zone(title) + for _, zone in ipairs(luci.sys.zoneinfo.TZ) do + if zone[1] == title then return zone[2] end + end + end + + AbstractValue.write(self, section, value) + local timezone = lookup_zone(value) or "GMT0" + self.map.uci:set("system", section, "timezone", timezone) + luci.fs.writefile("/etc/TZ", timezone .. "\n") +end + + +-- +-- Logging +-- + +o = s:taboption("logging", Value, "log_size", translate("System log buffer size"), "kiB") +o.optional = true +o.placeholder = 16 +o.datatype = "uinteger" + +o = s:taboption("logging", Value, "log_ip", translate("External system log server")) +o.optional = true +o.placeholder = "0.0.0.0" +o.datatype = "ip4addr" + +o = s:taboption("logging", Value, "log_port", translate("External system log server port")) +o.optional = true +o.placeholder = 514 +o.datatype = "port" + +o = s:taboption("logging", ListValue, "conloglevel", translate("Log output level")) +o:value(7, translate("Debug")) +o:value(6, translate("Info")) +o:value(5, translate("Notice")) +o:value(4, translate("Warning")) +o:value(3, translate("Error")) +o:value(2, translate("Critical")) +o:value(1, translate("Alert")) +o:value(0, translate("Emergency")) + +o = s:taboption("logging", ListValue, "cronloglevel", translate("Cron Log Level")) +o.default = 8 +o:value(5, translate("Debug")) +o:value(8, translate("Normal")) +o:value(9, translate("Warning")) + + +-- +-- Langauge & Style +-- + +o = s:taboption("language", ListValue, "_lang", translate("Language")) +o:value("auto") + +local i18ndir = luci.i18n.i18ndir .. "base." +for k, v in luci.util.kspairs(luci.config.languages) do + local file = i18ndir .. k:gsub("_", "-") + if k:sub(1, 1) ~= "." and luci.fs.access(file .. ".lmo") then + o:value(k, v) + end +end + +function o.cfgvalue(...) + return m.uci:get("luci", "main", "lang") +end + +function o.write(self, section, value) + m.uci:set("luci", "main", "lang", value) +end + + +o = s:taboption("language", ListValue, "_mediaurlbase", translate("Design")) +for k, v in pairs(luci.config.themes) do + if k:sub(1, 1) ~= "." then + o:value(v, k) + end +end + +function o.cfgvalue(...) + return m.uci:get("luci", "main", "mediaurlbase") +end + +function o.write(self, section, value) + m.uci:set("luci", "main", "mediaurlbase", value) +end + + +-- +-- Rdate +-- + +if has_rdate then + m3= Map("timeserver", translate("Time Server (rdate)")) + s = m3:section(TypedSection, "timeserver") + s.anonymous = true + s.addremove = true + s.template = "cbi/tblsection" + s.rmempty = true + + s:option(Value, "hostname", translate("Name")) + i = s:option(ListValue, "interface", translate("Interface")) + i:value("", translate("Default")) + m3.uci:foreach("network", "interface", + function (section) + local ifc = section[".name"] + if ifc ~= "loopback" then + i:value(ifc) + end + end + ) +end + + +m2 = Map("luci") + +f = m2:section(NamedSection, "main", "core", translate("Files to be kept when flashing a new firmware")) + +f:tab("detected", translate("Detected Files"), + translate("The following files are detected by the system and will be kept automatically during sysupgrade")) + +f:tab("custom", translate("Custom Files"), + translate("This is a list of shell glob patterns for matching files and directories to include during sysupgrade")) + +d = f:taboption("detected", DummyValue, "_detected", translate("Detected files")) +d.rawhtml = true +d.cfgvalue = function(s) + local list = io.popen( + "( find $(sed -ne '/^[[:space:]]*$/d; /^#/d; p' /etc/sysupgrade.conf " .. + "/lib/upgrade/keep.d/* 2>/dev/null) -type f 2>/dev/null; " .. + "opkg list-changed-conffiles ) | sort -u" + ) + + if list then + local files = { "" + + return table.concat(files, "") + end + + return "" .. translate("No files found") .. "" +end + +c = f:taboption("custom", TextValue, "_custom", translate("Custom files")) +c.rmempty = false +c.cols = 70 +c.rows = 30 + +c.cfgvalue = function(self, section) + return nixio.fs.readfile("/etc/sysupgrade.conf") +end + +c.write = function(self, section, value) + value = value:gsub("\r\n?", "\n") + return nixio.fs.writefile("/etc/sysupgrade.conf", value) +end + -s:option(Value, "hostname", translate("hostname")) - -tz = s:option(ListValue, "timezone", translate("timezone")) -for k, offset in luci.util.vspairs(luci.http.protocol.date.TZ) do - local zone = k:upper() - local osgn = (offset > 0 and "+" or "") - local ohrs = math.floor(offset / 3600) - local omin = (offset % 3600) / 60 - - local ptz = zone .. osgn .. (ohrs ~= 0 and ohrs or "") .. (omin ~= 0 and ":" .. omin or "") - local dtz = string.format("%+03d:%02d ", ohrs, omin) .. zone - - tz:value(ptz, dtz) -end - -s:option(Value, "log_size", nil, "kiB").optional = true -s:option(Value, "log_ip").optional = true -s:option(Value, "conloglevel").optional = true -return m \ No newline at end of file +return m, m3, m2