浏览代码

Add IVR Menu lua script.

Mark Crane 12 年之前
父节点
当前提交
9c23f1763d
共有 1 个文件被更改,包括 127 次插入0 次删除
  1. 127 0
      includes/install/scripts/ivr_menu.lua

+ 127 - 0
includes/install/scripts/ivr_menu.lua

@@ -0,0 +1,127 @@
+--	ivr_menu.lua
+--	Part of FusionPBX
+--	Copyright (C) 2012 Mark J Crane <[email protected]>
+--	All rights reserved.
+--
+--	Redistribution and use in source and binary forms, with or without
+--	modification, are permitted provided that the following conditions are met:
+--
+--	1. Redistributions of source code must retain the above copyright notice,
+--	this list of conditions and the following disclaimer.
+--
+--	2. Redistributions in binary form must reproduce the above copyright
+--	notice, this list of conditions and the following disclaimer in the
+--	documentation and/or other materials provided with the distribution.
+--
+--	THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
+--	INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
+--	AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+--	AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
+--	OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+--	SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+--	INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+--	CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+--	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+--	POSSIBILITY OF SUCH DAMAGE.
+
+--include the lua script
+	scripts_dir = string.sub(debug.getinfo(1).source,2,string.len(debug.getinfo(1).source)-(string.len(argv[0])+1));
+	include = assert(loadfile(scripts_dir .. "/resources/config.lua"));
+	include();
+
+--connect to the database
+	--ODBC - data source name
+		if (dsn_name) then
+			dbh = freeswitch.Dbh(dsn_name,dsn_username,dsn_password);
+		end
+	--FreeSWITCH core db handler
+		if (db_type == "sqlite") then
+			dbh = freeswitch.Dbh("core:"..db_path.."/"..db_name);
+		end
+
+--get the variables
+	domain_name = session:getVariable("domain_name");
+	ivr_menu_uuid = session:getVariable("ivr_menu_uuid");
+	caller_id_name = session:getVariable("caller_id_name");
+	caller_id_number = session:getVariable("caller_id_number");
+
+--get the ivr menu
+	sql = [[SELECT * FROM v_ivr_menus 
+		WHERE ivr_menu_uuid = ']] .. ivr_menu_uuid ..[['
+		AND ivr_menu_enabled = 'true' ]];
+	if (debug["sql"]) then
+		freeswitch.consoleLog("notice", "[ivr_menu] SQL: " .. sql .. "\n");
+	end
+	status = dbh:query(sql, function(row)
+		ivr_menu_name = row["ivr_menu_name"];
+		--ivr_menu_extension = row["ivr_menu_extension"];
+		ivr_menu_greet_long = row["ivr_menu_greet_long"];
+		ivr_menu_greet_short = row["ivr_menu_greet_short"];
+		ivr_menu_invalid_sound = row["ivr_menu_invalid_sound"];
+		ivr_menu_exit_sound = row["ivr_menu_exit_sound"];
+		ivr_menu_confirm_macro = row["ivr_menu_confirm_macro"];
+		ivr_menu_confirm_key = row["ivr_menu_confirm_key"];
+		ivr_menu_tts_engine = row["ivr_menu_tts_engine"];
+		ivr_menu_tts_voice = row["ivr_menu_tts_voice"];
+		ivr_menu_confirm_attempts = row["ivr_menu_confirm_attempts"];
+		ivr_menu_timeout = row["ivr_menu_timeout"];
+		--ivr_menu_exit_app = row["ivr_menu_exit_app"];
+		--ivr_menu_exit_data = row["ivr_menu_exit_data"];
+		ivr_menu_inter_digit_timeout = row["ivr_menu_inter_digit_timeout"];
+		ivr_menu_max_failures = row["ivr_menu_max_failures"];
+		ivr_menu_max_timeouts = row["ivr_menu_max_timeouts"];
+		ivr_menu_digit_len = row["ivr_menu_digit_len"];
+		--ivr_menu_direct_dial = row["ivr_menu_direct_dial"];
+		--ivr_menu_description = row["ivr_menu_description"];
+		ivr_menu_ringback = row["ivr_menu_ringback"];
+	end);
+
+hash = {
+	["main"] = undef,
+	["name"] = ivr_menu_name,
+	["greet_long"] = ivr_menu_greet_long,
+	["greet_short"] = ivr_menu_greet_short,
+	["invalid_sound"] = ivr_menu_invalid_sound,
+	["exit_sound"] = ivr_menu_exit_sound,
+	["confirm_macro"] = ivr_menu_confirm_macro,
+	["confirm_key"] = ivr_menu_confirm_key,
+	["tts_engine"] = ivr_menu_tts_engine,
+	["tts_voice"] = ivr_menu_tts_voice,
+	["max_timeouts"] = ivr_menu_max_timeouts,
+	["confirm_attempts"] = ivr_menu_confirm_attempts,
+	["inter_digit_timeout"] = ivr_menu_inter_digit_timeout,
+	["digit_len"] = ivr_menu_digit_len,
+	["timeout"] = ivr_menu_timeout,
+	["max_failures"] = ivr_menu_max_failures
+} 
+
+top = freeswitch.IVRMenu(
+	hash["main"],
+	hash["name"],
+	hash["greet_long"],
+	hash["greet_short"],
+	hash["invalid_sound"],
+	hash["exit_sound"],
+	hash["confirm_macro"],
+	hash["confirm_key"],
+	hash["tts_engine"],
+	hash["tts_voice"],
+	hash["max_timeouts"],
+	hash["confirm_attempts"],
+	hash["inter_digit_timeout"],
+	hash["digit_len"],
+	hash["timeout"],
+	hash["max_failures"]);
+
+--get the ivr menu options
+	sql = [[SELECT * FROM v_ivr_menu_options WHERE ivr_menu_uuid = ']] .. ivr_menu_uuid ..[[' ORDER BY ivr_menu_option_order asc ]];
+	if (debug["sql"]) then
+		freeswitch.consoleLog("notice", "[ivr_menu] SQL: " .. sql .. "\n");
+	end
+	status = dbh:query(sql, function(row)
+		 --top:bindAction("menu-exec-app", "playback /tmp/swimp.raw", "2");
+		top:bindAction(row.ivr_menu_option_action, row.ivr_menu_option_param, row.ivr_menu_option_digits);
+	end);
+
+--execute the ivr menu
+	top:execute(session, ivr_menu_name);