modules/admin-mini: merge r4865 to admin-mini
authorJo-Philipp Wich <jow@openwrt.org>
Wed, 17 Jun 2009 12:48:18 +0000 (12:48 +0000)
committerJo-Philipp Wich <jow@openwrt.org>
Wed, 17 Jun 2009 12:48:18 +0000 (12:48 +0000)
modules/admin-mini/luasrc/controller/mini/system.lua

index bb93a34..3aae6fa 100644 (file)
@@ -149,15 +149,21 @@ function action_upgrade()
        -- previous pages should arrange the stuff as required.
        if step == 4 then
                if has_platform and has_image and has_support then
        -- previous pages should arrange the stuff as required.
        if step == 4 then
                if has_platform and has_image and has_support then
-                       -- Next line is to bypass luci.http layer
-                       luci.http.context.eoh = true
-
                        -- Now invoke sysupgrade
                        local keepcfg = keep_avail and luci.http.formvalue("keepcfg") == "1"
                        -- Now invoke sysupgrade
                        local keepcfg = keep_avail and luci.http.formvalue("keepcfg") == "1"
-                       os.execute("/sbin/luci-flash %s %q" %{
+                       local fd = io.popen("/sbin/luci-flash %s %q" %{
                                keepcfg and "-k %q" % _keep_pattern() or "", tmpfile
                        })
 
                                keepcfg and "-k %q" % _keep_pattern() or "", tmpfile
                        })
 
+                       if fd then
+                               while true do
+                                       local ln = fd:read("*l")
+                                       if not ln then break end
+                                       luci.http.write(ln)
+                               end
+                               fd:close()
+                       end
+
                        -- Make sure the device is rebooted
                        luci.sys.reboot()
                end
                        -- Make sure the device is rebooted
                        luci.sys.reboot()
                end