* Merged Luci to use native UCI-library
[project/luci.git] / applications / luci-ffwizard-leipzig / luasrc / controller / luci_ffwizard_leipzig / wizard.lua
index 2fabfb1..216230f 100644 (file)
@@ -11,233 +11,220 @@ function action_wizard()
        end
        
        local ifaces = {}
-       local wldevs = luci.model.uci.sections("wireless")
-       
-       if wldevs then
-               for k, v in pairs(wldevs) do
-                       if v[".type"] == "wifi-device" then
-                               table.insert(ifaces, k)
-                       end
-               end
-       end
+       luci.model.uci.foreach("wireless", "wifi-device",
+               function(section)
+                       table.insert(ifaces, section[".name"])
+               end)
        
        luci.template.render("freifunk/wizard", {ifaces=ifaces})
 end
 
 function configure_freifunk()
        local ip  = luci.http.formvalue("ip")
-       local uci = luci.model.uci.Session()
-       
-       -- Load UCI
-       uci:t_load("network")
-       uci:t_load("dhcp")
-       uci:t_load("freifunk")
-       uci:t_load("luci_splash")
-       uci:t_load("olsr")
-       uci:t_load("wireless")
-       uci:t_load("luci_fw")
+       local uci = luci.model.uci
+       local cfg = uci.config
        
        
        -- Configure FF-Interface
-       uci:t_del("network", "ff")
-       uci:t_del("network", "ffdhcp")
+       uci.delete("network", "ff")
+       uci.delete("network", "ffdhcp")
        
-       uci:t_set("network", "ff", nil, "interface")
-       uci:t_set("network", "ff", "type", "bridge")
-       uci:t_set("network", "ff", "proto", "static")
-       uci:t_set("network", "ff", "ipaddr", ip)
-       uci:t_set("network", "ff", "netmask", uci:t_get("freifunk", "community", "mask")) 
-       uci:t_set("network", "ff", "dns", uci:t_get("freifunk", "community", "dns")) 
+       cfg.network.ff = "interface"
+       cfg.network.ff.type = "bridge"
+       cfg.network.ff.proto = "static"
+       cfg.network.ff.ipaddr = ip
+       cfg.network.ff.netmask = cfg.freifunk.community.mask 
+       cfg.network.ff.dns = cfg.freifunk.community.dns 
        
        -- Reset Routing
-       local routing = uci:t_sections("luci_fw")
-       if routing then
-               for k, v in pairs(routing) do
-                       if v[".type"] == "routing" and (v.iface == "ff" or v.oface == "ff") then
-                               uci:t_del("luci_fw", k)
+       uci.foreach("luci_fw", "routing",
+               function (section)
+                       if section.iface == "ff" or section.oface == "ff" then
+                               uci.delete("luci_fw", section[".name"])
                        end
-               end
+               end)
        
-               local int = uci:t_add("luci_fw", "routing")
-               uci:t_set("luci_fw", int, "iface", "ff")
-               uci:t_set("luci_fw", int, "oface", "ff")
-               uci:t_set("luci_fw", int, "fwd", "1")
+       if cfg.luci_fw then
+               cfg.luci_fw[""] = "routing"
+               cfg.luci_fw[""].iface = "ff"
+               cfg.luci_fw[""].oface = "ff"
+               cfg.luci_fw[""].fwd = "1"
        end
        
        -- Routing from Internal
        local iface = luci.http.formvalue("frominternal")
        if iface and iface ~= "" then
-               local routing = uci:t_sections("luci_fw")
-               if routing then
-                       for k, v in pairs(routing) do
-                               if v[".type"] == "routing" and (v.iface == iface and v.oface == "ff") then
-                                       uci:t_del("luci_fw", k)
+               uci.foreach("luci_fw", "routing",
+                       function (section)
+                               if section.iface == iface and section.oface == "ff" then
+                                       uci.delete("luci_fw", section[".name"])
                                end
-                       end
+                       end)
                
-                       local int = uci:t_add("luci_fw", "routing")
-                       uci:t_set("luci_fw", int, "iface", iface)
-                       uci:t_set("luci_fw", int, "oface", "ff")
-                       uci:t_set("luci_fw", int, "fwd", "1")
-                       uci:t_set("luci_fw", int, "nat", "1")
-               end             
+               if cfg.luci_fw then
+                       cfg.luci_fw[""] = "routing"
+                       cfg.luci_fw[""].iface = iface
+                       cfg.luci_fw[""].oface = "ff"
+                       cfg.luci_fw[""].fwd = "1"
+                       cfg.luci_fw[""].nat = "1"
+               end     
        end     
        
        -- Routing to External
        local iface = luci.http.formvalue("toexternal")
        if iface and iface ~= "" then
-               local routing = uci:t_sections("luci_fw")
-               if routing then
-                       for k, v in pairs(routing) do
-                               if v[".type"] == "routing" and (v.oface == iface and v.iface == "ff") then
-                                       uci:t_del("luci_fw", k)
+               uci.foreach("luci_fw", "routing",
+                       function (section)
+                               if section.oface == iface and section.iface == "ff" then
+                                       uci.delete("luci_fw", section[".name"])
                                end
-                       end
+                       end)
                
-                       local int = uci:t_add("luci_fw", "routing")
-                       uci:t_set("luci_fw", int, "iface", "ff")
-                       uci:t_set("luci_fw", int, "oface", iface)
-                       uci:t_set("luci_fw", int, "fwd", "1")
-                       uci:t_set("luci_fw", int, "nat", "1")
-               end             
+               if cfg.luci_fw then
+                       cfg.luci_fw[""] = "routing"
+                       cfg.luci_fw[""].oface = iface
+                       cfg.luci_fw[""].iface = "ff"
+                       cfg.luci_fw[""].fwd = "1"
+                       cfg.luci_fw[""].nat = "1"
+               end     
        end     
        
        -- Configure DHCP
        if luci.http.formvalue("dhcp") then
-               local dhcpnet = uci:t_get("freifunk", "community", "dhcp"):match("^([0-9]+)")
+               local dhcpnet = cfg.freifunk.community.dhcp:match("^([0-9]+)")
                local dhcpip  = ip:gsub("^[0-9]+", dhcpnet)
        
-               uci:t_set("network", "ffdhcp", nil, "interface")
-               uci:t_set("network", "ffdhcp", "proto", "static")
-               uci:t_set("network", "ffdhcp", "ifname", "br-ff:dhcp")
-               uci:t_set("network", "ffdhcp", "ipaddr", dhcpip)
-               uci:t_set("network", "ffdhcp", "netmask", uci:t_get("freifunk", "community", "dhcpmask"))
+               cfg.network.ffdhcp = "interface"
+               cfg.network.ffdhcp.proto = "static"
+               cfg.network.ffdhcp.ifname = "br-ff:dhcp"
+               cfg.network.ffdhcp.ipaddr = dhcpip
+               cfg.network.ffdhcp.netmask = cfg.freifunk.community.dhcpmask
                
-               local dhcp = uci:t_sections("dhcp")
-               if dhcp then
-                       for k, v in pairs(dhcp) do
-                               if v[".type"] == "dhcp" and v.interface == "ffdhcp" then
-                                       uci:t_del("dhcp", k)
+               uci.foreach("dhcp", "dhcp",
+                       function (section)
+                               if section.interface == "ffdhcp" then
+                                       uci.delete("dhcp", section[".name"])
                                end
-                       end             
-                       
-                       local dhcpbeg = 48 + tonumber(ip:match("[0-9]+$")) * 4
+                       end)    
                        
-                       local sk = uci:t_add("dhcp", "dhcp")
-                       uci:t_set("dhcp", sk, "interface", "ffdhcp")
-                       uci:t_set("dhcp", sk, "start", dhcpbeg)
-                       uci:t_set("dhcp", sk, "limit", (dhcpbeg < 252) and 3 or 2)
-                       uci:t_set("dhcp", sk, "leasetime", "30m")
-               end 
+               local dhcpbeg = 48 + tonumber(ip:match("[0-9]+$")) * 4
+               
+               cfg.dhcp[""] = "dhcp"
+               cfg.dhcp[""].interface = "ffdhcp"
+               cfg.dhcp[""].start = dhcpbeg
+               cfg.dhcp[""].limit = (dhcpbeg < 252) and 3 or 2
+               cfg.dhcp[""].leasetime = "30m"
                
-               local splash = uci:t_sections("luci_splash")
-               if splash then
-                       for k, v in pairs(splash) do
-                               if v[".type"] == "iface" then
-                                       uci:t_del("luci_splash", k)
+               
+               uci.foreach("luci_splash", "iface",
+                       function (section)
+                               if section.network == "ffdhcp" then
+                                       uci.delete("luci_splash", section[".name"])
                                end
-                       end             
+                       end)    
                        
-                       local sk = uci:t_add("luci_splash", "iface")
-                       uci:t_set("luci_splash", sk, "network", "ffdhcp")
-               end     
+               if cfg.luci_splash then
+                       cfg.luci_splash[""] = "iface"
+                       cfg.luci_splash[""].network = "ffdhcp"
+               end
+               
                
-               local routing = uci:t_sections("luci_fw")
-               if routing then
-                       for k, v in pairs(routing) do
-                               if v[".type"] == "routing" and (v.iface == "ffdhcp" or v.oface == "ffdhcp") then
-                                       uci:t_del("luci_fw", k)
+               uci.foreach("luci_fw", "routing",
+                       function (section)
+                               if section.iface == "ffdhcp" or section.oface == "ffdhcp" then
+                                       uci.delete("luci_fw", section[".name"])
                                end
-                       end
-                       
-                       local int = uci:t_add("luci_fw", "routing")
-                       uci:t_set("luci_fw", int, "iface", "ffdhcp")
-                       uci:t_set("luci_fw", int, "oface", "ff")
-                       uci:t_set("luci_fw", int, "nat", "1")                   
+                       end)
+
+               if cfg.luci_fw then                     
+                       cfg.luci_fw[""] = "routing"
+                       cfg.luci_fw[""].iface = "ffdhcp"
+                       cfg.luci_fw[""].oface = "ff"
+                       cfg.luci_fw[""].nat = "1"       
                        
                        local iface = luci.http.formvalue("toexternal")
                        if iface and iface ~= "" then
-                               local int = uci:t_add("luci_fw", "routing")
-                               uci:t_set("luci_fw", int, "iface", "ffdhcp")
-                               uci:t_set("luci_fw", int, "oface", iface)
-                               uci:t_set("luci_fw", int, "nat", "1")                           
+                               cfg.luci_fw[""] = "routing"
+                               cfg.luci_fw[""].iface = "ffdhcp"
+                               cfg.luci_fw[""].oface = iface
+                               cfg.luci_fw[""].nat = "1"                       
                        end
                end     
        end
        
        -- Configure OLSR
-       if luci.http.formvalue("olsr") and uci:t_sections("olsr") then
-               for k, v in pairs(uci:t_sections("olsr")) do
-                       if v[".type"] == "Interface" or v[".type"] == "LoadPlugin" then
-                               uci:t_del("olsr", k)
-                       end
-               end
+       if luci.http.formvalue("olsr") and cfg.olsr then
+               uci.foreach("olsr", "Interface",
+                       function (section)
+                               uci.delete("olsr", section[".name"])
+                       end)
+                       
+               uci.foreach("olsr", "LoadPlugin",
+                       function (section)
+                               uci.delete("olsr", section[".name"])
+                       end)
                
                if luci.http.formvalue("shareinet") then
-                       uci:t_set("olsr", "dyn_gw", nil, "LoadPlugin")
-                       uci:t_set("olsr", "dyn_gw", "Library", "olsrd_dyn_gw.so.0.4")
+                       cfg.olsr.dyn_gw = "LoadPlugin"
+                       cfg.olsr.dyn_gw.Library = "olsrd_dyn_gw.so.0.4"
                end
                
-               uci:t_set("olsr", "nameservice", nil, "LoadPlugin")
-               uci:t_set("olsr", "nameservice", "Library", "olsrd_nameservice.so.0.3")
-               uci:t_set("olsr", "nameservice", "name", ip:gsub("%.", "-"))
-               uci:t_set("olsr", "nameservice", "hosts_file", "/var/etc/hosts")
-               uci:t_set("olsr", "nameservice", "suffix", ".olsr")
-               uci:t_set("olsr", "nameservice", "latlon_infile", "/tmp/latlon.txt")
+               cfg.olsr.nameservice = "LoadPlugin"
+               cfg.olsr.nameservice.Library = "olsrd_nameservice.so.0.3"
+               cfg.olsr.nameservice.name = ip:gsub("%.", "-")
+               cfg.olsr.nameservice.hosts_file = "/var/etc/hosts"
+               cfg.olsr.nameservice.suffix = ".olsr"
+               cfg.olsr.nameservice.latlon_infile = "/tmp/latlon.txt"
                
-               uci:t_set("olsr", "txtinfo", nil, "LoadPlugin")
-               uci:t_set("olsr", "txtinfo", "Library", "olsrd_txtinfo.so.0.1")
-               uci:t_set("olsr", "txtinfo", "Accept", "127.0.0.1")
+               cfg.olsr.txtinfo = "LoadPlugin"
+               cfg.olsr.txtinfo.Library = "olsrd_txtinfo.so.0.1"
+               cfg.olsr.txtinfo.Accept = "127.0.0.1"
                
-               local oif = uci:t_add("olsr", "Interface")
-               uci:t_set("olsr", oif, "Interface", "ff")
-               uci:t_set("olsr", oif, "HelloInterval", "6.0")
-               uci:t_set("olsr", oif, "HelloValidityTime", "108.0")
-               uci:t_set("olsr", oif, "TcInterval", "4.0")
-               uci:t_set("olsr", oif, "TcValidityTime", "324.0")
-               uci:t_set("olsr", oif, "MidInterval", "18.0")
-               uci:t_set("olsr", oif, "MidValidityTime", "324.0")
-               uci:t_set("olsr", oif, "HnaInterval", "18.0")
-               uci:t_set("olsr", oif, "HnaValidityTime", "108.0")
+               cfg.olsr[""] = "Interface"
+               cfg.olsr[""].Interface = "ff"
+               cfg.olsr[""].HelloInterval = "6.0"
+               cfg.olsr[""].HelloValidityTime = "108.0"
+               cfg.olsr[""].TcInterval = "4.0"
+               cfg.olsr[""].TcValidityTime = "324.0"
+               cfg.olsr[""].MidInterval = "18.0"
+               cfg.olsr[""].MidValidityTime = "324.0"
+               cfg.olsr[""].HnaInterval = "18.0"
+               cfg.olsr[""].HnaValidityTime = "108.0"
        end
        
        -- Configure Wifi
-       local wcfg = uci:t_sections("wireless")
-       if wcfg then
-               for iface, v in pairs(wcfg) do
-                       if v[".type"] == "wifi-device" and luci.http.formvalue("wifi."..iface) then
-                               -- Cleanup
-                               for k, j in pairs(wcfg) do
-                                       if j[".type"] == "wifi-iface" and j.device == iface then
-                                               uci:t_del("wireless", k)
-                                       end
+       if cfg.wireless then
+               uci.foreach("wireless", "wifi-device",
+                       function (section)
+                               local device = section[".name"]
+                               
+                               if luci.http.formvalue("wifi."..iface) then
+                                       uci.foreach("wireless", "wifi-iface",
+                                               function (section)
+                                                       if section.device == device then
+                                                               uci.delete("wireless", section[".name"]) 
+                                                       end
+                                               end)
                                end
                                
-                               uci:t_set("wireless", iface, "disabled", "0")
-                               uci:t_set("wireless", iface, "mode", "11g")
-                               uci:t_set("wireless", iface, "txantenna", 1)
-                               uci:t_set("wireless", iface, "rxantenna", 1)
-                               uci:t_set("wireless", iface, "channel", uci:t_get("freifunk", "community", "channel")) 
+                               cfg.wireless[device].disabled = "0"
+                               cfg.wireless[device].mode = "11g"
+                               cfg.wireless[device].txantenna = "1"
+                               cfg.wireless[device].rxantenna = "1"
+                               cfg.wireless[device].channel = cfg.freifunk.community.channel
                                
-                               local wif = uci:t_add("wireless", "wifi-iface")
-                               uci:t_set("wireless", wif, "device", iface)
-                               uci:t_set("wireless", wif, "network", "ff")
-                               uci:t_set("wireless", wif, "mode", "adhoc")
-                               uci:t_set("wireless", wif, "ssid", uci:t_get("freifunk", "community", "essid"))
-                               uci:t_set("wireless", wif, "bssid", uci:t_get("freifunk", "community", "bssid"))
-                               uci:t_set("wireless", wif, "txpower", 13)
-                       end
-               end
+                               cfg.wireless[""] = "wifi-iface"
+                               cfg.wireless[""].device = iface
+                               cfg.wireless[""].network = "ff"
+                               cfg.wireless[""].mode = "adhoc"
+                               cfg.wireless[""].ssid = cfg.freifunk.community.essid
+                               cfg.wireless[""].bssid = cfg.freifunk.community.bssid
+                               cfg.wireless[""].txpower = 13
+                       end)
        end
        
        -- Save UCI
-       uci:t_save("network")
-       uci:t_save("dhcp")
-       uci:t_save("freifunk")
-       uci:t_save("luci_splash")
-       uci:t_save("olsr")
-       uci:t_save("wireless")
-       uci:t_save("luci_fw")
+       uci.save()
 
        luci.http.redirect(luci.dispatcher.build_url("admin", "uci", "changes"))
 end
\ No newline at end of file