Built motion from commit efa66e19.|2.6.22
[motion2.git] / server / services / agi / index.js
index 1b7363c..130ba2e 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x09aa=['createSquareReport','then','catch','indexOf','agi_','substring','debug','variables','stringify','close','timeout','evtHangup','hangup','find','handleNotFound','production','handleUnpublished','getLicense','voice','callysquare','[LICENSE]\x20CHANNELS:\x20UNLIMITED','[LICENSE]\x20VOICE\x20IS\x20DISABLED','finally','connection','lodash','syncho','util','../../config/environment','../../config/logger','../../config/license/util','./project','EventEmitter','agi','127.0.0.1','projectUpdate','nextTick','stack','deleted','splice','push','error','log','Cally\x20Square\x20server\x20listening\x20on\x20port\x20%d!','port','info','[LISTENING]\x20Cally\x20Square\x20listening\x20%s:%d','name','message','[%s]\x20%s','format','[CLOSE]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s','arg_1','callerid','uniqueid','[TIMEOUT]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s','dnid','calleridname'];(function(_0x5160b6,_0x261d95){var _0x200f73=function(_0x667484){while(--_0x667484){_0x5160b6['push'](_0x5160b6['shift']());}};_0x200f73(++_0x261d95);}(_0x09aa,0xc3));var _0xa09a=function(_0x137f37,_0x3f72eb){_0x137f37=_0x137f37-0x0;var _0x228525=_0x09aa[_0x137f37];return _0x228525;};'use strict';var _=require(_0xa09a('0x0'));var syncho=require(_0xa09a('0x1'));var util=require(_0xa09a('0x2'));var config=require(_0xa09a('0x3'));var logger=require(_0xa09a('0x4'))('agi');var utilLicense=require(_0xa09a('0x5'));var rpc=require('./rpc');var Project=require(_0xa09a('0x6'));var AGIEmitter=require('./events')[_0xa09a('0x7')];var projects=[];config['agi']=_['defaults'](config[_0xa09a('0x8')],{'ip':_0xa09a('0x9'),'port':0x11dd});AGIEmitter['on'](_0xa09a('0xa'),projectUpdateHandler);function connectionHandler(_0x4252f3){process[_0xa09a('0xb')](function(){syncho(function(){try{setChannelVariables(_0x4252f3);agiHandler(_0x4252f3);}catch(_0x4591b6){logger['error'](_0x4591b6[_0xa09a('0xc')]);}});});}function projectUpdateHandler(_0x174990){try{var _0x142f56=_['findIndex'](projects,['id',_0x174990['id']]);if(_0x142f56>-0x1){if(_0x174990[_0xa09a('0xd')]===!![]){projects[_0xa09a('0xe')](_0x142f56,0x1);}else{projects[_0x142f56]=_0x174990;}}else{projects[_0xa09a('0xf')](_0x174990);}}catch(_0x54c8bb){logger[_0xa09a('0x10')](_0x54c8bb['stack']);}}function listeningHandler(){console[_0xa09a('0x11')](_0xa09a('0x12'),config[_0xa09a('0x8')][_0xa09a('0x13')]);logger[_0xa09a('0x14')](util['format'](_0xa09a('0x15'),config[_0xa09a('0x8')]['ip'],config[_0xa09a('0x8')][_0xa09a('0x13')]));}function errorHandler(_0x328db0){if(_0x328db0&&_0x328db0[_0xa09a('0x16')]&&_0x328db0[_0xa09a('0x17')]){logger['error'](util['format'](_0xa09a('0x18'),_0x328db0[_0xa09a('0x16')],_0x328db0[_0xa09a('0x17')]));}else{logger[_0xa09a('0x10')](util[_0xa09a('0x19')]('[ERROR]\x20%s',_0x328db0['stack']));}}function closeHandler(){logger['info'](util['format'](_0xa09a('0x1a'),this[_0xa09a('0x1b')],this['calleridname'],this[_0xa09a('0x1c')],this['dnid'],this[_0xa09a('0x1d')]));try{createSquareReport(this);}catch(_0x46dfa6){logger[_0xa09a('0x10')](_0x46dfa6['stack']);}}function timeoutHandler(){logger[_0xa09a('0x14')](util[_0xa09a('0x19')](_0xa09a('0x1e'),this['arg_1'],this['calleridname'],this[_0xa09a('0x1c')],this[_0xa09a('0x1f')],this[_0xa09a('0x1d')]));}function hangupHandler(){logger[_0xa09a('0x14')](util[_0xa09a('0x19')]('[HANGUP]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s',this['arg_1'],this[_0xa09a('0x20')],this[_0xa09a('0x1c')],this['dnid'],this[_0xa09a('0x1d')]));this['evtHangup']=!![];}function createSquareReport(_0x38258a,_0x2ccb24){rpc[_0xa09a('0x21')](_0x38258a)[_0xa09a('0x22')](function(_0x216271){if(_0x2ccb24){_0x2ccb24(null,_0x216271);}})[_0xa09a('0x23')](function(_0x291707){if(_0x2ccb24){_0x2ccb24(null,_0x291707);}});}function setChannelVariables(_0x2f4d1a){for(var _0x2628c6 in _0x2f4d1a){if(_0x2f4d1a['hasOwnProperty'](_0x2628c6)){if(_0x2628c6[_0xa09a('0x24')](_0xa09a('0x25'))===0x0){_0x2f4d1a[_0x2628c6[_0xa09a('0x26')](0x4)]=_0x2f4d1a[_0x2628c6];delete _0x2f4d1a[_0x2628c6];}}}}function agiHandler(_0x50a8c4){logger[_0xa09a('0x27')](_0xa09a('0x28'),JSON[_0xa09a('0x29')](_0x50a8c4,null,0x2));logger[_0xa09a('0x14')](util[_0xa09a('0x19')]('[START]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s',_0x50a8c4[_0xa09a('0x1b')],_0x50a8c4[_0xa09a('0x20')],_0x50a8c4[_0xa09a('0x1c')],_0x50a8c4[_0xa09a('0x1f')],_0x50a8c4[_0xa09a('0x1d')]));_0x50a8c4['on']('error',errorHandler);_0x50a8c4['on'](_0xa09a('0x2a'),closeHandler);_0x50a8c4['on'](_0xa09a('0x2b'),timeoutHandler);_0x50a8c4[_0xa09a('0x2c')]=![];_0x50a8c4['on'](_0xa09a('0x2d'),hangupHandler);var _0x3786a0=_[_0xa09a('0x2e')](projects,[_0xa09a('0x16'),_0x50a8c4[_0xa09a('0x1b')]]);if(!_0x3786a0)return Project[_0xa09a('0x2f')](_0x50a8c4);if(!_0x3786a0[_0xa09a('0x30')])return Project[_0xa09a('0x31')](_0x50a8c4);return Project['initialize'](_0x3786a0,_0x50a8c4);}function main(){var _0x3106bd;return utilLicense[_0xa09a('0x32')]()[_0xa09a('0x22')](function(_0x535ea2){if(!_0x535ea2)return;if(_0x535ea2[_0xa09a('0x33')]){if(_0x535ea2[_0xa09a('0x34')]&&_0x535ea2[_0xa09a('0x34')]>0x0){logger[_0xa09a('0x14')](util[_0xa09a('0x19')]('[LICENSE]\x20CHANNELS:\x20%s',_0x535ea2[_0xa09a('0x34')]));_0x3106bd=_0x535ea2[_0xa09a('0x34')];}else{logger['info'](_0xa09a('0x35'));}}else{logger[_0xa09a('0x14')](_0xa09a('0x36'));_0x3106bd=-0x1;}})[_0xa09a('0x22')](function(){return Project['getAll']();})[_0xa09a('0x22')](function(_0x5f35b0){projects=_0x5f35b0;return;})[_0xa09a('0x23')](function(_0x55ed04){logger[_0xa09a('0x10')]('[LICENSE]',_0x55ed04[_0xa09a('0xc')]);})[_0xa09a('0x37')](function(){var _0x39fd17=require('./server')(config[_0xa09a('0x8')]['port'],config['agi']['ip'],_0x3106bd);_0x39fd17['on'](_0xa09a('0x10'),errorHandler);_0x39fd17['on']('listening',listeningHandler);_0x39fd17['on'](_0xa09a('0x38'),connectionHandler);_0x39fd17['on'](_0xa09a('0x2a'),closeHandler);});}main();
\ No newline at end of file
+var _0xb8b2=['createSquareReport','then','hasOwnProperty','indexOf','agi_','substring','debug','variables','stringify','close','timeout','find','handleNotFound','production','handleUnpublished','initialize','getLicense','voice','callysquare','[LICENSE]\x20CHANNELS:\x20%s','[LICENSE]\x20CHANNELS:\x20UNLIMITED','[LICENSE]\x20VOICE\x20IS\x20DISABLED','getAll','catch','[LICENSE]','finally','listening','connection','lodash','syncho','util','../../config/environment','agi','../../config/license/util','./project','EventEmitter','defaults','127.0.0.1','projectUpdate','nextTick','error','stack','findIndex','deleted','splice','push','log','Cally\x20Square\x20server\x20listening\x20on\x20port\x20%d!','info','format','[LISTENING]\x20Cally\x20Square\x20listening\x20%s:%d','port','name','message','[CLOSE]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s','arg_1','calleridname','dnid','uniqueid','[TIMEOUT]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s','[HANGUP]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s','evtHangup'];(function(_0x20c159,_0x5e151a){var _0x3b48f7=function(_0x135700){while(--_0x135700){_0x20c159['push'](_0x20c159['shift']());}};_0x3b48f7(++_0x5e151a);}(_0xb8b2,0x1ce));var _0x2b8b=function(_0x35b18a,_0x6b2fbe){_0x35b18a=_0x35b18a-0x0;var _0x4db1bd=_0xb8b2[_0x35b18a];return _0x4db1bd;};'use strict';var _=require(_0x2b8b('0x0'));var syncho=require(_0x2b8b('0x1'));var util=require(_0x2b8b('0x2'));var config=require(_0x2b8b('0x3'));var logger=require('../../config/logger')(_0x2b8b('0x4'));var utilLicense=require(_0x2b8b('0x5'));var rpc=require('./rpc');var Project=require(_0x2b8b('0x6'));var AGIEmitter=require('./events')[_0x2b8b('0x7')];var projects=[];config[_0x2b8b('0x4')]=_[_0x2b8b('0x8')](config[_0x2b8b('0x4')],{'ip':_0x2b8b('0x9'),'port':0x11dd});AGIEmitter['on'](_0x2b8b('0xa'),projectUpdateHandler);function connectionHandler(_0x39bb0f){process[_0x2b8b('0xb')](function(){syncho(function(){try{setChannelVariables(_0x39bb0f);agiHandler(_0x39bb0f);}catch(_0xcfd64c){logger[_0x2b8b('0xc')](_0xcfd64c[_0x2b8b('0xd')]);}});});}function projectUpdateHandler(_0x5189fa){try{var _0x285878=_[_0x2b8b('0xe')](projects,['id',_0x5189fa['id']]);if(_0x285878>-0x1){if(_0x5189fa[_0x2b8b('0xf')]===!![]){projects[_0x2b8b('0x10')](_0x285878,0x1);}else{projects[_0x285878]=_0x5189fa;}}else{projects[_0x2b8b('0x11')](_0x5189fa);}}catch(_0x3b44c4){logger[_0x2b8b('0xc')](_0x3b44c4[_0x2b8b('0xd')]);}}function listeningHandler(){console[_0x2b8b('0x12')](_0x2b8b('0x13'),config[_0x2b8b('0x4')]['port']);logger[_0x2b8b('0x14')](util[_0x2b8b('0x15')](_0x2b8b('0x16'),config[_0x2b8b('0x4')]['ip'],config[_0x2b8b('0x4')][_0x2b8b('0x17')]));}function errorHandler(_0x5c36cf){if(_0x5c36cf&&_0x5c36cf[_0x2b8b('0x18')]&&_0x5c36cf[_0x2b8b('0x19')]){logger[_0x2b8b('0xc')](util[_0x2b8b('0x15')]('[%s]\x20%s',_0x5c36cf[_0x2b8b('0x18')],_0x5c36cf[_0x2b8b('0x19')]));}else{logger[_0x2b8b('0xc')](util[_0x2b8b('0x15')]('[ERROR]\x20%s',_0x5c36cf[_0x2b8b('0xd')]));}}function closeHandler(){logger[_0x2b8b('0x14')](util['format'](_0x2b8b('0x1a'),this[_0x2b8b('0x1b')],this[_0x2b8b('0x1c')],this['callerid'],this[_0x2b8b('0x1d')],this[_0x2b8b('0x1e')]));try{createSquareReport(this);}catch(_0x456c45){logger[_0x2b8b('0xc')](_0x456c45[_0x2b8b('0xd')]);}}function timeoutHandler(){logger['info'](util['format'](_0x2b8b('0x1f'),this[_0x2b8b('0x1b')],this['calleridname'],this['callerid'],this[_0x2b8b('0x1d')],this[_0x2b8b('0x1e')]));}function hangupHandler(){logger[_0x2b8b('0x14')](util[_0x2b8b('0x15')](_0x2b8b('0x20'),this[_0x2b8b('0x1b')],this[_0x2b8b('0x1c')],this['callerid'],this[_0x2b8b('0x1d')],this['uniqueid']));this[_0x2b8b('0x21')]=!![];}function createSquareReport(_0x44a6a8,_0x4c456f){rpc[_0x2b8b('0x22')](_0x44a6a8)[_0x2b8b('0x23')](function(_0x3e37be){if(_0x4c456f){_0x4c456f(null,_0x3e37be);}})['catch'](function(_0x1c6f51){if(_0x4c456f){_0x4c456f(null,_0x1c6f51);}});}function setChannelVariables(_0x1b5988){for(var _0x5ecc6f in _0x1b5988){if(_0x1b5988[_0x2b8b('0x24')](_0x5ecc6f)){if(_0x5ecc6f[_0x2b8b('0x25')](_0x2b8b('0x26'))===0x0){_0x1b5988[_0x5ecc6f[_0x2b8b('0x27')](0x4)]=_0x1b5988[_0x5ecc6f];delete _0x1b5988[_0x5ecc6f];}}}}function agiHandler(_0x5ac1af){logger[_0x2b8b('0x28')](_0x2b8b('0x29'),JSON[_0x2b8b('0x2a')](_0x5ac1af,null,0x2));logger[_0x2b8b('0x14')](util[_0x2b8b('0x15')]('[START]\x20%s\x20project:\x20from\x20\x22%s\x22\x20<%s>\x20to\x20extension\x20%s\x20with\x20uniqueid\x20%s',_0x5ac1af[_0x2b8b('0x1b')],_0x5ac1af['calleridname'],_0x5ac1af['callerid'],_0x5ac1af[_0x2b8b('0x1d')],_0x5ac1af[_0x2b8b('0x1e')]));_0x5ac1af['on'](_0x2b8b('0xc'),errorHandler);_0x5ac1af['on'](_0x2b8b('0x2b'),closeHandler);_0x5ac1af['on'](_0x2b8b('0x2c'),timeoutHandler);_0x5ac1af[_0x2b8b('0x21')]=![];_0x5ac1af['on']('hangup',hangupHandler);var _0xa0bb42=_[_0x2b8b('0x2d')](projects,['name',_0x5ac1af[_0x2b8b('0x1b')]]);if(!_0xa0bb42)return Project[_0x2b8b('0x2e')](_0x5ac1af);if(!_0xa0bb42[_0x2b8b('0x2f')])return Project[_0x2b8b('0x30')](_0x5ac1af);return Project[_0x2b8b('0x31')](_0xa0bb42,_0x5ac1af);}function main(){var _0x3afec3;return utilLicense[_0x2b8b('0x32')]()[_0x2b8b('0x23')](function(_0x996898){if(!_0x996898)return;if(_0x996898[_0x2b8b('0x33')]){if(_0x996898[_0x2b8b('0x34')]&&_0x996898[_0x2b8b('0x34')]>0x0){logger['info'](util[_0x2b8b('0x15')](_0x2b8b('0x35'),_0x996898[_0x2b8b('0x34')]));_0x3afec3=_0x996898[_0x2b8b('0x34')];}else{logger[_0x2b8b('0x14')](_0x2b8b('0x36'));}}else{logger[_0x2b8b('0x14')](_0x2b8b('0x37'));_0x3afec3=-0x1;}})['then'](function(){return Project[_0x2b8b('0x38')]();})[_0x2b8b('0x23')](function(_0x298e2e){projects=_0x298e2e;return;})[_0x2b8b('0x39')](function(_0x238555){logger[_0x2b8b('0xc')](_0x2b8b('0x3a'),_0x238555['stack']);})[_0x2b8b('0x3b')](function(){var _0x27c8c9=require('./server')(config[_0x2b8b('0x4')]['port'],config['agi']['ip'],_0x3afec3);_0x27c8c9['on'](_0x2b8b('0xc'),errorHandler);_0x27c8c9['on'](_0x2b8b('0x3c'),listeningHandler);_0x27c8c9['on'](_0x2b8b('0x3d'),connectionHandler);_0x27c8c9['on'](_0x2b8b('0x2b'),closeHandler);});}main();
\ No newline at end of file