summaryrefslogtreecommitdiffhomepage
path: root/modules
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2008-08-03 15:01:36 +0000
committerSteven Barth <steven@midlink.org>2008-08-03 15:01:36 +0000
commitf26e93beadda6cc361c4551777f1d728d9ddfa7d (patch)
tree84fd7adb7caef7123bf5c8943716fda85a223758 /modules
parente3097c4df37e0c12246b15c44cb3fc076bc256fe (diff)
admin-full, admin-mini: Added configuration backup, restore, reset page
admin-full, admin-mini: Fixed a bug in firmware upgrade preventing configuration files from being kept
Diffstat (limited to 'modules')
-rw-r--r--modules/admin-full/luasrc/controller/admin/system.lua70
-rw-r--r--modules/admin-full/luasrc/view/admin_system/applyreboot.htm21
-rw-r--r--modules/admin-full/luasrc/view/admin_system/backup.htm40
-rw-r--r--modules/admin-mini/luasrc/controller/mini/system.lua66
-rw-r--r--modules/admin-mini/luasrc/view/mini/applyreboot.htm21
-rw-r--r--modules/admin-mini/luasrc/view/mini/backup.htm40
6 files changed, 234 insertions, 24 deletions
diff --git a/modules/admin-full/luasrc/controller/admin/system.lua b/modules/admin-full/luasrc/controller/admin/system.lua
index 14fd813c3..01663a4c3 100644
--- a/modules/admin-full/luasrc/controller/admin/system.lua
+++ b/modules/admin-full/luasrc/controller/admin/system.lua
@@ -24,8 +24,9 @@ function index()
entry({"admin", "system", "sshkeys"}, call("action_sshkeys"), i18n("a_s_sshkeys", "SSH-SchlĂĽssel"), 30)
entry({"admin", "system", "system"}, cbi("admin_system/system"), i18n("system", "System"), 40)
entry({"admin", "system", "fstab"}, cbi("admin_system/fstab"), i18n("a_s_fstab", "Einhängepunkte"), 50)
- entry({"admin", "system", "upgrade"}, call("action_upgrade"), i18n("a_s_flash", "Firmwareupgrade"), 60)
- entry({"admin", "system", "reboot"}, call("action_reboot"), i18n("reboot", "Neu starten"), 70)
+ entry({"admin", "system", "backup"}, call("action_backup"), i18n("a_s_backup"), 60)
+ entry({"admin", "system", "upgrade"}, call("action_upgrade"), i18n("a_s_flash", "Firmwareupgrade"), 70)
+ entry({"admin", "system", "reboot"}, call("action_reboot"), i18n("reboot", "Neu starten"), 80)
end
function action_editor()
@@ -153,6 +154,47 @@ function action_packages()
install=install, remove=remove, update=update, upgrade=upgrade})
end
+function action_backup()
+ local reset_avail = luci.sys.exec([[grep '"rootfs_data"' /proc/mtd >/dev/null 2>&1]]) == 0
+ local restore_cmd = "gunzip | tar -xC/ >/dev/null 2>&1"
+ local backup_cmd = "tar -c %s | gzip 2>/dev/null"
+
+ local restore_fpi
+ luci.http.setfilehandler(
+ function(meta, chunk, eof)
+ if not restore_fpi then
+ restore_fpi = io.popen(restore_cmd, "w")
+ end
+ if chunk then
+ restore_fpi:write(chunk)
+ end
+ if eof then
+ restore_fpi:close()
+ end
+ end
+ )
+
+ local upload = luci.http.formvalue("archive")
+ local backup = luci.http.formvalue("backup")
+ local reset = reset_avail and luci.http.formvalue("reset")
+
+ if upload and #upload > 0 then
+ luci.template.render("admin_system/applyreboot")
+ luci.sys.reboot()
+ elseif backup then
+ luci.util.perror(backup_cmd:format(_keep_pattern()))
+ local backup_fpi = io.popen(backup_cmd:format(_keep_pattern()), "r")
+ luci.http.header('Content-Disposition', 'attachment; filename="backup.tar.gz"')
+ luci.http.prepare_content("application/x-targz")
+ luci.ltn12.pump.all(luci.ltn12.source.file(backup_fpi), luci.http.write)
+ elseif reset then
+ luci.template.render("admin_system/applyreboot")
+ luci.sys.exec("mtd -r erase rootfs_data")
+ else
+ luci.template.render("admin_system/backup", {reset_avail = reset_avail})
+ end
+end
+
function action_passwd()
local p1 = luci.http.formvalue("pwd1")
local p2 = luci.http.formvalue("pwd2")
@@ -221,18 +263,20 @@ function action_upgrade()
local keepcfg = luci.http.formvalue("keepcfg")
if plat and fname then
- local kpattern = nil
- if keepcfg then
- local files = luci.model.uci.get_all("luci", "flash_keep")
- if files.luci and files.luci.flash_keep then
- kpattern = ""
- for k,v in pairs(files.luci.flash_keep) do
- kpattern = kpattern .. " " .. v
- end
- end
- end
- ret = luci.sys.flash(tmpfile, kpattern)
+ ret = luci.sys.flash(tmpfile, keepcfg and _keep_pattern())
end
luci.template.render("admin_system/upgrade", {sysupgrade=plat, ret=ret})
+end
+
+function _keep_pattern()
+ local kpattern = ""
+ local files = luci.model.uci.get_all("luci", "flash_keep")
+ if files then
+ kpattern = ""
+ for k,v in pairs(files) do
+ kpattern = kpattern .. " " .. v
+ end
+ end
+ return kpattern
end \ No newline at end of file
diff --git a/modules/admin-full/luasrc/view/admin_system/applyreboot.htm b/modules/admin-full/luasrc/view/admin_system/applyreboot.htm
new file mode 100644
index 000000000..cbfa23d31
--- /dev/null
+++ b/modules/admin-full/luasrc/view/admin_system/applyreboot.htm
@@ -0,0 +1,21 @@
+<%#
+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$
+
+-%>
+<%+header%>
+<h1><%:system%></h1>
+<br />
+<p><% if msg then %><%=msg%><% else %><%:a_s_applyreboot1%><% end %></p>
+<p><%:a_s_reboot_running%></p>
+<script type="text/javascript">setTimeout("location='<%=controller%>'", 60000)</script>
+<%+footer%> \ No newline at end of file
diff --git a/modules/admin-full/luasrc/view/admin_system/backup.htm b/modules/admin-full/luasrc/view/admin_system/backup.htm
new file mode 100644
index 000000000..42d338e1d
--- /dev/null
+++ b/modules/admin-full/luasrc/view/admin_system/backup.htm
@@ -0,0 +1,40 @@
+<%#
+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$
+
+-%>
+<%+header%>
+<h1><%:system%></h1>
+<h2><%:a_s_backup%></h2>
+<p><%:a_s_backup1%></p>
+<br />
+<div>
+ <ul>
+ <li><a href="<%=REQUEST_URI%>?backup=kthxbye"><%:a_s_backup_backup%></a></li>
+ <% if reset_avail then -%>
+ <li><a href="<%=REQUEST_URI%>?reset=yarly" onclick="return confirm('<%:a_s_backup_reset1%>')"><%:a_s_backup_reset%></a></li>
+ <% end -%>
+ </ul>
+</div>
+
+<br />
+
+<form method="post" action="<%=REQUEST_URI%>" enctype="multipart/form-data">
+ <div class="left"><%:a_s_backup_archive%>:</div>
+ <div>
+ <input type="file" size="30" name="archive" />
+ </div>
+ <div>
+ <input type="submit" value="<%:a_s_backup_restore%>" />
+ </div>
+</form>
+<%+footer%> \ No newline at end of file
diff --git a/modules/admin-mini/luasrc/controller/mini/system.lua b/modules/admin-mini/luasrc/controller/mini/system.lua
index a4a07a672..e272a1fc7 100644
--- a/modules/admin-mini/luasrc/controller/mini/system.lua
+++ b/modules/admin-mini/luasrc/controller/mini/system.lua
@@ -22,10 +22,52 @@ function index()
entry({"mini", "system"}, alias("mini", "system", "index"), i18n("system"), 40)
entry({"mini", "system", "index"}, cbi("mini/system"), i18n("general"), 1)
entry({"mini", "system", "passwd"}, call("action_passwd"), i18n("a_s_changepw"), 10)
+ entry({"mini", "system", "backup"}, call("action_backup"), i18n("a_s_backup"), 80)
entry({"mini", "system", "upgrade"}, call("action_upgrade"), i18n("a_s_flash"), 90)
entry({"mini", "system", "reboot"}, call("action_reboot"), i18n("reboot"), 100)
end
+function action_backup()
+ local reset_avail = luci.sys.exec([[grep '"rootfs_data"' /proc/mtd >/dev/null 2>&1]]) == 0
+ local restore_cmd = "gunzip | tar -xC/ >/dev/null 2>&1"
+ local backup_cmd = "tar -c %s | gzip 2>/dev/null"
+
+ local restore_fpi
+ luci.http.setfilehandler(
+ function(meta, chunk, eof)
+ if not restore_fpi then
+ restore_fpi = io.popen(restore_cmd, "w")
+ end
+ if chunk then
+ restore_fpi:write(chunk)
+ end
+ if eof then
+ restore_fpi:close()
+ end
+ end
+ )
+
+ local upload = luci.http.formvalue("archive")
+ local backup = luci.http.formvalue("backup")
+ local reset = reset_avail and luci.http.formvalue("reset")
+
+ if upload and #upload > 0 then
+ luci.template.render("mini/applyreboot")
+ luci.sys.reboot()
+ elseif backup then
+ luci.util.perror(backup_cmd:format(_keep_pattern()))
+ local backup_fpi = io.popen(backup_cmd:format(_keep_pattern()), "r")
+ luci.http.header('Content-Disposition', 'attachment; filename="backup.tar.gz"')
+ luci.http.prepare_content("application/x-targz")
+ luci.ltn12.pump.all(luci.ltn12.source.file(backup_fpi), luci.http.write)
+ elseif reset then
+ luci.template.render("mini/applyreboot")
+ luci.sys.exec("mtd -r erase rootfs_data")
+ else
+ luci.template.render("mini/backup", {reset_avail = reset_avail})
+ end
+end
+
function action_reboot()
local reboot = luci.http.formvalue("reboot")
luci.template.render("mini/reboot", {reboot=reboot})
@@ -60,17 +102,7 @@ function action_upgrade()
local keepcfg = luci.http.formvalue("keepcfg")
if plat and fname then
- local kpattern = nil
- if keepcfg then
- local files = luci.model.uci.get_all("luci", "flash_keep")
- if files.luci and files.luci.flash_keep then
- kpattern = ""
- for k,v in pairs(files.luci.flash_keep) do
- kpattern = kpattern .. " " .. v
- end
- end
- end
- ret = luci.sys.flash(tmpfile, kpattern)
+ ret = luci.sys.flash(tmpfile, keepcfg and _keep_pattern())
end
luci.template.render("mini/upgrade", {sysupgrade=plat, ret=ret})
@@ -90,4 +122,16 @@ function action_passwd()
end
luci.template.render("mini/passwd", {stat=stat})
+end
+
+function _keep_pattern()
+ local kpattern = ""
+ local files = luci.model.uci.get_all("luci", "flash_keep")
+ if files then
+ kpattern = ""
+ for k,v in pairs(files) do
+ kpattern = kpattern .. " " .. v
+ end
+ end
+ return kpattern
end \ No newline at end of file
diff --git a/modules/admin-mini/luasrc/view/mini/applyreboot.htm b/modules/admin-mini/luasrc/view/mini/applyreboot.htm
new file mode 100644
index 000000000..cbfa23d31
--- /dev/null
+++ b/modules/admin-mini/luasrc/view/mini/applyreboot.htm
@@ -0,0 +1,21 @@
+<%#
+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$
+
+-%>
+<%+header%>
+<h1><%:system%></h1>
+<br />
+<p><% if msg then %><%=msg%><% else %><%:a_s_applyreboot1%><% end %></p>
+<p><%:a_s_reboot_running%></p>
+<script type="text/javascript">setTimeout("location='<%=controller%>'", 60000)</script>
+<%+footer%> \ No newline at end of file
diff --git a/modules/admin-mini/luasrc/view/mini/backup.htm b/modules/admin-mini/luasrc/view/mini/backup.htm
new file mode 100644
index 000000000..42d338e1d
--- /dev/null
+++ b/modules/admin-mini/luasrc/view/mini/backup.htm
@@ -0,0 +1,40 @@
+<%#
+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$
+
+-%>
+<%+header%>
+<h1><%:system%></h1>
+<h2><%:a_s_backup%></h2>
+<p><%:a_s_backup1%></p>
+<br />
+<div>
+ <ul>
+ <li><a href="<%=REQUEST_URI%>?backup=kthxbye"><%:a_s_backup_backup%></a></li>
+ <% if reset_avail then -%>
+ <li><a href="<%=REQUEST_URI%>?reset=yarly" onclick="return confirm('<%:a_s_backup_reset1%>')"><%:a_s_backup_reset%></a></li>
+ <% end -%>
+ </ul>
+</div>
+
+<br />
+
+<form method="post" action="<%=REQUEST_URI%>" enctype="multipart/form-data">
+ <div class="left"><%:a_s_backup_archive%>:</div>
+ <div>
+ <input type="file" size="30" name="archive" />
+ </div>
+ <div>
+ <input type="submit" value="<%:a_s_backup_restore%>" />
+ </div>
+</form>
+<%+footer%> \ No newline at end of file