44c4eec73905411e418a275d3798684397791804
[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 _0xa4ff=['Timeout','Call_Start_Time','Inbound','merge','Call\x20created!','err','host','serverUrl','stripTrailingSlash','[QUEUE]','Recording\x20is\x20enabled!','recordingURL','/api/voice/recordings/','uniqueid','/downloads?type=uniqueid&token=','com','email','The\x20User\x20ID\x20is:','calleridname','calleridnum','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=','outbound','recordingFormat','[OUTBOUND]','zoho.eu','destcalleridname','destcalleridnum','Outbound','unmanaged','monitor_format','toUpperCase','lodash','request-promise','util','moment','ioredis','bluebird','zoho','redis','localhost','socket.io-emitter','emit','stringify','forEach','includes','picklist','type','idField','content','toString','variable','variableName','customVariable','Variable','name','toLowerCase','isNil','access_token','zone','https://accounts.zoho.com','https://accounts.zoho.eu','https://accounts.zoho.in','https://accounts.zoho.com.cn','POST','/oauth/v2/token','refreshToken','clientId','clientSecret','refresh_token','add','seconds','Failing\x20creating\x20the\x20access_token','stack','GET','format','https://www.zohoapis.%s/crm/v2/users','ActiveUsers','then','isArrayLikeObject','findIndex','info','Agent\x20found!','Using\x20the\x20admin\x20account!','profile','Administrator','users','user','The\x20failing\x20result\x20is','error','catch','data','enduserType','https://www.zohoapis.','/crm/v2/','startCase','role','first_name','last_name','Zoho-oauthtoken\x20','code','SUCCESS','details','moduleCreate','Error:\x20','log','CREATE\x20ERROR','moduleSearch','contact_lead','uri','Contacts','/crm/v2/Leads/search?criteria=((Phone:equals:','nothing','contact','/crm/v2/Contacts/search?criteria=((Phone:equals:','Leads','Creating\x20new\x20call...','Owner','getString','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','talktime','utc','mm:ss','endtime','YYYY-MM-DDTHH:mm:ss','starttime','lastevent','called','Call_Result','Called','connect','Answered','rejected','Rejected','Abandoned'];(function(_0x2776c0,_0x3bdc05){var _0x42b7b7=function(_0x94d837){while(--_0x94d837){_0x2776c0['push'](_0x2776c0['shift']());}};_0x42b7b7(++_0x3bdc05);}(_0xa4ff,0xb5));var _0xfa4f=function(_0x175ca4,_0x3a74c4){_0x175ca4=_0x175ca4-0x0;var _0x8c846d=_0xa4ff[_0x175ca4];return _0x8c846d;};'use strict';var _=require(_0xfa4f('0x0'));var rp=require(_0xfa4f('0x1'));var md5=require('md5');var util=require(_0xfa4f('0x2'));var intUtil=require('./util');var moment=require(_0xfa4f('0x3'));var Redis=require(_0xfa4f('0x4'));var BPromise=require(_0xfa4f('0x5'));var config=require('../../../../config/environment');var logger=require('../../../../config/logger')(_0xfa4f('0x6'));config[_0xfa4f('0x7')]=_['defaults'](config[_0xfa4f('0x7')],{'host':_0xfa4f('0x8'),'port':0x18eb});var io=require(_0xfa4f('0x9'))(new Redis(config[_0xfa4f('0x7')]));function emit(_0x594a75,_0x7e9b4b,_0x54b318){io['to'](_0x594a75)[_0xfa4f('0xa')](_0x7e9b4b,_0x54b318);}function request(_0x36ea8a){logger['debug']('[HTTP]',JSON[_0xfa4f('0xb')](_0x36ea8a));return rp(_0x36ea8a);}function getCustomFields(_0x3512ed,_0x466aaf){var _0x56a5b5={};if(_0x3512ed['length']>0x0){_[_0xfa4f('0xc')](_0x3512ed,function(_0x327b02){if(_[_0xfa4f('0xd')](['string',_0xfa4f('0xe')],_0x327b02[_0xfa4f('0xf')])&&_0x327b02['idField']){_0x56a5b5[_0x327b02[_0xfa4f('0x10')]]=_0x327b02[_0xfa4f('0x11')][_0xfa4f('0x12')]();}else if(_0x327b02[_0xfa4f('0xf')]===_0xfa4f('0x13')&&_0x327b02[_0xfa4f('0x14')]&&_0x327b02[_0xfa4f('0x10')]&&_0x466aaf[_0x327b02['variableName']]){_0x56a5b5[_0x327b02[_0xfa4f('0x10')]]=_0x466aaf[_0x327b02[_0xfa4f('0x14')]][_0xfa4f('0x12')]();}else if(_0x327b02[_0xfa4f('0xf')]===_0xfa4f('0x15')&&_0x327b02[_0xfa4f('0x16')]&&_0x327b02['Variable'][_0xfa4f('0x17')]&&_0x327b02[_0xfa4f('0x10')]&&_0x466aaf[_0x327b02[_0xfa4f('0x16')][_0xfa4f('0x17')][_0xfa4f('0x18')]()]){_0x56a5b5[_0x327b02['idField']]=_0x466aaf[_0x327b02[_0xfa4f('0x16')][_0xfa4f('0x17')][_0xfa4f('0x18')]()]['toString']();}});}return _0x56a5b5;}function getName(_0x2d36e6){if(_0x2d36e6['indexOf']('\x20')>0x0){var _0x24f031=_0x2d36e6['split'](/ (.+)/);if(_0x24f031[0x1]){return _0x24f031;}}return[_0x2d36e6,_0x2d36e6];}var accountsTokens={};function getAccessToken(_0x516f5c){return new Promise(function(_0x430da9,_0x5d22f3){if(!_['isNil'](accountsTokens[_0x516f5c['id']])&&!_[_0xfa4f('0x19')](accountsTokens[_0x516f5c['id']][_0xfa4f('0x1a')])){if(moment()['isBefore'](accountsTokens[_0x516f5c['id']]['expires_in'])){_0x430da9(accountsTokens[_0x516f5c['id']][_0xfa4f('0x1a')]);}}var _0x4883e2;switch(_0x516f5c[_0xfa4f('0x1b')]){case'US':_0x4883e2=_0xfa4f('0x1c');break;case'AU':_0x4883e2='https://accounts.zoho.com.au';break;case'EU':_0x4883e2=_0xfa4f('0x1d');break;case'IN':_0x4883e2=_0xfa4f('0x1e');break;case'CN':_0x4883e2=_0xfa4f('0x1f');break;default:_0x4883e2=_0xfa4f('0x1d');break;}var _0x3e14a2={'method':_0xfa4f('0x20'),'uri':_0x4883e2+_0xfa4f('0x21'),'qs':{'refresh_token':_0x516f5c[_0xfa4f('0x22')],'client_id':_0x516f5c[_0xfa4f('0x23')],'client_secret':_0x516f5c[_0xfa4f('0x24')],'grant_type':_0xfa4f('0x25')},'json':!![]};return rp(_0x3e14a2)['then'](function(_0x27b191){accountsTokens[_0x516f5c['id']]={'access_token':_0x27b191[_0xfa4f('0x1a')],'expires_in':moment()[_0xfa4f('0x26')](_0x27b191['expires_in'],_0xfa4f('0x27'))};_0x430da9(_0x27b191['access_token']);})['catch'](function(_0x4103eb){logger['error'](_0xfa4f('0x28'),_0x4103eb[_0xfa4f('0x29')]);_0x5d22f3(_0x4103eb);});});}function getUser(_0x5d01fb,_0x1b27c5,_0x84db02,_0x17ce68){logger['info']('Search\x20user');return request({'method':_0xfa4f('0x2a'),'uri':util[_0xfa4f('0x2b')](_0xfa4f('0x2c'),_0x1b27c5),'qs':{'type':_0xfa4f('0x2d')},'headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x5d01fb},'json':!![]})[_0xfa4f('0x2e')](function(_0x9e60ee){if(_0x9e60ee['users']){var _0x52a7e1=-0x1;if(_[_0xfa4f('0x2f')](_0x9e60ee['users'])){if(!_[_0xfa4f('0x19')](_0x17ce68)){_0x52a7e1=_[_0xfa4f('0x30')](_0x9e60ee['users'],function(_0xadc033){return _0xadc033['email']===_0x17ce68;});}if(_0x52a7e1>=0x0){logger[_0xfa4f('0x31')](_0xfa4f('0x32'));}else{logger[_0xfa4f('0x31')](_0xfa4f('0x33'));_0x52a7e1=_[_0xfa4f('0x30')](_0x9e60ee['users'],function(_0xeeb6f3){return _0xeeb6f3[_0xfa4f('0x34')][_0xfa4f('0x17')]===_0xfa4f('0x35');});}return _0x9e60ee[_0xfa4f('0x36')][_0x52a7e1];}else{if(_0x9e60ee[_0xfa4f('0x37')]['profile'][_0xfa4f('0x17')]==='Administrator'){logger[_0xfa4f('0x31')](_0xfa4f('0x33'));user=_0x9e60ee[_0xfa4f('0x37')];return user;}else{logger['error'](_0xfa4f('0x38'),JSON[_0xfa4f('0xb')](_0x9e60ee));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON['stringify'](_0x9e60ee));}}}else{logger[_0xfa4f('0x39')](_0xfa4f('0x38'),JSON['stringify'](_0x9e60ee));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON[_0xfa4f('0xb')](_0x9e60ee));}})[_0xfa4f('0x3a')](function(_0x4ad1cb){console['error'](_0x4ad1cb);});}function getZohoUser(_0x18e1ce,_0x5a5a52){return new BPromise(function(_0x2e7e92,_0x3d67fa){request(_0x18e1ce)[_0xfa4f('0x2e')](function(_0x2f0695){var _0x12b767=null;if(_0x2f0695){_0x12b767=_0x2f0695[_0xfa4f('0x3b')][0x0];_0x12b767[_0xfa4f('0x3c')]=_0x5a5a52;}_0x2e7e92(_0x12b767);})['catch'](function(_0x1b8bd4){_0x3d67fa(_0x1b8bd4);});});}function createEndUser(_0x40ea0c,_0x57f46e,_0x202d8f,_0x4c47a3,_0x5eeb7d,_0xfbed9d){var _0x202d8f=getName(_0x202d8f);return request({'method':_0xfa4f('0x20'),'uri':_0xfa4f('0x3d')+_0x57f46e+_0xfa4f('0x3e')+_[_0xfa4f('0x3f')](_0xfbed9d['moduleCreate'])+'s','body':{'data':[{'Last_Name':_0x202d8f[0x1],'First_Name':_0x202d8f[0x0],'Phone':_0x4c47a3,'Owner':{'name':!_['isNil'](_0x5eeb7d[_0xfa4f('0x40')]['name'])?_0x5eeb7d[_0xfa4f('0x40')][_0xfa4f('0x17')]:!_[_0xfa4f('0x19')](_0x5eeb7d[_0xfa4f('0x41')])?_0x5eeb7d['first_name']+'\x20'+_0x5eeb7d[_0xfa4f('0x42')]:_0x5eeb7d['last_name'],'id':_0x5eeb7d['id']}}]},'headers':{'Authorization':_0xfa4f('0x43')+_0x40ea0c},'json':!![]})['then'](function(_0xfaa94f){if(_0xfaa94f&&_0xfaa94f['data'][0x0][_0xfa4f('0x44')]===_0xfa4f('0x45')){var _0x78b814=_0xfaa94f[_0xfa4f('0x3b')][0x0][_0xfa4f('0x46')];_0x78b814[_0xfa4f('0x3c')]=_['startCase'](_0xfbed9d[_0xfa4f('0x47')])+'s';return _0x78b814;}logger[_0xfa4f('0x39')](_0xfa4f('0x38'),JSON[_0xfa4f('0xb')](data));throw new Error(_0xfa4f('0x48')+JSON[_0xfa4f('0xb')](data));})[_0xfa4f('0x3a')](function(_0x208b04){console[_0xfa4f('0x49')](_0xfa4f('0x4a'),_0x208b04);});}function getEndUser(_0x46aba1,_0x4bae17,_0x4f54fc,_0x1dbc55,_0x48a9c9,_0x54961e,_0x4f0b63){var _0x4e6d7e={'method':_0xfa4f('0x2a'),'uri':'','headers':{'Authorization':_0xfa4f('0x43')+_0x46aba1},'json':!![]};switch(_0x4f0b63[_0xfa4f('0x4b')]){case _0xfa4f('0x4c'):_0x4e6d7e[_0xfa4f('0x4d')]=_0xfa4f('0x3d')+_0x4bae17+'/crm/v2/Contacts/search?criteria=((Phone:equals:'+_0x48a9c9+'))';return getZohoUser(_0x4e6d7e,_0xfa4f('0x4e'))[_0xfa4f('0x2e')](function(_0x518801){if(_0x518801)return _0x518801;_0x4e6d7e['uri']=_0xfa4f('0x3d')+_0x4bae17+_0xfa4f('0x4f')+_0x48a9c9+'))';return getZohoUser(_0x4e6d7e,'Leads')[_0xfa4f('0x2e')](function(_0x4579e3){if(_0x4579e3)return _0x4579e3;if(_0x4f0b63['moduleCreate']!=_0xfa4f('0x50')){return createEndUser(_0x46aba1,_0x4bae17,_0x1dbc55,_0x48a9c9,_0x54961e,_0x4f0b63);}else{return{};}});});break;case _0xfa4f('0x51'):_0x4e6d7e[_0xfa4f('0x4d')]=_0xfa4f('0x3d')+_0x4bae17+_0xfa4f('0x52')+_0x48a9c9+'))';return getZohoUser(_0x4e6d7e,_0xfa4f('0x4e'))[_0xfa4f('0x2e')](function(_0x1828dd){if(_0x1828dd)return _0x1828dd;if(_0x4f0b63['moduleCreate']!=_0xfa4f('0x50')){return createEndUser(_0x46aba1,_0x4bae17,_0x1dbc55,_0x48a9c9,_0x54961e,_0x4f0b63);}else{return{};}});break;case'lead':_0x4e6d7e['uri']=_0xfa4f('0x3d')+_0x4bae17+_0xfa4f('0x4f')+_0x48a9c9+'))';return getZohoUser(_0x4e6d7e,_0xfa4f('0x53'))[_0xfa4f('0x2e')](function(_0x1640af){if(_0x1640af)return _0x1640af;if(_0x4f0b63['moduleCreate']!=_0xfa4f('0x50')){return createEndUser(_0x46aba1,_0x4bae17,_0x1dbc55,_0x48a9c9,_0x54961e,_0x4f0b63);}else{return{};}});break;}}function getCall(_0x38ea71,_0x1af838,_0x5df6d9,_0x4d509f,_0x10b11b,_0x20c23c,_0x28aa37,_0x524280){logger[_0xfa4f('0x31')](_0xfa4f('0x54'));var _0x20523a={};_0x20523a[_0xfa4f('0x55')]={'name':!_[_0xfa4f('0x19')](_0x4d509f[_0xfa4f('0x40')][_0xfa4f('0x17')])&&!_['isNil'](_0x4d509f['profile'][_0xfa4f('0x17')])&&_0x4d509f[_0xfa4f('0x34')][_0xfa4f('0x17')]==='administrator'?_0x4d509f[_0xfa4f('0x40')][_0xfa4f('0x17')]:!_[_0xfa4f('0x19')](_0x4d509f['first_name'])?_0x4d509f[_0xfa4f('0x41')]+'\x20'+_0x4d509f[_0xfa4f('0x42')]:_0x4d509f[_0xfa4f('0x42')],'id':_0x4d509f['id']};_0x20523a['Subject']=intUtil['getString'](_0x20c23c['Subjects'],_0x28aa37,'\x20');_0x20523a['Description']=intUtil[_0xfa4f('0x56')](_0x20c23c[_0xfa4f('0x57')],_0x28aa37,'\x0a');if(_0x10b11b['enduserType']==='Contacts'){_0x20523a[_0xfa4f('0x58')]={'name':!_[_0xfa4f('0x19')](_0x10b11b[_0xfa4f('0x59')])?_0x10b11b[_0xfa4f('0x59')]:!_[_0xfa4f('0x19')](_0x10b11b[_0xfa4f('0x5a')])?_0x10b11b[_0xfa4f('0x5a')]+'\x20'+_0x10b11b[_0xfa4f('0x5b')]:_0x10b11b['Last_Name'],'id':_0x10b11b['id']};}if(_0x10b11b[_0xfa4f('0x3c')]===_0xfa4f('0x53')){_0x20523a[_0xfa4f('0x5c')]={'name':!_['isNil'](_0x10b11b['Full_Name'])?_0x10b11b['Full_Name']:!_['isNil'](_0x10b11b[_0xfa4f('0x5a')])?_0x10b11b['First_Name']+'\x20'+_0x10b11b[_0xfa4f('0x5b')]:_0x10b11b[_0xfa4f('0x5b')],'id':_0x10b11b['id']};_0x20523a[_0xfa4f('0x5d')]=_[_0xfa4f('0x3f')](_0x10b11b[_0xfa4f('0x3c')]);}if(_0x28aa37[_0xfa4f('0x5e')]){_0x20523a['Call_Duration']=moment[_0xfa4f('0x5f')](parseInt(_0x28aa37[_0xfa4f('0x5e')])*0x3e8)[_0xfa4f('0x2b')](_0xfa4f('0x60'));}else if(_0x28aa37['answertime']&&_0x28aa37['endtime']){_0x20523a['Call_Duration']=moment['utc'](moment(_0x28aa37[_0xfa4f('0x61')],_0xfa4f('0x62'))['diff'](moment(_0x28aa37[_0xfa4f('0x63')],_0xfa4f('0x62'))))['format']('mm:ss');}switch(_0x28aa37[_0xfa4f('0x64')]){case _0xfa4f('0x65'):_0x20523a[_0xfa4f('0x66')]=_0xfa4f('0x67');break;case'complete':case _0xfa4f('0x68'):_0x20523a[_0xfa4f('0x66')]=_0xfa4f('0x69');break;case _0xfa4f('0x6a'):_0x20523a[_0xfa4f('0x66')]=_0xfa4f('0x6b');break;case'abandoned':_0x20523a['Call_Result']=_0xfa4f('0x6c');break;case'timeout':_0x20523a[_0xfa4f('0x66')]=_0xfa4f('0x6d');default:}_0x20523a[_0xfa4f('0x6e')]=(_0x524280==='outbound'?moment(_0x28aa37[_0xfa4f('0x63')])[_0xfa4f('0x2b')]('YYYY-MM-DDTHH:mm:ss'):moment(_0x28aa37['agentcalledAt'])[_0xfa4f('0x2b')](_0xfa4f('0x62')))||moment()[_0xfa4f('0x2b')](_0xfa4f('0x62'));_0x20523a['Call_Type']=_0x524280||_0xfa4f('0x6f');_0x20523a=_[_0xfa4f('0x70')](_0x20523a,getCustomFields(_0x20c23c['Fields'],_0x28aa37));return request({'method':_0xfa4f('0x20'),'uri':_0xfa4f('0x3d')+_0x1af838+'/crm/v2/Calls','headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x38ea71},'body':{'data':[_0x20523a]},'json':!![]})['then'](function(_0x4bb7bd){if(_0x4bb7bd&&_0x4bb7bd[_0xfa4f('0x3b')][0x0][_0xfa4f('0x44')]===_0xfa4f('0x45')){logger[_0xfa4f('0x31')](_0xfa4f('0x71'));return{'id':_0x4bb7bd[_0xfa4f('0x3b')][0x0][_0xfa4f('0x46')]['id']};}})[_0xfa4f('0x3a')](function(_0xab4b4f){logger[_0xfa4f('0x31')](_0xfa4f('0x72'),_0xab4b4f[_0xfa4f('0x29')]);console[_0xfa4f('0x49')](_0xfa4f('0x72'),_0xab4b4f);});}exports['queue']=function(_0x5cd4b0,_0xebf2b5,_0x539203,_0x7c5f82,_0x5e1a1e,_0x3694fc){var _0x380df2,_0x1499dc,_0x423e29;_0x3694fc[_0xfa4f('0x73')]=intUtil['stripTrailingSlash'](_0x3694fc[_0xfa4f('0x73')]);_0x3694fc[_0xfa4f('0x74')]=intUtil[_0xfa4f('0x75')](_0x3694fc[_0xfa4f('0x74')]);if(_0x5e1a1e&&_0x5e1a1e['monitor_format']){logger[_0xfa4f('0x31')](_0xfa4f('0x76'),_0xfa4f('0x77'));_0xebf2b5[_0xfa4f('0x78')]=_0x3694fc[_0xfa4f('0x74')]+_0xfa4f('0x79')+_0xebf2b5[_0xfa4f('0x7a')]+_0xfa4f('0x7b')+md5(_0xebf2b5[_0xfa4f('0x7a')]);}else{_0xebf2b5[_0xfa4f('0x78')]='';}var _0x2fd14c=_0x3694fc[_0xfa4f('0x73')]==='zoho.eu'?'eu':_0xfa4f('0x7c');return getAccessToken(_0x3694fc)[_0xfa4f('0x2e')](function(_0x344c54){_0x423e29=_0x344c54;return getUser(_0x423e29,_0x2fd14c,_0x3694fc,_0x7c5f82[_0xfa4f('0x7d')]);})['then'](function(_0x593691){_0x380df2=_0x593691;logger[_0xfa4f('0x31')](_0xfa4f('0x7e'),_0x380df2['id']);return getEndUser(_0x423e29,_0x2fd14c,_0x3694fc,_0xebf2b5[_0xfa4f('0x7f')],_0xebf2b5[_0xfa4f('0x80')],_0x380df2,_0x539203);})[_0xfa4f('0x2e')](function(_0x53064a){_0x1499dc=_0x53064a;return getCall(_0x423e29,_0x2fd14c,_0x3694fc,_0x380df2,_0x1499dc,_0x539203,_0xebf2b5,'Inbound');})[_0xfa4f('0x2e')](function(_0x57f9b0){if(_0x57f9b0){logger[_0xfa4f('0x31')](_0xfa4f('0x81'),_0x57f9b0['id']);logger[_0xfa4f('0x31')](_0xfa4f('0x76'),_0xfa4f('0x82'));emit(util[_0xfa4f('0x2b')](_0xfa4f('0x83'),_0x7c5f82['name']),_0xfa4f('0x84'),{'uri':_0xfa4f('0x85')+_0x3694fc[_0xfa4f('0x73')]+_0xfa4f('0x86')+_0x57f9b0['id']});}})[_0xfa4f('0x3a')](function(_0x4280a4){logger[_0xfa4f('0x39')](_0xfa4f('0x76'),JSON[_0xfa4f('0xb')](_0x4280a4));});};exports[_0xfa4f('0x87')]=function(_0x2dc40d,_0x3601cf,_0x581114,_0x5c00bb,_0x36c9f9,_0x5d19ec,_0x3092d5){var _0x170690,_0x3eefe4,_0x30e685;_0x5d19ec[_0xfa4f('0x73')]=intUtil[_0xfa4f('0x75')](_0x5d19ec[_0xfa4f('0x73')]);_0x5d19ec['serverUrl']=intUtil[_0xfa4f('0x75')](_0x5d19ec[_0xfa4f('0x74')]);if(_0x3092d5&&_0x3092d5['recordingFormat']&&_0x3092d5[_0xfa4f('0x88')]!=='none'){logger['info'](_0xfa4f('0x89'),'Recording\x20is\x20enabled!');_0x3601cf[_0xfa4f('0x78')]=_0x5d19ec[_0xfa4f('0x74')]+_0xfa4f('0x79')+_0x3601cf['uniqueid']+_0xfa4f('0x7b')+md5(_0x3601cf['uniqueid']);}var _0x5717c3=_0x5d19ec[_0xfa4f('0x73')]===_0xfa4f('0x8a')?'eu':_0xfa4f('0x7c');return getAccessToken(_0x5d19ec)['then'](function(_0x465294){_0x30e685=_0x465294;return getUser(_0x30e685,_0x5717c3,_0x5d19ec,_0x5c00bb[_0xfa4f('0x7d')]);})[_0xfa4f('0x2e')](function(_0x2dabd7){_0x170690=_0x2dabd7;logger[_0xfa4f('0x31')](_0xfa4f('0x7e'),_0x170690['id']);return getEndUser(_0x30e685,_0x5717c3,_0x5d19ec,_0x3601cf[_0xfa4f('0x8b')],_0x3601cf[_0xfa4f('0x8c')],_0x170690,_0x581114);})['then'](function(_0x1d1367){_0x3eefe4=_0x1d1367;return getCall(_0x30e685,_0x5717c3,_0x5d19ec,_0x170690,_0x3eefe4,_0x581114,_0x3601cf,_0xfa4f('0x8d'));})['then'](function(_0xa619bc){if(_0xa619bc){logger[_0xfa4f('0x31')](_0xfa4f('0x81'),_0xa619bc['id']);logger['info'](_0xfa4f('0x89'),_0xfa4f('0x82'));emit(util[_0xfa4f('0x2b')]('user:%s',_0x5c00bb[_0xfa4f('0x17')]),_0xfa4f('0x84'),{'uri':'https://crm.'+_0x5d19ec[_0xfa4f('0x73')]+_0xfa4f('0x86')+_0xa619bc['id']});}})['catch'](function(_0x1abf71){logger['error'](_0xfa4f('0x89'),JSON[_0xfa4f('0xb')](_0x1abf71));});};exports[_0xfa4f('0x8e')]=function(_0x3fca32,_0x14bb35,_0x9e2fa4,_0x40b02e,_0x5586bf,_0x128149){var _0x3bfcf7,_0x398d96,_0x2a2b74;_0x128149['host']=intUtil[_0xfa4f('0x75')](_0x128149['host']);_0x128149['serverUrl']=intUtil['stripTrailingSlash'](_0x128149['serverUrl']);if(_0x5586bf&&_0x5586bf[_0xfa4f('0x8f')]){logger[_0xfa4f('0x31')]('['+_0x14bb35[_0xfa4f('0x64')][_0xfa4f('0x90')]()+']',_0xfa4f('0x77'));_0x14bb35[_0xfa4f('0x78')]=_0x128149[_0xfa4f('0x74')]+'/api/voice/recordings/'+_0x14bb35[_0xfa4f('0x7a')]+_0xfa4f('0x7b')+md5(_0x14bb35[_0xfa4f('0x7a')]);}else{_0x14bb35[_0xfa4f('0x78')]='';}var _0x26a638=_0x128149[_0xfa4f('0x73')]===_0xfa4f('0x8a')?'eu':_0xfa4f('0x7c');return getAccessToken(_0x128149)[_0xfa4f('0x2e')](function(_0x1d7e54){_0x2a2b74=_0x1d7e54;return getUser(_0x2a2b74,_0x26a638,_0x128149);})[_0xfa4f('0x2e')](function(_0x401d3c){_0x3bfcf7=_0x401d3c;logger[_0xfa4f('0x31')](_0xfa4f('0x7e'),_0x3bfcf7['id']);return getEndUser(_0x2a2b74,_0x26a638,_0x128149,_0x14bb35['calleridname'],_0x14bb35[_0xfa4f('0x80')],_0x3bfcf7,_0x9e2fa4);})[_0xfa4f('0x2e')](function(_0x5013f9){_0x398d96=_0x5013f9;return getCall(_0x2a2b74,_0x26a638,_0x128149,_0x3bfcf7,_0x398d96,_0x9e2fa4,_0x14bb35,_0xfa4f('0x6f'));})[_0xfa4f('0x2e')](function(_0xe22ae3){if(_0xe22ae3){logger[_0xfa4f('0x31')](_0xfa4f('0x81'),_0xe22ae3['id']);}})[_0xfa4f('0x3a')](function(_0x2dd70a){logger[_0xfa4f('0x39')]('['+_0x14bb35[_0xfa4f('0x64')][_0xfa4f('0x90')]()+']',JSON[_0xfa4f('0xb')](_0x2dd70a));});};