From: Jo-Philipp Wich
Date: Tue, 30 Jun 2009 04:50:24 +0000 (+0000)
Subject: luci-0.9: merge r4941-r4944
X-Git-Tag: 0.9.0~175
X-Git-Url: https://git.archive.openwrt.org/?a=commitdiff_plain;h=836e65e00e346d7acf729ba98fdb2dc3d747dc10;p=project%2Fluci.git
luci-0.9: merge r4941-r4944
---
diff --git a/modules/freifunk/htdocs/luci-static/flashing.html b/modules/freifunk/htdocs/luci-static/flashing.html
new file mode 100644
index 000000000..f2de57507
--- /dev/null
+++ b/modules/freifunk/htdocs/luci-static/flashing.html
@@ -0,0 +1,84 @@
+
+
+
+
+
+ LuCI - System Upgrade
+
+
+
+
+
+
+
+
+
Performing Upgrade
+
+
+ The System is flashing now. The procedure can take up to 20 minutes,
+ please be patient and wait until this page reloads itself.
+
+
+
+ Remaining time (estimated): unknown
+
+
+
+
+
diff --git a/modules/freifunk/htdocs/luci-static/resources/flashing.gif b/modules/freifunk/htdocs/luci-static/resources/flashing.gif
new file mode 100644
index 000000000..e207fc56a
Binary files /dev/null and b/modules/freifunk/htdocs/luci-static/resources/flashing.gif differ
diff --git a/modules/freifunk/luasrc/controller/freifunk/remote_update.lua b/modules/freifunk/luasrc/controller/freifunk/remote_update.lua
new file mode 100644
index 000000000..badfbf2da
--- /dev/null
+++ b/modules/freifunk/luasrc/controller/freifunk/remote_update.lua
@@ -0,0 +1,63 @@
+--[[
+LuCI - Lua Configuration Interface
+
+Copyright 2009 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.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+$Id: freifunk.lua 4649 2009-05-26 18:30:00Z jow $
+]]--
+
+local nixio = require "nixio"
+
+module("luci.controller.freifunk.remote_update", package.seeall)
+
+function index()
+ local i18n = luci.i18n.translate
+
+ entry({"admin", "system", "remote_update"}, call("act_remote_update"),
+ i18n("ff_remote_update", "Freifunk Remote Update"), 90)
+end
+
+function act_remote_update()
+ if luci.http.formvalue("flash") == "1" then
+ if luci.http.formvalue("confirm") == "1" then
+ local nobackup = ( luci.http.formvalue("keepcfg") ~= "1" )
+ local noverify = ( luci.http.formvalue("verify") ~= "1" )
+
+ luci.http.redirect("/luci-static/flashing.html")
+
+ os.execute("start-stop-daemon -S -b -x /usr/sbin/remote-update -- %s%s-s 5 -y" % {
+ noverify and "-v " or "",
+ nobackup and "-n " or ""
+ })
+ else
+ luci.template.render("freifunk/remote_update", {confirm=1})
+ end
+ else
+ local fd = io.popen("remote-update -c")
+ local update = { }
+
+ if fd then
+ while true do
+ local ln=fd:read("*l")
+
+ if not ln then break
+ elseif ln:find("Local: ") then update.locvar = ln:match("Local: (%d+)")
+ elseif ln:find("Remote: ") then update.remver = ln:match("Remote: (%d+)")
+ elseif ln == "--" then update.info = ""
+ elseif update.info ~= nil then
+ update.info = update.info .. ln .. "\n"
+ end
+ end
+
+ fd:close()
+ end
+
+ luci.template.render("freifunk/remote_update", {update=update})
+ end
+end
diff --git a/modules/freifunk/luasrc/view/freifunk/remote_update.htm b/modules/freifunk/luasrc/view/freifunk/remote_update.htm
new file mode 100644
index 000000000..3dfaf5d5c
--- /dev/null
+++ b/modules/freifunk/luasrc/view/freifunk/remote_update.htm
@@ -0,0 +1,59 @@
+<%#
+LuCI - Lua Configuration Interface
+Copyright 2008 Steven Barth
+Copyright 2008 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.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+$Id: contact.htm 3529 2008-10-07 13:10:24Z jow $
+
+-%>
+<%+header%>
+
+<%:ff_remote_update Freifunk Remote Update%>
+
+<%:ff_remote_update_desc Check for new firmware versions and perform automatic updates.%>
+
+<% if update then %>
+
+ <% if update.info then %>
+ <%:ff_remote_update_available Update available!%>
+
+ <%=update.info%>
+ <% else %>
+ <%:ff_remote_update_uptodate The installed firmware is the most recent version.%>
+
+ <% end %>
+
+
+
+
+
+<% elseif confirm then %>
+
+ <%:ff_remote_update_settings Update Settings%>
+
+
+
+
+<% end %>
+
+<%+footer%>
diff --git a/modules/freifunk/root/etc/config/freifunk b/modules/freifunk/root/etc/config/freifunk
index 49112894c..d6f3d57df 100644
--- a/modules/freifunk/root/etc/config/freifunk
+++ b/modules/freifunk/root/etc/config/freifunk
@@ -78,6 +78,7 @@ config defaults time
config defaults upgrade
option repository "http://dev.luci.freifunk-halle.net/freifunk-snapshots"
+ option rssfeed "http://firmware.leipzig.freifunk.net/kamikaze/.rss.xml"
config community leipzig
option name "Freifunk Leipzig"
diff --git a/modules/freifunk/root/usr/sbin/remote-update b/modules/freifunk/root/usr/sbin/remote-update
index 3f50f3207..67751d6cf 100755
--- a/modules/freifunk/root/usr/sbin/remote-update
+++ b/modules/freifunk/root/usr/sbin/remote-update
@@ -49,9 +49,14 @@ find_local_checksum()
echo $1
}
+find_remote_info()
+{
+ wget -qO- "${1%/*}/VERSION.txt" 2>/dev/null
+}
+
find_remote_version()
{
- wget -qO- "${1%/*}/VERSION.txt" 2>/dev/null | \
+ find_remote_info "$1" | \
sed -ne "s!.*$D4/$D2/$D2 $D2:$D2.*!\\1\\2\\3\\4\\5!p;t"
}
@@ -197,9 +202,12 @@ if [ "$checkupdate" = 1 ]; then
[ -n "$v1" -a -n "$v2" ] && {
version_compare "$v1" "$v2"
[ $? == 2 ] && {
- echo "Update available! $v1 -> $v2"
+ echo "Update available!${NL}Local: $v1${NL}Remote: $v2${NL}--"
+ find_remote_info "$image_url"
+ exit 0
} || {
echo "Local version $v1 is up to date"
+ exit 2
}
} || {
echo "No remote time stamp found."
diff --git a/po/de/freifunk.po b/po/de/freifunk.po
index c172dce60..7728c26c7 100644
--- a/po/de/freifunk.po
+++ b/po/de/freifunk.po
@@ -2,8 +2,8 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2009-06-07 22:10+0200\n"
-"PO-Revision-Date: 2009-06-07 22:17+0200\n"
+"POT-Creation-Date: 2009-06-30 06:43+0200\n"
+"PO-Revision-Date: 2009-06-30 06:47+0200\n"
"Last-Translator: Jo-Philipp Wich \n"
"Language-Team: LANGUAGE \n"
"MIME-Version: 1.0\n"
@@ -220,3 +220,41 @@ msgstr "Layer7-Protokolle"
#. IP-P2P
msgid "ff_p2pblock_ipp2p"
msgstr "IPP2P"
+
+#. Freifunk Remote Update
+msgid "ff_remote_update"
+msgstr "Freifunk Fernupdate"
+
+#. Check for new firmware versions and perform automatic updates.
+msgid "ff_remote_update_desc"
+msgstr ""
+"Der Fernupdate-Mechanismus prüft nach neuen Firmware-Versionen und führt "
+"automatisierte Updates durch."
+
+#. Update available!
+msgid "ff_remote_update_available"
+msgstr "Update verfügbar!"
+
+#. The installed firmware is the most recent version.
+msgid "ff_remote_update_uptodate"
+msgstr "Die installierte Firmware ist bereits die neueste Version."
+
+#. Start Upgrade
+msgid "ff_remote_update_install"
+msgstr "Updatevorgang starten"
+
+#. Update Settings
+msgid "ff_remote_update_settings"
+msgstr "Einstellungen zum Update"
+
+#. Keep configuration
+msgid "ff_remote_update_keepcfg"
+msgstr "Konfigurationsdateien wiederherstellen"
+
+#. Verify downloaded images
+msgid "ff_remote_update_keepcfg"
+msgstr "Heruntergeladene Images verifizieren"
+
+#. Confirm Upgrade
+msgid "ff_remote_update_install"
+msgstr "Update bestätigen"
diff --git a/po/en/freifunk.po b/po/en/freifunk.po
index 7a431fdd4..a4127dc96 100644
--- a/po/en/freifunk.po
+++ b/po/en/freifunk.po
@@ -2,8 +2,8 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2009-06-07 22:10+0200\n"
-"PO-Revision-Date: 2009-06-07 22:18+0200\n"
+"POT-Creation-Date: 2009-06-30 06:42+0200\n"
+"PO-Revision-Date: 2009-06-30 06:43+0200\n"
"Last-Translator: Jo-Philipp Wich \n"
"Language-Team: LANGUAGE \n"
"MIME-Version: 1.0\n"
@@ -218,3 +218,39 @@ msgstr "Layer7-Protocols"
#. IP-P2P
msgid "ff_p2pblock_ipp2p"
msgstr "IP-P2P"
+
+#. Freifunk Remote Update
+msgid "ff_remote_update"
+msgstr "Freifunk Remote Update"
+
+#. Check for new firmware versions and perform automatic updates.
+msgid "ff_remote_update_desc"
+msgstr "Check for new firmware versions and perform automatic updates."
+
+#. Update available!
+msgid "ff_remote_update_available"
+msgstr "Update available!"
+
+#. The installed firmware is the most recent version.
+msgid "ff_remote_update_uptodate"
+msgstr "The installed firmware is the most recent version."
+
+#. Start Upgrade
+msgid "ff_remote_update_install"
+msgstr "Start Upgrade"
+
+#. Update Settings
+msgid "ff_remote_update_settings"
+msgstr "Update Settings"
+
+#. Keep configuration
+msgid "ff_remote_update_keepcfg"
+msgstr "Keep configuration"
+
+#. Verify downloaded images
+msgid "ff_remote_update_keepcfg"
+msgstr "Verify downloaded images"
+
+#. Confirm Upgrade
+msgid "ff_remote_update_install"
+msgstr "Confirm Upgrade"
diff --git a/po/templates/freifunk.pot b/po/templates/freifunk.pot
index 104d9cb11..66b9da7ae 100644
--- a/po/templates/freifunk.pot
+++ b/po/templates/freifunk.pot
@@ -203,3 +203,39 @@ msgstr ""
#. IP-P2P
msgid "ff_p2pblock_ipp2p"
msgstr ""
+
+#. Freifunk Remote Update
+msgid "ff_remote_update"
+msgstr ""
+
+#. Check for new firmware versions and perform automatic updates.
+msgid "ff_remote_update_desc"
+msgstr ""
+
+#. Update available!
+msgid "ff_remote_update_available"
+msgstr ""
+
+#. The installed firmware is the most recent version.
+msgid "ff_remote_update_uptodate"
+msgstr ""
+
+#. Start Upgrade
+msgid "ff_remote_update_install"
+msgstr ""
+
+#. Update Settings
+msgid "ff_remote_update_settings"
+msgstr ""
+
+#. Keep configuration
+msgid "ff_remote_update_keepcfg"
+msgstr ""
+
+#. Verify downloaded images
+msgid "ff_remote_update_keepcfg"
+msgstr ""
+
+#. Confirm Upgrade
+msgid "ff_remote_update_install"
+msgstr ""