applications/luci-asterisk: add meetme support, data integrity improvements
[project/luci.git] / applications / luci-asterisk / luasrc / controller / asterisk.lua
index b321b5a..ab05339 100644 (file)
@@ -53,7 +53,11 @@ function index()
        entry({"admin", "asterisk", "voicemail", "mailboxes"},  cbi("asterisk/voicemail"),                      "Mailboxes",    1)
        entry({"admin", "asterisk", "voicemail", "settings"},   cbi("asterisk/voicemail_settings"),     "Settings",     2)
 
-       entry({"admin", "asterisk", "dialplans"},                               call("handle_dialplan"),                "Call Routing", 4)
+       entry({"admin", "asterisk", "meetme"},                          cbi("asterisk/meetme"),                 "MeetMe",               4)
+       entry({"admin", "asterisk", "meetme", "rooms"},                 cbi("asterisk/meetme"),                         "Rooms",                1)
+       entry({"admin", "asterisk", "meetme", "settings"},              cbi("asterisk/meetme_settings"),        "Settings",     2)
+
+       entry({"admin", "asterisk", "dialplans"},                               call("handle_dialplan"),                "Call Routing", 5)
        entry({"admin", "asterisk", "dialplans", "out"},                cbi("asterisk/dialplan_out"),           nil,            1).leaf = true
        entry({"admin", "asterisk", "dialplans", "zones"},              call("handle_dialzones"),                       "Dial Zones",   2).leaf = true
 
@@ -81,8 +85,6 @@ function handle_dialplan()
                        if #newinc > 0 then
                                uci:set("asterisk", plan.name, "include", newinc)
                        end
-
-                       uci:save("asterisk")
                end
        end
 
@@ -101,8 +103,6 @@ function handle_dialplan()
                        if #newinc > 0 then
                                uci:set("asterisk", plan.name, "include", newinc)
                        end
-
-                       uci:save("asterisk")
                end
        end
 
@@ -111,7 +111,6 @@ function handle_dialplan()
                if #v > 0 and plan then
                        uci:delete_all("asterisk", "dialplanvoice",
                                { extension=v, dialplan=plan.name })
-                       uci:save("asterisk")
                end
        end
 
@@ -127,7 +126,28 @@ function handle_dialplan()
                                voicebox                = vbox.number,
                                voicecontext    = vbox.context
                        })
-                       uci:save("asterisk")
+               end
+       end
+
+       for k, v in pairs(luci.http.formvaluetable("delmeetme")) do
+               local plan = ast.dialplan.plan(k)
+               if #v > 0 and plan then
+                       uci:delete_all("asterisk", "dialplanmeetme",
+                               { extension=v, dialplan=plan.name })
+               end
+       end
+
+       for k, v in pairs(luci.http.formvaluetable("addmeetme")) do
+               local plan = ast.dialplan.plan(k)
+               local meetme = ast.meetme.room(v)
+               if plan and meetme then
+                       local mext = luci.http.formvalue("addmeetmeext.%s" % plan.name)
+                       mext = ( mext and #mext > 0 ) and mext or meetme.room
+                       uci:section("asterisk", "dialplanmeetme", nil, {
+                               dialplan        = plan.name,
+                               extension       = mext,
+                               room            = meetme.room
+                       })
                end
        end
 
@@ -135,7 +155,6 @@ function handle_dialplan()
        if aname and #aname > 0 then
                if aname:match("^[a-zA-Z0-9_]+$") then
                        uci:section("asterisk", "dialplan", aname, { })
-                       uci:save("asterisk")
                else
                        err = true
                end
@@ -145,11 +164,14 @@ function handle_dialplan()
        if dname and #dname > 0 then
                if uci:get("asterisk", dname) == "dialplan" then
                        uci:delete("asterisk", dname)
-                       uci:save("asterisk")
+                       uci:delete_all("asterisk", "dialplanvoice", { dialplan=dname })
+                       uci:delete_all("asterisk", "dialplanmeetme", { dialplan=dname })
                end
        end
 
+       uci:save("asterisk")
        ast.uci_resync()
+
        luci.template.render("asterisk/dialplans", { create_error = err })
 end