fusionpbx/app/scripts/resources/scripts/do_not_disturb.lua

300 lines
10 KiB
Lua
Raw Normal View History

--
-- FusionPBX
-- Version: MPL 1.1
--
-- The contents of this file are subject to the Mozilla Public License Version
-- 1.1 (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.mozilla.org/MPL/
--
-- Software distributed under the License is distributed on an "AS IS" basis,
-- WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
-- for the specific language governing rights and limitations under the
-- License.
--
-- The Original Code is FusionPBX
--
-- The Initial Developer of the Original Code is
-- Mark J Crane <markjcrane@fusionpbx.com>
2019-09-11 21:26:37 +02:00
-- Copyright (C) 2010-2019
-- the Initial Developer. All Rights Reserved.
--
-- Contributor(s):
-- Mark J Crane <markjcrane@fusionpbx.com>
--set default variables
min_digits = "1";
max_digits = "11";
max_tries = "3";
digit_timeout = "3000";
--define the trim function
require "resources.functions.trim";
--define the explode function
require "resources.functions.explode";
--create the api object
api = freeswitch.API();
--include config.lua
require "resources.functions.config";
local blf = require "resources.functions.blf"
local cache = require "resources.functions.cache"
2019-09-05 19:01:59 +02:00
local Settings = require "resources.functions.lazy_settings"
local notify = require "app.feature_event.resources.functions.feature_event_notify"
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
--answer the call
if (session:ready()) then
session:answer();
end
2019-09-05 19:01:59 +02:00
--get the variables
if (session:ready()) then
enabled = session:getVariable("enabled");
pin_number = session:getVariable("pin_number");
sounds_dir = session:getVariable("sounds_dir");
domain_uuid = session:getVariable("domain_uuid");
domain_name = session:getVariable("domain_name");
extension_uuid = session:getVariable("extension_uuid");
end
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
--set the sounds path for the language, dialect and voice
if (session:ready()) then
default_language = session:getVariable("default_language");
default_dialect = session:getVariable("default_dialect");
default_voice = session:getVariable("default_voice");
if (not default_language) then default_language = 'en'; end
if (not default_dialect) then default_dialect = 'us'; end
if (not default_voice) then default_voice = 'callie'; end
end
--wait a moment to sleep
if (session:ready()) then
session:sleep(1000);
end
--connect to the database
local Database = require "resources.functions.database";
dbh = Database.new('system');
local settings = Settings.new(dbh, domain_name, domain_uuid);
--include json library
2019-09-05 21:43:49 +02:00
--debug["sql"] = true;
2019-09-05 19:01:59 +02:00
local json
if (debug["sql"]) then
json = require "resources.functions.lunajson"
end
--determine whether to update the dial string
local sql = "select * from v_extensions ";
sql = sql .. "where domain_uuid = :domain_uuid ";
sql = sql .. "and extension_uuid = :extension_uuid ";
local params = {domain_uuid = domain_uuid, extension_uuid = extension_uuid};
if (debug["sql"]) then
freeswitch.consoleLog("notice", "[do_not_disturb] " .. sql .. "; params:" .. json.encode(params) .. "\n");
end
dbh:query(sql, params, function(row)
extension = row.extension;
number_alias = row.number_alias or '';
accountcode = row.accountcode;
follow_me_uuid = row.follow_me_uuid or nil;
2019-09-05 19:01:59 +02:00
do_not_disturb = row.do_not_disturb;
forward_all_destination = row.forward_all_destination;
forward_all_enabled = row.forward_all_enabled;
context = row.user_context;
end);
--send information to the console
if (session:ready()) then
freeswitch.consoleLog("NOTICE", "[do_not_disturb] do_not_disturb "..do_not_disturb.."\n");
freeswitch.consoleLog("NOTICE", "[do_not_disturb] extension "..extension.."\n");
freeswitch.consoleLog("NOTICE", "[do_not_disturb] follow_me_uuid "..follow_me_uuid.."\n");
freeswitch.consoleLog("NOTICE", "[do_not_disturb] accountcode "..accountcode.."\n");
--freeswitch.consoleLog("NOTICE", "[do_not_disturb] enabled before "..enabled.."\n");
end
--toggle do not disturb
if (enabled == "toggle") then
if (do_not_disturb == "true") then
enabled = "false";
else
enabled = "true";
end
end
--send information to the console
if (session:ready()) then
freeswitch.consoleLog("NOTICE", "[do_not_disturb] enabled "..enabled.."\n");
end
--set the dial string
if (enabled == "true") then
local user = (number_alias and #number_alias > 0) and number_alias or extension;
end
--set do not disturb
if (enabled == "true") then
--set do_not_disturb_enabled
do_not_disturb_enabled = "true";
--notify the caller
if (session:ready()) then
session:streamFile(sounds_dir.."/"..default_language.."/"..default_dialect.."/"..default_voice.."/ivr/ivr-dnd_activated.wav");
end
2019-09-05 19:01:59 +02:00
end
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
--unset do not disturb
if (enabled == "false") then
--set fdo_not_disturb_enabled
do_not_disturb_enabled = "false";
--notify the caller
if (session:ready()) then
session:streamFile(sounds_dir.."/"..default_language.."/"..default_dialect.."/"..default_voice.."/ivr/ivr-dnd_cancelled.wav");
end
2019-09-05 19:01:59 +02:00
end
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
--update follow me
if (follow_me_uuid ~= nil and enabled == 'true') then
local sql = "update v_follow_me ";
sql = sql .. "set follow_me_enabled = 'false' ";
sql = sql .. "where domain_uuid = :domain_uuid ";
sql = sql .. "and follow_me_uuid = :follow_me_uuid ";
local params = {domain_uuid = domain_uuid, follow_me_uuid = follow_me_uuid};
2019-09-05 21:43:49 +02:00
if (debug["sql"]) then
2019-09-05 19:01:59 +02:00
freeswitch.consoleLog("notice", "[do_not_disturb] "..sql.."; params:" .. json.encode(params) .. "\n");
2019-09-05 21:43:49 +02:00
end
2019-09-05 19:01:59 +02:00
dbh:query(sql, params);
end
--update the extension
sql = "update v_extensions set ";
if (enabled == "true") then
sql = sql .. "follow_me_enabled = 'false', ";
2019-09-11 21:26:37 +02:00
sql = sql .. "dial_string = 'error/user_busy', ";
2019-09-05 19:01:59 +02:00
sql = sql .. "do_not_disturb = 'true', ";
sql = sql .. "forward_all_enabled = 'false' ";
else
2019-09-11 21:26:37 +02:00
sql = sql .. "dial_string = null, ";
2019-09-05 19:01:59 +02:00
sql = sql .. "do_not_disturb = 'false' ";
end
sql = sql .. "where domain_uuid = :domain_uuid ";
sql = sql .. "and extension_uuid = :extension_uuid ";
2019-09-11 21:26:37 +02:00
local params = {domain_uuid = domain_uuid, extension_uuid = extension_uuid};
2019-09-05 19:01:59 +02:00
if (debug["sql"]) then
freeswitch.consoleLog("notice", "[do_not_disturb] "..sql.."; params:" .. json.encode(params) .. "\n");
end
dbh:query(sql, params);
--determine whether to update the dial string
sql = "select * from v_extension_users as e, v_users as u ";
sql = sql .. "where e.extension_uuid = :extension_uuid ";
sql = sql .. "and e.user_uuid = u.user_uuid ";
sql = sql .. "and e.domain_uuid = :domain_uuid ";
local params = {domain_uuid = domain_uuid, extension_uuid = extension_uuid};
if (debug["sql"]) then
freeswitch.consoleLog("notice", "[do_not_disturb] "..sql.."; params:" .. json.encode(params) .. "\n");
end
dbh:query(sql, params, function(row)
--update the call center status
if (enabled == "true") then
user_status = "Logged Out";
api:execute("callcenter_config", "agent set status "..row.username.."@"..domain_name.." '"..user_status.."'");
end
2019-09-05 19:01:59 +02:00
--update the database user_status
if (enabled == "true") then
2019-09-05 19:01:59 +02:00
user_status = "Do Not Disturb";
else
2019-09-05 19:01:59 +02:00
user_status = "Available";
end
2019-09-05 19:01:59 +02:00
local sql = "update v_users set ";
sql = sql .. "user_status = :user_status ";
sql = sql .. "where domain_uuid = :domain_uuid ";
2019-09-05 19:01:59 +02:00
sql = sql .. "and user_uuid = :user_uuid ";
local params = {user_status = user_status, domain_uuid = domain_uuid, user_uuid = row.user_uuid};
if (debug["sql"]) then
freeswitch.consoleLog("notice", "[do_not_disturb] "..sql.."; params:" .. json.encode(params) .. "\n");
end
dbh:query(sql, params);
2019-09-05 19:01:59 +02:00
end);
--send notify to phone if feature sync is enabled
if settings:get('device', 'feature_sync', 'boolean') == 'true' then
-- Get values from the database
2019-09-05 19:01:59 +02:00
do_not_disturb, forward_all_enabled, forward_all_destination, forward_busy_enabled, forward_busy_destination, forward_no_answer_enabled, forward_no_answer_destination, call_timeout = notify.get_db_values(extension, domain_name)
-- Get the sip_profile
2019-09-05 19:01:59 +02:00
if (extension ~= nil and domain_name ~= nil) then
sip_profile = notify.get_profile(extension, domain_name);
end
2019-09-05 19:01:59 +02:00
-- check if not nil
if (sip_profile ~= nil) then
freeswitch.consoleLog("NOTICE", "[feature_event] SIP NOTIFY: CFWD set to "..forward_all_enabled.."\n");
2019-09-05 19:01:59 +02:00
--Do Not Disturb
notify.dnd(extension, domain_name, sip_profile, do_not_disturb);
--Forward all
forward_immediate_enabled = forward_all_enabled;
forward_immediate_destination = forward_all_destination;
2019-09-05 19:01:59 +02:00
--workaround for freeswitch not sending NOTIFY when destination values are nil. Send 0.
if (string.len(forward_immediate_destination) < 1) then
forward_immediate_destination = '0';
end
2019-09-05 19:01:59 +02:00
notify.forward_immediate(extension, domain_name, sip_profile, forward_immediate_enabled, forward_immediate_destination);
2019-09-05 19:01:59 +02:00
--Forward busy
--workaround for freeswitch not sending NOTIFY when destination values are nil. Send 0.
if (string.len(forward_busy_destination) < 1) then
forward_busy_destination = '0';
end
2019-09-05 19:01:59 +02:00
notify.forward_busy(extension, domain_name, sip_profile, forward_busy_enabled, forward_busy_destination);
--Forward No Answer
ring_count = math.ceil (call_timeout / 6);
--workaround for freeswitch not sending NOTIFY when destination values are nil. Send 0.
if (string.len(forward_no_answer_destination) < 1) then
forward_no_answer_destination = '0';
end
2019-09-05 19:01:59 +02:00
notify.forward_no_answer(extension, domain_name, sip_profile, forward_no_answer_enabled, forward_no_answer_destination, ring_count);
end
end
2019-09-05 19:01:59 +02:00
--clear the cache
if extension and #extension > 0 and cache.support() then
cache.del("directory:"..extension.."@"..context);
if #number_alias > 0 then
cache.del("directory:"..number_alias.."@"..context);
end
end
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
--wait for the file to be written before proceeding
if (session:ready()) then
session:sleep(1000);
end
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
--end the call
if (session:ready()) then
session:hangup();
end
2014-08-29 10:33:15 +02:00
2019-09-05 19:01:59 +02:00
-- BLF for display DND status
blf.dnd(enabled == "true", extension, number_alias, domain_name)
2019-09-05 19:01:59 +02:00
-- Turn off BLF for call forward
if forward_all_enabled == 'true' and enabled == 'true' then
blf.forward(false, extension, number_alias,
forward_all_destination, nil, domain_name
)
end
2019-09-05 19:01:59 +02:00
--disconnect from database
dbh:release()