Built motion from commit (unavailable).|2.5.18
[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 _0xde1e=['destcalleridname','destcalleridnum','Outbound','unmanaged','lastevent','toUpperCase','lodash','request-promise','md5','util','./util','moment','bluebird','../../../../config/environment','../../../../config/logger','zoho','redis','defaults','localhost','socket.io-emitter','stringify','length','forEach','type','string','idField','toString','variable','variableName','customVariable','Variable','name','toLowerCase','indexOf','isNil','access_token','isBefore','expires_in','zone','https://accounts.zoho.com.au','https://accounts.zoho.eu','clientId','clientSecret','refresh_token','then','add','seconds','catch','Failing\x20creating\x20the\x20access_token','stack','info','Search\x20user','GET','format','https://www.zohoapis.%s/crm/v2/users','ActiveUsers','isArrayLikeObject','users','findIndex','email','profile','Administrator','Using\x20the\x20admin\x20account!','user','error','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','The\x20failing\x20result\x20is','data','enduserType','POST','https://www.zohoapis.','/crm/v2/','startCase','moduleCreate','role','first_name','last_name','Zoho-oauthtoken\x20','code','SUCCESS','details','log','moduleSearch','contact_lead','Contacts','uri','/crm/v2/Leads/search?criteria=((Phone:equals:','Leads','contact','/crm/v2/Contacts/search?criteria=((Phone:equals:','nothing','lead','Creating\x20new\x20call...','Subject','getString','Subjects','Description','Who_Id','Full_Name','First_Name','Last_Name','What_Id','Call_Duration','utc','talktime','mm:ss','endtime','YYYY-MM-DDTHH:mm:ss','starttime','called','Call_Result','Called','complete','connect','Answered','Rejected','abandoned','Abandoned','timeout','Timeout','agentcalledAt','Call_Type','Inbound','merge','Fields','Call\x20created!','err','queue','host','serverUrl','monitor_format','[QUEUE]','Recording\x20is\x20enabled!','/api/voice/recordings/','uniqueid','/downloads?type=uniqueid&token=','zoho.eu','com','The\x20User\x20ID\x20is:','calleridname','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','user:%s','trigger:browser:url','https://crm.','/crm/EntityInfo.do?module=Calls&id=','stripTrailingSlash','recordingFormat','none','[OUTBOUND]','recordingURL'];(function(_0x9e0b56,_0x521371){var _0x5c7dc4=function(_0x847d1a){while(--_0x847d1a){_0x9e0b56['push'](_0x9e0b56['shift']());}};_0x5c7dc4(++_0x521371);}(_0xde1e,0x9d));var _0xede1=function(_0x2641f9,_0x26715f){_0x2641f9=_0x2641f9-0x0;var _0x585741=_0xde1e[_0x2641f9];return _0x585741;};'use strict';var _=require(_0xede1('0x0'));var rp=require(_0xede1('0x1'));var md5=require(_0xede1('0x2'));var util=require(_0xede1('0x3'));var intUtil=require(_0xede1('0x4'));var moment=require(_0xede1('0x5'));var Redis=require('ioredis');var BPromise=require(_0xede1('0x6'));var config=require(_0xede1('0x7'));var logger=require(_0xede1('0x8'))(_0xede1('0x9'));config[_0xede1('0xa')]=_[_0xede1('0xb')](config['redis'],{'host':_0xede1('0xc'),'port':0x18eb});var io=require(_0xede1('0xd'))(new Redis(config[_0xede1('0xa')]));function emit(_0x452e74,_0x29fe67,_0x378954){io['to'](_0x452e74)['emit'](_0x29fe67,_0x378954);}function request(_0xa1641){logger['debug']('[HTTP]',JSON[_0xede1('0xe')](_0xa1641));return rp(_0xa1641);}function getCustomFields(_0x1a896b,_0x336f1a){var _0x225b26={};if(_0x1a896b[_0xede1('0xf')]>0x0){_[_0xede1('0x10')](_0x1a896b,function(_0x4d817f){if(_0x4d817f[_0xede1('0x11')]===_0xede1('0x12')&&_0x4d817f[_0xede1('0x13')]){_0x225b26[_0x4d817f['idField']]=_0x4d817f['content'][_0xede1('0x14')]();}else if(_0x4d817f[_0xede1('0x11')]===_0xede1('0x15')&&_0x4d817f[_0xede1('0x16')]&&_0x4d817f[_0xede1('0x13')]&&_0x336f1a[_0x4d817f['variableName']]){_0x225b26[_0x4d817f[_0xede1('0x13')]]=_0x336f1a[_0x4d817f[_0xede1('0x16')]][_0xede1('0x14')]();}else if(_0x4d817f[_0xede1('0x11')]===_0xede1('0x17')&&_0x4d817f[_0xede1('0x18')]&&_0x4d817f[_0xede1('0x18')][_0xede1('0x19')]&&_0x4d817f['idField']&&_0x336f1a[_0x4d817f[_0xede1('0x18')][_0xede1('0x19')][_0xede1('0x1a')]()]){_0x225b26[_0x4d817f[_0xede1('0x13')]]=_0x336f1a[_0x4d817f[_0xede1('0x18')][_0xede1('0x19')][_0xede1('0x1a')]()][_0xede1('0x14')]();}});}return _0x225b26;}function getName(_0x131540){if(_0x131540[_0xede1('0x1b')]('\x20')>0x0){var _0x359352=_0x131540['split'](/ (.+)/);if(_0x359352[0x1]){return _0x359352;}}return[_0x131540,_0x131540];}var accountsTokens={};function getAccessToken(_0x480b6d){return new Promise(function(_0x5e2d7b,_0x55523b){if(!_[_0xede1('0x1c')](accountsTokens[_0x480b6d['id']])&&!_[_0xede1('0x1c')](accountsTokens[_0x480b6d['id']][_0xede1('0x1d')])){if(moment()[_0xede1('0x1e')](accountsTokens[_0x480b6d['id']][_0xede1('0x1f')])){_0x5e2d7b(accountsTokens[_0x480b6d['id']][_0xede1('0x1d')]);}}var _0x153943;switch(_0x480b6d[_0xede1('0x20')]){case'US':_0x153943='https://accounts.zoho.com';break;case'AU':_0x153943=_0xede1('0x21');break;case'EU':_0x153943=_0xede1('0x22');break;case'IN':_0x153943='https://accounts.zoho.in';break;case'CN':_0x153943='https://accounts.zoho.com.cn';break;default:_0x153943=_0xede1('0x22');break;}var _0x2e69ae={'method':'POST','uri':_0x153943+'/oauth/v2/token','qs':{'refresh_token':_0x480b6d['refreshToken'],'client_id':_0x480b6d[_0xede1('0x23')],'client_secret':_0x480b6d[_0xede1('0x24')],'grant_type':_0xede1('0x25')},'json':!![]};return rp(_0x2e69ae)[_0xede1('0x26')](function(_0x36ddc8){accountsTokens[_0x480b6d['id']]={'access_token':_0x36ddc8[_0xede1('0x1d')],'expires_in':moment()[_0xede1('0x27')](_0x36ddc8[_0xede1('0x1f')],_0xede1('0x28'))};_0x5e2d7b(_0x36ddc8[_0xede1('0x1d')]);})[_0xede1('0x29')](function(_0x2830fc){logger['error'](_0xede1('0x2a'),_0x2830fc[_0xede1('0x2b')]);_0x55523b(_0x2830fc);});});}function getUser(_0x4ef352,_0x368946,_0x20e647,_0xbf0a98){logger[_0xede1('0x2c')](_0xede1('0x2d'));return request({'method':_0xede1('0x2e'),'uri':util[_0xede1('0x2f')](_0xede1('0x30'),_0x368946),'qs':{'type':_0xede1('0x31')},'headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x4ef352},'json':!![]})['then'](function(_0x77b5b0){if(_0x77b5b0['users']){var _0x347a7b=-0x1;if(_[_0xede1('0x32')](_0x77b5b0[_0xede1('0x33')])){if(!_[_0xede1('0x1c')](_0xbf0a98)){_0x347a7b=_[_0xede1('0x34')](_0x77b5b0[_0xede1('0x33')],function(_0xc0d992){return _0xc0d992[_0xede1('0x35')]===_0xbf0a98;});}if(_0x347a7b>=0x0){logger[_0xede1('0x2c')]('Agent\x20found!');}else{logger[_0xede1('0x2c')]('Using\x20the\x20admin\x20account!');_0x347a7b=_[_0xede1('0x34')](_0x77b5b0['users'],function(_0x46a483){return _0x46a483[_0xede1('0x36')][_0xede1('0x19')]===_0xede1('0x37');});}return _0x77b5b0[_0xede1('0x33')][_0x347a7b];}else{if(_0x77b5b0['user'][_0xede1('0x36')]['name']===_0xede1('0x37')){logger[_0xede1('0x2c')](_0xede1('0x38'));user=_0x77b5b0[_0xede1('0x39')];return user;}else{logger[_0xede1('0x3a')]('The\x20failing\x20result\x20is',JSON[_0xede1('0xe')](_0x77b5b0));throw new Error(_0xede1('0x3b')+JSON[_0xede1('0xe')](_0x77b5b0));}}}else{logger[_0xede1('0x3a')](_0xede1('0x3c'),JSON[_0xede1('0xe')](_0x77b5b0));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON[_0xede1('0xe')](_0x77b5b0));}})[_0xede1('0x29')](function(_0x45e0ba){console['error'](_0x45e0ba);});}function getZohoUser(_0x23baa1,_0x3e3b06){return new BPromise(function(_0x4cafc5,_0xf978e5){request(_0x23baa1)[_0xede1('0x26')](function(_0x4e60f5){var _0x4cb806=null;if(_0x4e60f5){_0x4cb806=_0x4e60f5[_0xede1('0x3d')][0x0];_0x4cb806[_0xede1('0x3e')]=_0x3e3b06;}_0x4cafc5(_0x4cb806);})[_0xede1('0x29')](function(_0x32dc3c){_0xf978e5(_0x32dc3c);});});}function createEndUser(_0x3198fc,_0xe8af0f,_0x113a2e,_0x30acce,_0x3cfd96,_0x683354){var _0x113a2e=getName(_0x113a2e);return request({'method':_0xede1('0x3f'),'uri':_0xede1('0x40')+_0xe8af0f+_0xede1('0x41')+_[_0xede1('0x42')](_0x683354[_0xede1('0x43')])+'s','body':{'data':[{'Last_Name':_0x113a2e[0x1],'First_Name':_0x113a2e[0x0],'Phone':_0x30acce,'Owner':{'name':!_[_0xede1('0x1c')](_0x3cfd96['role'][_0xede1('0x19')])?_0x3cfd96[_0xede1('0x44')][_0xede1('0x19')]:!_[_0xede1('0x1c')](_0x3cfd96[_0xede1('0x45')])?_0x3cfd96[_0xede1('0x45')]+'\x20'+_0x3cfd96[_0xede1('0x46')]:_0x3cfd96[_0xede1('0x46')],'id':_0x3cfd96['id']}}]},'headers':{'Authorization':_0xede1('0x47')+_0x3198fc},'json':!![]})[_0xede1('0x26')](function(_0x32b6ba){if(_0x32b6ba&&_0x32b6ba['data'][0x0][_0xede1('0x48')]===_0xede1('0x49')){var _0x499b82=_0x32b6ba[_0xede1('0x3d')][0x0][_0xede1('0x4a')];_0x499b82[_0xede1('0x3e')]=_[_0xede1('0x42')](_0x683354[_0xede1('0x43')])+'s';return _0x499b82;}logger[_0xede1('0x3a')](_0xede1('0x3c'),JSON[_0xede1('0xe')](data));throw new Error('Error:\x20'+JSON['stringify'](data));})[_0xede1('0x29')](function(_0x37ea3e){console[_0xede1('0x4b')]('CREATE\x20ERROR',_0x37ea3e);});}function getEndUser(_0x1714d2,_0x413977,_0x51edf7,_0x436cfd,_0x2ee32f,_0x431b0d,_0x2c1ec5){var _0x5ae061={'method':'GET','uri':'','headers':{'Authorization':_0xede1('0x47')+_0x1714d2},'json':!![]};switch(_0x2c1ec5[_0xede1('0x4c')]){case _0xede1('0x4d'):_0x5ae061['uri']=_0xede1('0x40')+_0x413977+'/crm/v2/Contacts/search?criteria=((Phone:equals:'+_0x2ee32f+'))';return getZohoUser(_0x5ae061,_0xede1('0x4e'))[_0xede1('0x26')](function(_0x361d70){if(_0x361d70)return _0x361d70;_0x5ae061[_0xede1('0x4f')]=_0xede1('0x40')+_0x413977+_0xede1('0x50')+_0x2ee32f+'))';return getZohoUser(_0x5ae061,_0xede1('0x51'))['then'](function(_0xc83dea){if(_0xc83dea)return _0xc83dea;if(_0x2c1ec5[_0xede1('0x43')]!='nothing'){return createEndUser(_0x1714d2,_0x413977,_0x436cfd,_0x2ee32f,_0x431b0d,_0x2c1ec5);}else{return{};}});});break;case _0xede1('0x52'):_0x5ae061[_0xede1('0x4f')]=_0xede1('0x40')+_0x413977+_0xede1('0x53')+_0x2ee32f+'))';return getZohoUser(_0x5ae061,_0xede1('0x4e'))[_0xede1('0x26')](function(_0x1d5593){if(_0x1d5593)return _0x1d5593;if(_0x2c1ec5[_0xede1('0x43')]!=_0xede1('0x54')){return createEndUser(_0x1714d2,_0x413977,_0x436cfd,_0x2ee32f,_0x431b0d,_0x2c1ec5);}else{return{};}});break;case _0xede1('0x55'):_0x5ae061[_0xede1('0x4f')]=_0xede1('0x40')+_0x413977+_0xede1('0x50')+_0x2ee32f+'))';return getZohoUser(_0x5ae061,_0xede1('0x51'))['then'](function(_0x2f05e9){if(_0x2f05e9)return _0x2f05e9;if(_0x2c1ec5[_0xede1('0x43')]!=_0xede1('0x54')){return createEndUser(_0x1714d2,_0x413977,_0x436cfd,_0x2ee32f,_0x431b0d,_0x2c1ec5);}else{return{};}});break;}}function getCall(_0x4cb60f,_0x45db9a,_0x1b0c43,_0x2dca9f,_0x411525,_0x2babbf,_0x5a472d,_0xbfc812){logger[_0xede1('0x2c')](_0xede1('0x56'));var _0x3de198={};_0x3de198['Owner']={'name':!_[_0xede1('0x1c')](_0x2dca9f[_0xede1('0x44')][_0xede1('0x19')])&&!_[_0xede1('0x1c')](_0x2dca9f[_0xede1('0x36')][_0xede1('0x19')])&&_0x2dca9f[_0xede1('0x36')][_0xede1('0x19')]==='administrator'?_0x2dca9f[_0xede1('0x44')][_0xede1('0x19')]:!_[_0xede1('0x1c')](_0x2dca9f[_0xede1('0x45')])?_0x2dca9f[_0xede1('0x45')]+'\x20'+_0x2dca9f[_0xede1('0x46')]:_0x2dca9f['last_name'],'id':_0x2dca9f['id']};_0x3de198[_0xede1('0x57')]=intUtil[_0xede1('0x58')](_0x2babbf[_0xede1('0x59')],_0x5a472d,'\x20');_0x3de198[_0xede1('0x5a')]=intUtil[_0xede1('0x58')](_0x2babbf['Descriptions'],_0x5a472d,'\x0a');if(_0x411525[_0xede1('0x3e')]===_0xede1('0x4e')){_0x3de198[_0xede1('0x5b')]={'name':!_[_0xede1('0x1c')](_0x411525[_0xede1('0x5c')])?_0x411525['Full_Name']:!_['isNil'](_0x411525[_0xede1('0x5d')])?_0x411525[_0xede1('0x5d')]+'\x20'+_0x411525['Last_Name']:_0x411525[_0xede1('0x5e')],'id':_0x411525['id']};}if(_0x411525['enduserType']===_0xede1('0x51')){_0x3de198[_0xede1('0x5f')]={'name':!_[_0xede1('0x1c')](_0x411525[_0xede1('0x5c')])?_0x411525[_0xede1('0x5c')]:!_[_0xede1('0x1c')](_0x411525[_0xede1('0x5d')])?_0x411525[_0xede1('0x5d')]+'\x20'+_0x411525[_0xede1('0x5e')]:_0x411525[_0xede1('0x5e')],'id':_0x411525['id']};_0x3de198['$se_module']=_[_0xede1('0x42')](_0x411525[_0xede1('0x3e')]);}if(_0x5a472d['talktime']){_0x3de198[_0xede1('0x60')]=moment[_0xede1('0x61')](parseInt(_0x5a472d[_0xede1('0x62')])*0x3e8)[_0xede1('0x2f')](_0xede1('0x63'));}else if(_0x5a472d['answertime']&&_0x5a472d[_0xede1('0x64')]){_0x3de198['Call_Duration']=moment[_0xede1('0x61')](moment(_0x5a472d[_0xede1('0x64')],_0xede1('0x65'))['diff'](moment(_0x5a472d[_0xede1('0x66')],_0xede1('0x65'))))['format'](_0xede1('0x63'));}switch(_0x5a472d['lastevent']){case _0xede1('0x67'):_0x3de198[_0xede1('0x68')]=_0xede1('0x69');break;case _0xede1('0x6a'):case _0xede1('0x6b'):_0x3de198[_0xede1('0x68')]=_0xede1('0x6c');break;case'rejected':_0x3de198[_0xede1('0x68')]=_0xede1('0x6d');break;case _0xede1('0x6e'):_0x3de198[_0xede1('0x68')]=_0xede1('0x6f');break;case _0xede1('0x70'):_0x3de198[_0xede1('0x68')]=_0xede1('0x71');default:}_0x3de198['Call_Start_Time']=(_0xbfc812==='outbound'?moment(_0x5a472d[_0xede1('0x66')])['format'](_0xede1('0x65')):moment(_0x5a472d[_0xede1('0x72')])[_0xede1('0x2f')](_0xede1('0x65')))||moment()[_0xede1('0x2f')](_0xede1('0x65'));_0x3de198[_0xede1('0x73')]=_0xbfc812||_0xede1('0x74');_0x3de198=_[_0xede1('0x75')](_0x3de198,getCustomFields(_0x2babbf[_0xede1('0x76')],_0x5a472d));return request({'method':_0xede1('0x3f'),'uri':_0xede1('0x40')+_0x45db9a+'/crm/v2/Calls','headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x4cb60f},'body':{'data':[_0x3de198]},'json':!![]})[_0xede1('0x26')](function(_0x108c5f){if(_0x108c5f&&_0x108c5f[_0xede1('0x3d')][0x0][_0xede1('0x48')]===_0xede1('0x49')){logger[_0xede1('0x2c')](_0xede1('0x77'));return{'id':_0x108c5f['data'][0x0][_0xede1('0x4a')]['id']};}})[_0xede1('0x29')](function(_0x4c1010){logger[_0xede1('0x2c')]('err',_0x4c1010[_0xede1('0x2b')]);console[_0xede1('0x4b')](_0xede1('0x78'),_0x4c1010);});}exports[_0xede1('0x79')]=function(_0x2cfe05,_0x2f95b1,_0x188de5,_0xb2e7a,_0x7c354d,_0x4592e1){var _0x5cadc5,_0x546486,_0x4c6369;_0x4592e1['host']=intUtil['stripTrailingSlash'](_0x4592e1[_0xede1('0x7a')]);_0x4592e1[_0xede1('0x7b')]=intUtil['stripTrailingSlash'](_0x4592e1['serverUrl']);if(_0x7c354d&&_0x7c354d[_0xede1('0x7c')]){logger[_0xede1('0x2c')](_0xede1('0x7d'),_0xede1('0x7e'));_0x2f95b1['recordingURL']=_0x4592e1['serverUrl']+_0xede1('0x7f')+_0x2f95b1[_0xede1('0x80')]+_0xede1('0x81')+md5(_0x2f95b1['uniqueid']);}else{_0x2f95b1['recordingURL']='';}var _0xf6c694=_0x4592e1[_0xede1('0x7a')]===_0xede1('0x82')?'eu':_0xede1('0x83');return getAccessToken(_0x4592e1)['then'](function(_0x1ada81){_0x4c6369=_0x1ada81;return getUser(_0x4c6369,_0xf6c694,_0x4592e1,_0xb2e7a[_0xede1('0x35')]);})[_0xede1('0x26')](function(_0x224666){_0x5cadc5=_0x224666;logger[_0xede1('0x2c')](_0xede1('0x84'),_0x5cadc5['id']);return getEndUser(_0x4c6369,_0xf6c694,_0x4592e1,_0x2f95b1[_0xede1('0x85')],_0x2f95b1['calleridnum'],_0x5cadc5,_0x188de5);})[_0xede1('0x26')](function(_0x5d5c7a){_0x546486=_0x5d5c7a;return getCall(_0x4c6369,_0xf6c694,_0x4592e1,_0x5cadc5,_0x546486,_0x188de5,_0x2f95b1,_0xede1('0x74'));})[_0xede1('0x26')](function(_0x342ae7){if(_0x342ae7){logger[_0xede1('0x2c')](_0xede1('0x86'),_0x342ae7['id']);logger[_0xede1('0x2c')](_0xede1('0x7d'),_0xede1('0x87'));emit(util[_0xede1('0x2f')](_0xede1('0x88'),_0xb2e7a[_0xede1('0x19')]),_0xede1('0x89'),{'uri':_0xede1('0x8a')+_0x4592e1[_0xede1('0x7a')]+_0xede1('0x8b')+_0x342ae7['id']});}})['catch'](function(_0xa0893a){logger[_0xede1('0x3a')](_0xede1('0x7d'),JSON[_0xede1('0xe')](_0xa0893a));});};exports['outbound']=function(_0x588c4d,_0x27c13b,_0x1fd471,_0x182cef,_0x276871,_0x515130,_0x1aa386){var _0x2fe981,_0x7aa36f,_0x525f18;_0x515130[_0xede1('0x7a')]=intUtil[_0xede1('0x8c')](_0x515130[_0xede1('0x7a')]);_0x515130[_0xede1('0x7b')]=intUtil['stripTrailingSlash'](_0x515130[_0xede1('0x7b')]);if(_0x1aa386&&_0x1aa386[_0xede1('0x8d')]&&_0x1aa386[_0xede1('0x8d')]!==_0xede1('0x8e')){logger[_0xede1('0x2c')](_0xede1('0x8f'),_0xede1('0x7e'));_0x27c13b[_0xede1('0x90')]=_0x515130[_0xede1('0x7b')]+_0xede1('0x7f')+_0x27c13b[_0xede1('0x80')]+_0xede1('0x81')+md5(_0x27c13b[_0xede1('0x80')]);}var _0x48557b=_0x515130[_0xede1('0x7a')]===_0xede1('0x82')?'eu':'com';return getAccessToken(_0x515130)[_0xede1('0x26')](function(_0x315e91){_0x525f18=_0x315e91;return getUser(_0x525f18,_0x48557b,_0x515130,_0x182cef['email']);})[_0xede1('0x26')](function(_0xd2b70a){_0x2fe981=_0xd2b70a;logger[_0xede1('0x2c')]('The\x20User\x20ID\x20is:',_0x2fe981['id']);return getEndUser(_0x525f18,_0x48557b,_0x515130,_0x27c13b[_0xede1('0x91')],_0x27c13b[_0xede1('0x92')],_0x2fe981,_0x1fd471);})[_0xede1('0x26')](function(_0x391d5a){_0x7aa36f=_0x391d5a;return getCall(_0x525f18,_0x48557b,_0x515130,_0x2fe981,_0x7aa36f,_0x1fd471,_0x27c13b,_0xede1('0x93'));})[_0xede1('0x26')](function(_0x106db7){if(_0x106db7){logger[_0xede1('0x2c')](_0xede1('0x86'),_0x106db7['id']);logger[_0xede1('0x2c')](_0xede1('0x8f'),_0xede1('0x87'));emit(util['format'](_0xede1('0x88'),_0x182cef[_0xede1('0x19')]),_0xede1('0x89'),{'uri':'https://crm.'+_0x515130[_0xede1('0x7a')]+_0xede1('0x8b')+_0x106db7['id']});}})[_0xede1('0x29')](function(_0x26b0ca){logger[_0xede1('0x3a')](_0xede1('0x8f'),JSON[_0xede1('0xe')](_0x26b0ca));});};exports[_0xede1('0x94')]=function(_0x19be12,_0x596fd4,_0x12ae86,_0x29b3e9,_0x18c4ec,_0xa2ef9a){var _0x12ea96,_0x1f8b57,_0x3db316;_0xa2ef9a[_0xede1('0x7a')]=intUtil['stripTrailingSlash'](_0xa2ef9a[_0xede1('0x7a')]);_0xa2ef9a[_0xede1('0x7b')]=intUtil[_0xede1('0x8c')](_0xa2ef9a['serverUrl']);if(_0x18c4ec&&_0x18c4ec[_0xede1('0x7c')]){logger[_0xede1('0x2c')]('['+_0x596fd4[_0xede1('0x95')][_0xede1('0x96')]()+']',_0xede1('0x7e'));_0x596fd4[_0xede1('0x90')]=_0xa2ef9a[_0xede1('0x7b')]+_0xede1('0x7f')+_0x596fd4[_0xede1('0x80')]+_0xede1('0x81')+md5(_0x596fd4['uniqueid']);}else{_0x596fd4[_0xede1('0x90')]='';}var _0x557c7d=_0xa2ef9a[_0xede1('0x7a')]==='zoho.eu'?'eu':_0xede1('0x83');return getAccessToken(_0xa2ef9a)[_0xede1('0x26')](function(_0x26b412){_0x3db316=_0x26b412;return getUser(_0x3db316,_0x557c7d,_0xa2ef9a);})[_0xede1('0x26')](function(_0x180778){_0x12ea96=_0x180778;logger[_0xede1('0x2c')](_0xede1('0x84'),_0x12ea96['id']);return getEndUser(_0x3db316,_0x557c7d,_0xa2ef9a,_0x596fd4[_0xede1('0x85')],_0x596fd4['calleridnum'],_0x12ea96,_0x12ae86);})['then'](function(_0xbf5729){_0x1f8b57=_0xbf5729;return getCall(_0x3db316,_0x557c7d,_0xa2ef9a,_0x12ea96,_0x1f8b57,_0x12ae86,_0x596fd4,'Inbound');})[_0xede1('0x26')](function(_0x54c0b3){if(_0x54c0b3){logger['info'](_0xede1('0x86'),_0x54c0b3['id']);}})[_0xede1('0x29')](function(_0x715e6f){logger['error']('['+_0x596fd4[_0xede1('0x95')][_0xede1('0x96')]()+']',JSON[_0xede1('0xe')](_0x715e6f));});};