6163be0517febec2228fe47c47114d4a775b7ddb
[motion2.git] / server / services / ami / trigger / integration / zoho.js
1 // *************************************************************************
2 // *                                                                       *
3 // * xCALLY Motion -  The Omnichannel Contact Center                       *
4 // * Copyright (c) Xenialab s.r.l. All Rights Reserved                     *
5 // *                                                                       *
6 // *************************************************************************
7 // *                                                                       *
8 // * Email: info@xcally.com                                                *
9 // * Website: https://www.xcally.com                                       *
10 // *                                                                       *
11 // *************************************************************************
12 // *                                                                       *
13 // * The SOFTWARE PRODUCT is protected by copyright laws and international *
14 // * copyright treaties, as well as other intellectual property laws and   *
15 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                         *
16 // *                                                                       *
17 // *************************************************************************
18 var _0x6594=['starttime','mm:ss','lastevent','called','Call_Result','Called','complete','connect','Answered','abandoned','Abandoned','Timeout','Call_Start_Time','outbound','agentcalledAt','Call_Type','merge','code','err','stack','log','queue','host','serverUrl','stripTrailingSlash','[QUEUE]','Recording\x20is\x20enabled!','recordingURL','/api/voice/recordings/','zoho.eu','com','The\x20User\x20ID\x20is:','calleridnum','Inbound','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','trigger:browser:url','https://crm.','/crm/EntityInfo.do?module=Calls&id=','recordingFormat','none','uniqueid','/downloads?type=uniqueid&token=','destcalleridname','destcalleridnum','Outbound','[OUTBOUND]','user:%s','unmanaged','monitor_format','toUpperCase','calleridname','./util','moment','ioredis','bluebird','../../../../config/environment','redis','defaults','localhost','emit','[HTTP]','stringify','length','forEach','string','picklist','type','idField','content','variable','variableName','toString','customVariable','Variable','name','toLowerCase','indexOf','isNil','access_token','isBefore','expires_in','https://accounts.zoho.com','https://accounts.zoho.eu','https://accounts.zoho.com.cn','POST','/oauth/v2/token','refreshToken','clientId','clientSecret','refresh_token','add','seconds','catch','error','info','format','https://www.zohoapis.%s/crm/v2/users','Zoho-oauthtoken\x20','then','users','isArrayLikeObject','findIndex','email','Agent\x20found!','Using\x20the\x20admin\x20account!','user','Administrator','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','The\x20failing\x20result\x20is','data','https://www.zohoapis.','/crm/v2/','moduleCreate','role','first_name','last_name','SUCCESS','details','enduserType','startCase','Error:\x20','moduleSearch','contact_lead','uri','/crm/v2/Contacts/search?criteria=((Phone:equals:','Contacts','/crm/v2/Leads/search?criteria=((Phone:equals:','Leads','nothing','lead','Creating\x20new\x20call...','profile','administrator','Subject','Subjects','Description','getString','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','talktime','Call_Duration','answertime','endtime','YYYY-MM-DDTHH:mm:ss','diff'];(function(_0x3960dd,_0x53ce7b){var _0x1199ce=function(_0x423def){while(--_0x423def){_0x3960dd['push'](_0x3960dd['shift']());}};_0x1199ce(++_0x53ce7b);}(_0x6594,0xcb));var _0x4659=function(_0x3b3750,_0x28f3b8){_0x3b3750=_0x3b3750-0x0;var _0x1b9e8b=_0x6594[_0x3b3750];return _0x1b9e8b;};'use strict';var _=require('lodash');var rp=require('request-promise');var md5=require('md5');var util=require('util');var intUtil=require(_0x4659('0x0'));var moment=require(_0x4659('0x1'));var Redis=require(_0x4659('0x2'));var BPromise=require(_0x4659('0x3'));var config=require(_0x4659('0x4'));var logger=require('../../../../config/logger')('zoho');config[_0x4659('0x5')]=_[_0x4659('0x6')](config[_0x4659('0x5')],{'host':_0x4659('0x7'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0x4659('0x5')]));function emit(_0x39b740,_0xd896b7,_0x16e287){io['to'](_0x39b740)[_0x4659('0x8')](_0xd896b7,_0x16e287);}function request(_0x27a2ea){logger['debug'](_0x4659('0x9'),JSON[_0x4659('0xa')](_0x27a2ea));return rp(_0x27a2ea);}function getCustomFields(_0xdff670,_0xe1e784){var _0x3a1c89={};if(_0xdff670[_0x4659('0xb')]>0x0){_[_0x4659('0xc')](_0xdff670,function(_0x517724){if(_['includes']([_0x4659('0xd'),_0x4659('0xe')],_0x517724[_0x4659('0xf')])&&_0x517724[_0x4659('0x10')]){_0x3a1c89[_0x517724[_0x4659('0x10')]]=_0x517724[_0x4659('0x11')]['toString']();}else if(_0x517724['type']===_0x4659('0x12')&&_0x517724['variableName']&&_0x517724[_0x4659('0x10')]&&_0xe1e784[_0x517724[_0x4659('0x13')]]){_0x3a1c89[_0x517724[_0x4659('0x10')]]=_0xe1e784[_0x517724['variableName']][_0x4659('0x14')]();}else if(_0x517724[_0x4659('0xf')]===_0x4659('0x15')&&_0x517724[_0x4659('0x16')]&&_0x517724['Variable'][_0x4659('0x17')]&&_0x517724[_0x4659('0x10')]&&_0xe1e784[_0x517724[_0x4659('0x16')][_0x4659('0x17')]['toLowerCase']()]){_0x3a1c89[_0x517724[_0x4659('0x10')]]=_0xe1e784[_0x517724[_0x4659('0x16')]['name'][_0x4659('0x18')]()][_0x4659('0x14')]();}});}return _0x3a1c89;}function getName(_0x6b8d07){if(_0x6b8d07[_0x4659('0x19')]('\x20')>0x0){var _0x53d9bd=_0x6b8d07['split'](/ (.+)/);if(_0x53d9bd[0x1]){return _0x53d9bd;}}return[_0x6b8d07,_0x6b8d07];}var accountsTokens={};function getAccessToken(_0x494261){return new Promise(function(_0x157f1a,_0x1fce1d){if(!_[_0x4659('0x1a')](accountsTokens[_0x494261['id']])&&!_[_0x4659('0x1a')](accountsTokens[_0x494261['id']][_0x4659('0x1b')])){if(moment()[_0x4659('0x1c')](accountsTokens[_0x494261['id']][_0x4659('0x1d')])){_0x157f1a(accountsTokens[_0x494261['id']][_0x4659('0x1b')]);}}var _0x494631;switch(_0x494261['zone']){case'US':_0x494631=_0x4659('0x1e');break;case'AU':_0x494631='https://accounts.zoho.com.au';break;case'EU':_0x494631=_0x4659('0x1f');break;case'IN':_0x494631='https://accounts.zoho.in';break;case'CN':_0x494631=_0x4659('0x20');break;default:_0x494631=_0x4659('0x1f');break;}var _0x155903={'method':_0x4659('0x21'),'uri':_0x494631+_0x4659('0x22'),'qs':{'refresh_token':_0x494261[_0x4659('0x23')],'client_id':_0x494261[_0x4659('0x24')],'client_secret':_0x494261[_0x4659('0x25')],'grant_type':_0x4659('0x26')},'json':!![]};return rp(_0x155903)['then'](function(_0x428dd5){accountsTokens[_0x494261['id']]={'access_token':_0x428dd5[_0x4659('0x1b')],'expires_in':moment()[_0x4659('0x27')](_0x428dd5[_0x4659('0x1d')],_0x4659('0x28'))};_0x157f1a(_0x428dd5[_0x4659('0x1b')]);})[_0x4659('0x29')](function(_0x2c23a7){logger[_0x4659('0x2a')]('Failing\x20creating\x20the\x20access_token',_0x2c23a7['stack']);_0x1fce1d(_0x2c23a7);});});}function getUser(_0xde3c49,_0x26d67f,_0x5c5a31,_0x507fc1){logger[_0x4659('0x2b')]('Search\x20user');return request({'method':'GET','uri':util[_0x4659('0x2c')](_0x4659('0x2d'),_0x26d67f),'qs':{'type':'ActiveUsers'},'headers':{'Authorization':_0x4659('0x2e')+_0xde3c49},'json':!![]})[_0x4659('0x2f')](function(_0x2edb51){if(_0x2edb51[_0x4659('0x30')]){var _0x1719a0=-0x1;if(_[_0x4659('0x31')](_0x2edb51[_0x4659('0x30')])){if(!_['isNil'](_0x507fc1)){_0x1719a0=_[_0x4659('0x32')](_0x2edb51[_0x4659('0x30')],function(_0x3841d1){return _0x3841d1[_0x4659('0x33')]===_0x507fc1;});}if(_0x1719a0>=0x0){logger['info'](_0x4659('0x34'));}else{logger[_0x4659('0x2b')](_0x4659('0x35'));_0x1719a0=_[_0x4659('0x32')](_0x2edb51[_0x4659('0x30')],function(_0x1e1d50){return _0x1e1d50['profile']['name']==='Administrator';});}return _0x2edb51[_0x4659('0x30')][_0x1719a0];}else{if(_0x2edb51[_0x4659('0x36')]['profile'][_0x4659('0x17')]===_0x4659('0x37')){logger['info'](_0x4659('0x35'));user=_0x2edb51[_0x4659('0x36')];return user;}else{logger['error']('The\x20failing\x20result\x20is',JSON[_0x4659('0xa')](_0x2edb51));throw new Error(_0x4659('0x38')+JSON[_0x4659('0xa')](_0x2edb51));}}}else{logger[_0x4659('0x2a')](_0x4659('0x39'),JSON[_0x4659('0xa')](_0x2edb51));throw new Error(_0x4659('0x38')+JSON[_0x4659('0xa')](_0x2edb51));}})[_0x4659('0x29')](function(_0x58e5b9){console[_0x4659('0x2a')](_0x58e5b9);});}function getZohoUser(_0x41d2bc,_0x4ad820){return new BPromise(function(_0x559316,_0x490d0b){request(_0x41d2bc)['then'](function(_0xb4a62d){var _0x77f449=null;if(_0xb4a62d){_0x77f449=_0xb4a62d[_0x4659('0x3a')][0x0];_0x77f449['enduserType']=_0x4ad820;}_0x559316(_0x77f449);})[_0x4659('0x29')](function(_0x103b7f){_0x490d0b(_0x103b7f);});});}function createEndUser(_0x528556,_0x155a09,_0x4fbabc,_0x1f5298,_0x27a42f,_0x4dc1ad){var _0x4fbabc=getName(_0x4fbabc);return request({'method':_0x4659('0x21'),'uri':_0x4659('0x3b')+_0x155a09+_0x4659('0x3c')+_['startCase'](_0x4dc1ad[_0x4659('0x3d')])+'s','body':{'data':[{'Last_Name':_0x4fbabc[0x1],'First_Name':_0x4fbabc[0x0],'Phone':_0x1f5298,'Owner':{'name':!_[_0x4659('0x1a')](_0x27a42f['role'][_0x4659('0x17')])?_0x27a42f[_0x4659('0x3e')][_0x4659('0x17')]:!_[_0x4659('0x1a')](_0x27a42f[_0x4659('0x3f')])?_0x27a42f[_0x4659('0x3f')]+'\x20'+_0x27a42f['last_name']:_0x27a42f[_0x4659('0x40')],'id':_0x27a42f['id']}}]},'headers':{'Authorization':_0x4659('0x2e')+_0x528556},'json':!![]})[_0x4659('0x2f')](function(_0x9f120a){if(_0x9f120a&&_0x9f120a['data'][0x0]['code']===_0x4659('0x41')){var _0x261146=_0x9f120a[_0x4659('0x3a')][0x0][_0x4659('0x42')];_0x261146[_0x4659('0x43')]=_[_0x4659('0x44')](_0x4dc1ad[_0x4659('0x3d')])+'s';return _0x261146;}logger['error'](_0x4659('0x39'),JSON[_0x4659('0xa')](data));throw new Error(_0x4659('0x45')+JSON[_0x4659('0xa')](data));})['catch'](function(_0x407e2b){console['log']('CREATE\x20ERROR',_0x407e2b);});}function getEndUser(_0x4a0fdf,_0x5ad30b,_0x5eba31,_0x1c4b8e,_0x22b75f,_0x2ab7b3,_0x16992a){var _0x2f9fc2={'method':'GET','uri':'','headers':{'Authorization':_0x4659('0x2e')+_0x4a0fdf},'json':!![]};switch(_0x16992a[_0x4659('0x46')]){case _0x4659('0x47'):_0x2f9fc2[_0x4659('0x48')]='https://www.zohoapis.'+_0x5ad30b+_0x4659('0x49')+_0x22b75f+'))';return getZohoUser(_0x2f9fc2,_0x4659('0x4a'))[_0x4659('0x2f')](function(_0x1d3876){if(_0x1d3876)return _0x1d3876;_0x2f9fc2[_0x4659('0x48')]='https://www.zohoapis.'+_0x5ad30b+_0x4659('0x4b')+_0x22b75f+'))';return getZohoUser(_0x2f9fc2,_0x4659('0x4c'))['then'](function(_0x3839cc){if(_0x3839cc)return _0x3839cc;if(_0x16992a['moduleCreate']!=_0x4659('0x4d')){return createEndUser(_0x4a0fdf,_0x5ad30b,_0x1c4b8e,_0x22b75f,_0x2ab7b3,_0x16992a);}else{return{};}});});break;case'contact':_0x2f9fc2[_0x4659('0x48')]='https://www.zohoapis.'+_0x5ad30b+_0x4659('0x49')+_0x22b75f+'))';return getZohoUser(_0x2f9fc2,_0x4659('0x4a'))[_0x4659('0x2f')](function(_0x146594){if(_0x146594)return _0x146594;if(_0x16992a[_0x4659('0x3d')]!=_0x4659('0x4d')){return createEndUser(_0x4a0fdf,_0x5ad30b,_0x1c4b8e,_0x22b75f,_0x2ab7b3,_0x16992a);}else{return{};}});break;case _0x4659('0x4e'):_0x2f9fc2[_0x4659('0x48')]=_0x4659('0x3b')+_0x5ad30b+'/crm/v2/Leads/search?criteria=((Phone:equals:'+_0x22b75f+'))';return getZohoUser(_0x2f9fc2,_0x4659('0x4c'))[_0x4659('0x2f')](function(_0x41233b){if(_0x41233b)return _0x41233b;if(_0x16992a[_0x4659('0x3d')]!='nothing'){return createEndUser(_0x4a0fdf,_0x5ad30b,_0x1c4b8e,_0x22b75f,_0x2ab7b3,_0x16992a);}else{return{};}});break;}}function getCall(_0x3b4a2d,_0x4a8a0d,_0x1d8b61,_0x105369,_0x3dbb46,_0x42bd7e,_0x4f62ac,_0xc62155){logger[_0x4659('0x2b')](_0x4659('0x4f'));var _0x35267e={};_0x35267e['Owner']={'name':!_[_0x4659('0x1a')](_0x105369[_0x4659('0x3e')][_0x4659('0x17')])&&!_[_0x4659('0x1a')](_0x105369[_0x4659('0x50')][_0x4659('0x17')])&&_0x105369[_0x4659('0x50')][_0x4659('0x17')]===_0x4659('0x51')?_0x105369[_0x4659('0x3e')][_0x4659('0x17')]:!_[_0x4659('0x1a')](_0x105369[_0x4659('0x3f')])?_0x105369[_0x4659('0x3f')]+'\x20'+_0x105369['last_name']:_0x105369[_0x4659('0x40')],'id':_0x105369['id']};_0x35267e[_0x4659('0x52')]=intUtil['getString'](_0x42bd7e[_0x4659('0x53')],_0x4f62ac,'\x20');_0x35267e[_0x4659('0x54')]=intUtil[_0x4659('0x55')](_0x42bd7e[_0x4659('0x56')],_0x4f62ac,'\x0a');if(_0x3dbb46[_0x4659('0x43')]===_0x4659('0x4a')){_0x35267e[_0x4659('0x57')]={'name':!_['isNil'](_0x3dbb46[_0x4659('0x58')])?_0x3dbb46[_0x4659('0x58')]:!_[_0x4659('0x1a')](_0x3dbb46[_0x4659('0x59')])?_0x3dbb46[_0x4659('0x59')]+'\x20'+_0x3dbb46[_0x4659('0x5a')]:_0x3dbb46[_0x4659('0x5a')],'id':_0x3dbb46['id']};}if(_0x3dbb46['enduserType']===_0x4659('0x4c')){_0x35267e[_0x4659('0x5b')]={'name':!_['isNil'](_0x3dbb46[_0x4659('0x58')])?_0x3dbb46[_0x4659('0x58')]:!_[_0x4659('0x1a')](_0x3dbb46['First_Name'])?_0x3dbb46[_0x4659('0x59')]+'\x20'+_0x3dbb46[_0x4659('0x5a')]:_0x3dbb46['Last_Name'],'id':_0x3dbb46['id']};_0x35267e[_0x4659('0x5c')]=_['startCase'](_0x3dbb46[_0x4659('0x43')]);}if(_0x4f62ac[_0x4659('0x5d')]){_0x35267e[_0x4659('0x5e')]=moment['utc'](parseInt(_0x4f62ac['talktime'])*0x3e8)[_0x4659('0x2c')]('mm:ss');}else if(_0x4f62ac[_0x4659('0x5f')]&&_0x4f62ac[_0x4659('0x60')]){_0x35267e[_0x4659('0x5e')]=moment['utc'](moment(_0x4f62ac['endtime'],_0x4659('0x61'))[_0x4659('0x62')](moment(_0x4f62ac[_0x4659('0x63')],'YYYY-MM-DDTHH:mm:ss')))['format'](_0x4659('0x64'));}switch(_0x4f62ac[_0x4659('0x65')]){case _0x4659('0x66'):_0x35267e[_0x4659('0x67')]=_0x4659('0x68');break;case _0x4659('0x69'):case _0x4659('0x6a'):_0x35267e['Call_Result']=_0x4659('0x6b');break;case'rejected':_0x35267e[_0x4659('0x67')]='Rejected';break;case _0x4659('0x6c'):_0x35267e[_0x4659('0x67')]=_0x4659('0x6d');break;case'timeout':_0x35267e['Call_Result']=_0x4659('0x6e');default:}_0x35267e[_0x4659('0x6f')]=(_0xc62155===_0x4659('0x70')?moment(_0x4f62ac[_0x4659('0x63')])[_0x4659('0x2c')](_0x4659('0x61')):moment(_0x4f62ac[_0x4659('0x71')])[_0x4659('0x2c')](_0x4659('0x61')))||moment()[_0x4659('0x2c')](_0x4659('0x61'));_0x35267e[_0x4659('0x72')]=_0xc62155||'Inbound';_0x35267e=_[_0x4659('0x73')](_0x35267e,getCustomFields(_0x42bd7e['Fields'],_0x4f62ac));return request({'method':_0x4659('0x21'),'uri':_0x4659('0x3b')+_0x4a8a0d+'/crm/v2/Calls','headers':{'Authorization':_0x4659('0x2e')+_0x3b4a2d},'body':{'data':[_0x35267e]},'json':!![]})[_0x4659('0x2f')](function(_0x296c2a){if(_0x296c2a&&_0x296c2a['data'][0x0][_0x4659('0x74')]===_0x4659('0x41')){logger[_0x4659('0x2b')]('Call\x20created!');return{'id':_0x296c2a[_0x4659('0x3a')][0x0]['details']['id']};}})[_0x4659('0x29')](function(_0x278eae){logger['info'](_0x4659('0x75'),_0x278eae[_0x4659('0x76')]);console[_0x4659('0x77')](_0x4659('0x75'),_0x278eae);});}exports[_0x4659('0x78')]=function(_0x482dc9,_0x26a336,_0x249eb1,_0x38ac19,_0x396c6f,_0x1570f0){var _0x179d84,_0x551ed8,_0x4a0a6a;_0x1570f0['host']=intUtil['stripTrailingSlash'](_0x1570f0[_0x4659('0x79')]);_0x1570f0[_0x4659('0x7a')]=intUtil[_0x4659('0x7b')](_0x1570f0['serverUrl']);if(_0x396c6f&&_0x396c6f['monitor_format']){logger['info'](_0x4659('0x7c'),_0x4659('0x7d'));_0x26a336[_0x4659('0x7e')]=_0x1570f0[_0x4659('0x7a')]+_0x4659('0x7f')+_0x26a336['uniqueid']+'/downloads?type=uniqueid&token='+md5(_0x26a336['uniqueid']);}else{_0x26a336['recordingURL']='';}var _0x59c4a6=_0x1570f0['host']===_0x4659('0x80')?'eu':_0x4659('0x81');return getAccessToken(_0x1570f0)[_0x4659('0x2f')](function(_0xcfa33f){_0x4a0a6a=_0xcfa33f;return getUser(_0x4a0a6a,_0x59c4a6,_0x1570f0,_0x38ac19[_0x4659('0x33')]);})[_0x4659('0x2f')](function(_0x5a15b0){_0x179d84=_0x5a15b0;logger[_0x4659('0x2b')](_0x4659('0x82'),_0x179d84['id']);return getEndUser(_0x4a0a6a,_0x59c4a6,_0x1570f0,_0x26a336['calleridname'],_0x26a336[_0x4659('0x83')],_0x179d84,_0x249eb1);})[_0x4659('0x2f')](function(_0x5a31cd){_0x551ed8=_0x5a31cd;return getCall(_0x4a0a6a,_0x59c4a6,_0x1570f0,_0x179d84,_0x551ed8,_0x249eb1,_0x26a336,_0x4659('0x84'));})['then'](function(_0x1c5650){if(_0x1c5650){logger['info'](_0x4659('0x85'),_0x1c5650['id']);logger[_0x4659('0x2b')](_0x4659('0x7c'),_0x4659('0x86'));emit(util['format']('user:%s',_0x38ac19[_0x4659('0x17')]),_0x4659('0x87'),{'uri':_0x4659('0x88')+_0x1570f0[_0x4659('0x79')]+_0x4659('0x89')+_0x1c5650['id']});}})[_0x4659('0x29')](function(_0x3066e5){logger[_0x4659('0x2a')](_0x4659('0x7c'),JSON['stringify'](_0x3066e5));});};exports[_0x4659('0x70')]=function(_0x45e350,_0x559f39,_0x3cc464,_0x289bd2,_0x1298d3,_0x524158,_0x2b51a7){var _0x4f4dc6,_0x460061,_0x1d176f;_0x524158[_0x4659('0x79')]=intUtil['stripTrailingSlash'](_0x524158[_0x4659('0x79')]);_0x524158[_0x4659('0x7a')]=intUtil[_0x4659('0x7b')](_0x524158[_0x4659('0x7a')]);if(_0x2b51a7&&_0x2b51a7[_0x4659('0x8a')]&&_0x2b51a7[_0x4659('0x8a')]!==_0x4659('0x8b')){logger[_0x4659('0x2b')]('[OUTBOUND]',_0x4659('0x7d'));_0x559f39[_0x4659('0x7e')]=_0x524158[_0x4659('0x7a')]+_0x4659('0x7f')+_0x559f39[_0x4659('0x8c')]+_0x4659('0x8d')+md5(_0x559f39['uniqueid']);}var _0x2e3135=_0x524158[_0x4659('0x79')]==='zoho.eu'?'eu':_0x4659('0x81');return getAccessToken(_0x524158)['then'](function(_0x1aca2b){_0x1d176f=_0x1aca2b;return getUser(_0x1d176f,_0x2e3135,_0x524158,_0x289bd2['email']);})[_0x4659('0x2f')](function(_0x1656cc){_0x4f4dc6=_0x1656cc;logger[_0x4659('0x2b')](_0x4659('0x82'),_0x4f4dc6['id']);return getEndUser(_0x1d176f,_0x2e3135,_0x524158,_0x559f39[_0x4659('0x8e')],_0x559f39[_0x4659('0x8f')],_0x4f4dc6,_0x3cc464);})[_0x4659('0x2f')](function(_0x273c52){_0x460061=_0x273c52;return getCall(_0x1d176f,_0x2e3135,_0x524158,_0x4f4dc6,_0x460061,_0x3cc464,_0x559f39,_0x4659('0x90'));})[_0x4659('0x2f')](function(_0xaa87dd){if(_0xaa87dd){logger['info'](_0x4659('0x85'),_0xaa87dd['id']);logger['info'](_0x4659('0x91'),_0x4659('0x86'));emit(util['format'](_0x4659('0x92'),_0x289bd2['name']),_0x4659('0x87'),{'uri':_0x4659('0x88')+_0x524158[_0x4659('0x79')]+_0x4659('0x89')+_0xaa87dd['id']});}})['catch'](function(_0x2997b7){logger[_0x4659('0x2a')](_0x4659('0x91'),JSON[_0x4659('0xa')](_0x2997b7));});};exports[_0x4659('0x93')]=function(_0x261c7e,_0x20212e,_0x46c430,_0x291d95,_0x14b144,_0x2c2577){var _0x2e9b28,_0x3601af,_0x3cb873;_0x2c2577['host']=intUtil[_0x4659('0x7b')](_0x2c2577[_0x4659('0x79')]);_0x2c2577['serverUrl']=intUtil['stripTrailingSlash'](_0x2c2577[_0x4659('0x7a')]);if(_0x14b144&&_0x14b144[_0x4659('0x94')]){logger[_0x4659('0x2b')]('['+_0x20212e['lastevent'][_0x4659('0x95')]()+']',_0x4659('0x7d'));_0x20212e[_0x4659('0x7e')]=_0x2c2577[_0x4659('0x7a')]+_0x4659('0x7f')+_0x20212e[_0x4659('0x8c')]+_0x4659('0x8d')+md5(_0x20212e['uniqueid']);}else{_0x20212e[_0x4659('0x7e')]='';}var _0xb4c445=_0x2c2577['host']==='zoho.eu'?'eu':_0x4659('0x81');return getAccessToken(_0x2c2577)['then'](function(_0x58ea22){_0x3cb873=_0x58ea22;return getUser(_0x3cb873,_0xb4c445,_0x2c2577);})[_0x4659('0x2f')](function(_0x3c0c44){_0x2e9b28=_0x3c0c44;logger['info'](_0x4659('0x82'),_0x2e9b28['id']);return getEndUser(_0x3cb873,_0xb4c445,_0x2c2577,_0x20212e[_0x4659('0x96')],_0x20212e['calleridnum'],_0x2e9b28,_0x46c430);})[_0x4659('0x2f')](function(_0x503f7a){_0x3601af=_0x503f7a;return getCall(_0x3cb873,_0xb4c445,_0x2c2577,_0x2e9b28,_0x3601af,_0x46c430,_0x20212e,_0x4659('0x84'));})[_0x4659('0x2f')](function(_0x5ccd9b){if(_0x5ccd9b){logger[_0x4659('0x2b')](_0x4659('0x85'),_0x5ccd9b['id']);}})[_0x4659('0x29')](function(_0x3bf1b2){logger[_0x4659('0x2a')]('['+_0x20212e[_0x4659('0x65')][_0x4659('0x95')]()+']',JSON[_0x4659('0xa')](_0x3bf1b2));});};