From 60c4ab88f1a4042ac0867d1d50864564c15efe75 Mon Sep 17 00:00:00 2001 From: Mikhail Chechnev Date: Fri, 14 Dec 2018 21:54:36 +0300 Subject: [PATCH] =?UTF-8?q?=D0=9C=D0=BE=D0=B4=D1=83=D0=BB=D0=B8=20=D0=B4?= =?UTF-8?q?=D0=BB=D1=8F=20=D1=82=D0=B5=D1=81=D1=82=D0=B8=D1=80=D0=BE=D0=B2?= =?UTF-8?q?=D0=B0=D0=BD=D0=B8=D1=8F=20=D0=B2=D1=85=D0=BE=D0=B4=D1=8F=D1=89?= =?UTF-8?q?=D0=B8=D1=85=20(=D0=B2=D0=B7=D0=B0=D0=B8=D0=BC=D0=BE=D0=B4?= =?UTF-8?q?=D0=B5=D0=B9=D1=81=D1=82=D0=B2=D0=B8=D0=B5=20=D1=81=20=D0=AF?= =?UTF-8?q?=D0=BD=D0=B4=D0=B5=D0=BA=D1=81-=D0=94=D0=B8=D0=B0=D0=BB=D0=BE?= =?UTF-8?q?=D0=B3=D0=B0=D0=BC=D0=B8)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- db/UDO_PKG_EXS_TEST.pck | 69 +++++++++++++++++++++++++++++++++++++++++ modules/parus_alice.js | 33 ++++++++++++++++++++ 2 files changed, 102 insertions(+) create mode 100644 modules/parus_alice.js diff --git a/db/UDO_PKG_EXS_TEST.pck b/db/UDO_PKG_EXS_TEST.pck index 55be0d7..3b50cab 100644 --- a/db/UDO_PKG_EXS_TEST.pck +++ b/db/UDO_PKG_EXS_TEST.pck @@ -13,6 +13,30 @@ create or replace package UDO_PKG_EXS_TEST as NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) NEXSQUEUE in number -- ); + + /* */ + procedure RESP_LOGIN + ( + NIDENT in number, -- + NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) + NEXSQUEUE in number -- + ); + + /* */ + procedure RESP_FIND_AGENT + ( + NIDENT in number, -- + NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) + NEXSQUEUE in number -- + ); + + /* */ + procedure RESP_FIND_CONTRACT + ( + NIDENT in number, -- + NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) + NEXSQUEUE in number -- + ); end; / @@ -99,6 +123,51 @@ create or replace package body UDO_PKG_EXS_TEST as when others then PKG_EXS.PRC_RESP_ARG_STR_SET(NIDENT => NIDENT, SARG => PKG_EXS.SCONT_FLD_SERR, SVALUE => sqlerrm); end; + + /* */ + procedure RESP_LOGIN + ( + NIDENT in number, -- + NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) + NEXSQUEUE in number -- + ) + is + REXSQUEUE EXSQUEUE%rowtype; -- + CTMP clob; -- + begin + /* */ + REXSQUEUE := GET_EXSQUEUE_ID(NFLAG_SMART => 0, NRN => NEXSQUEUE); + /* */ + CTMP := BLOB2CLOB(LBDATA => REXSQUEUE.MSG, SCHARSET => 'UTF8'); + /* */ + PKG_EXS.PRC_RESP_ARG_BLOB_SET(NIDENT => NIDENT, + SARG => PKG_EXS.SCONT_FLD_BRESP, + BVALUE => CLOB2BLOB(LCDATA => CTMP || ' 8', SCHARSET => 'UTF8')); + end; + + /* */ + procedure RESP_FIND_AGENT + ( + NIDENT in number, -- + NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) + NEXSQUEUE in number -- + ) + is + begin + null; + end; + + /* */ + procedure RESP_FIND_CONTRACT + ( + NIDENT in number, -- + NSRV_TYPE in number, -- (. PKG_EXS.NSRV_TYPE*) + NEXSQUEUE in number -- + ) + is + begin + null; + end; end; / diff --git a/modules/parus_alice.js b/modules/parus_alice.js new file mode 100644 index 0000000..101af56 --- /dev/null +++ b/modules/parus_alice.js @@ -0,0 +1,33 @@ +/* + Сервис интеграции ПП Парус 8 с WEB API + Дополнительный модуль: Взаимодействие с Яндекс-Диалогами (голосовым помошником "Алиса") +*/ + +//------------ +// Тело модуля +//------------ + +//ДО функции "Алиса/Начало сеанса" +const beforeLogin = async prms => { + const d = `${prms.queue.blMsg.toString()} BEFORE LOGIN`; + return { + blMsg: new Buffer(d) + }; +}; + +//ПОСЛЕ функции "Алиса/Начало сеанса" +const afterLogin = async prms => { + let d = ""; + if (prms.queue.blResp) d = `${prms.queue.blResp.toString()} AFTER LOGIN`; + else d = `${prms.queue.blMsg.toString()} AFTER LOGIN`; + return { + blResp: new Buffer(d) + }; +}; + +//----------------- +// Интерфейс модуля +//----------------- + +exports.beforeLogin = beforeLogin; +exports.afterLogin = afterLogin;