3dd5c03e59c8f70245ad9a0de2151d08f9704b95
[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 _0xe48f=['https://crm.','toUpperCase','The\x20Call\x20ID\x20is:','lodash','request-promise','md5','util','moment','ioredis','bluebird','../../../../config/environment','../../../../config/logger','zoho','defaults','localhost','redis','emit','debug','includes','picklist','type','idField','content','toString','variableName','customVariable','Variable','name','toLowerCase','indexOf','split','isNil','isBefore','expires_in','access_token','https://accounts.zoho.com','https://accounts.zoho.com.au','https://accounts.zoho.eu','https://accounts.zoho.in','POST','refreshToken','clientId','clientSecret','refresh_token','then','add','catch','info','Search\x20user','GET','format','https://www.zohoapis.%s/crm/v2/users','ActiveUsers','Zoho-oauthtoken\x20','users','isArrayLikeObject','findIndex','email','Agent\x20found!','Using\x20the\x20admin\x20account!','profile','user','Administrator','error','The\x20failing\x20result\x20is','stringify','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','data','enduserType','startCase','moduleCreate','role','first_name','code','SUCCESS','details','Error:\x20','log','CREATE\x20ERROR','moduleSearch','contact_lead','uri','/crm/v2/Contacts/search?criteria=((Phone:equals:','Contacts','https://www.zohoapis.','/crm/v2/Leads/search?criteria=((Phone:equals:','Leads','contact','nothing','lead','Creating\x20new\x20call...','administrator','Subject','getString','Subjects','Description','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','talktime','utc','endtime','Call_Duration','YYYY-MM-DDTHH:mm:ss','diff','starttime','mm:ss','lastevent','called','Call_Result','Called','complete','connect','Answered','rejected','abandoned','timeout','Call_Start_Time','outbound','agentcalledAt','Call_Type','merge','Fields','/crm/v2/Calls','stack','err','host','stripTrailingSlash','serverUrl','monitor_format','[QUEUE]','Recording\x20is\x20enabled!','uniqueid','/downloads?type=uniqueid&token=','recordingURL','zoho.eu','com','The\x20User\x20ID\x20is:','calleridname','calleridnum','Inbound','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','user:%s','trigger:browser:url','/crm/EntityInfo.do?module=Calls&id=','none','destcalleridname','destcalleridnum','Outbound'];(function(_0x1afabf,_0x56fdcc){var _0x497ff1=function(_0x2f6104){while(--_0x2f6104){_0x1afabf['push'](_0x1afabf['shift']());}};_0x497ff1(++_0x56fdcc);}(_0xe48f,0x9c));var _0xfe48=function(_0x4abab9,_0xde21a4){_0x4abab9=_0x4abab9-0x0;var _0x374eba=_0xe48f[_0x4abab9];return _0x374eba;};'use strict';var _=require(_0xfe48('0x0'));var rp=require(_0xfe48('0x1'));var md5=require(_0xfe48('0x2'));var util=require(_0xfe48('0x3'));var intUtil=require('./util');var moment=require(_0xfe48('0x4'));var Redis=require(_0xfe48('0x5'));var BPromise=require(_0xfe48('0x6'));var config=require(_0xfe48('0x7'));var logger=require(_0xfe48('0x8'))(_0xfe48('0x9'));config['redis']=_[_0xfe48('0xa')](config['redis'],{'host':_0xfe48('0xb'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0xfe48('0xc')]));function emit(_0x4b6f9b,_0x367d87,_0x3c60fa){io['to'](_0x4b6f9b)[_0xfe48('0xd')](_0x367d87,_0x3c60fa);}function request(_0x498eac){logger[_0xfe48('0xe')]('[HTTP]',JSON['stringify'](_0x498eac));return rp(_0x498eac);}function getCustomFields(_0x26933d,_0x53d625){var _0x33e0fe={};if(_0x26933d['length']>0x0){_['forEach'](_0x26933d,function(_0x3183f3){if(_[_0xfe48('0xf')](['string',_0xfe48('0x10')],_0x3183f3[_0xfe48('0x11')])&&_0x3183f3[_0xfe48('0x12')]){_0x33e0fe[_0x3183f3[_0xfe48('0x12')]]=_0x3183f3[_0xfe48('0x13')][_0xfe48('0x14')]();}else if(_0x3183f3[_0xfe48('0x11')]==='variable'&&_0x3183f3[_0xfe48('0x15')]&&_0x3183f3[_0xfe48('0x12')]&&_0x53d625[_0x3183f3[_0xfe48('0x15')]]){_0x33e0fe[_0x3183f3[_0xfe48('0x12')]]=_0x53d625[_0x3183f3['variableName']][_0xfe48('0x14')]();}else if(_0x3183f3[_0xfe48('0x11')]===_0xfe48('0x16')&&_0x3183f3[_0xfe48('0x17')]&&_0x3183f3[_0xfe48('0x17')][_0xfe48('0x18')]&&_0x3183f3[_0xfe48('0x12')]&&_0x53d625[_0x3183f3[_0xfe48('0x17')][_0xfe48('0x18')][_0xfe48('0x19')]()]){_0x33e0fe[_0x3183f3[_0xfe48('0x12')]]=_0x53d625[_0x3183f3[_0xfe48('0x17')][_0xfe48('0x18')][_0xfe48('0x19')]()]['toString']();}});}return _0x33e0fe;}function getName(_0x538190){if(_0x538190[_0xfe48('0x1a')]('\x20')>0x0){var _0x1f247b=_0x538190[_0xfe48('0x1b')](/ (.+)/);if(_0x1f247b[0x1]){return _0x1f247b;}}return[_0x538190,_0x538190];}var accountsTokens={};function getAccessToken(_0x23019e){return new Promise(function(_0x74b23a,_0x2dd606){if(!_[_0xfe48('0x1c')](accountsTokens[_0x23019e['id']])&&!_[_0xfe48('0x1c')](accountsTokens[_0x23019e['id']]['access_token'])){if(moment()[_0xfe48('0x1d')](accountsTokens[_0x23019e['id']][_0xfe48('0x1e')])){_0x74b23a(accountsTokens[_0x23019e['id']][_0xfe48('0x1f')]);}}var _0x464f46;switch(_0x23019e['zone']){case'US':_0x464f46=_0xfe48('0x20');break;case'AU':_0x464f46=_0xfe48('0x21');break;case'EU':_0x464f46=_0xfe48('0x22');break;case'IN':_0x464f46=_0xfe48('0x23');break;case'CN':_0x464f46='https://accounts.zoho.com.cn';break;default:_0x464f46=_0xfe48('0x22');break;}var _0x26b2d7={'method':_0xfe48('0x24'),'uri':_0x464f46+'/oauth/v2/token','qs':{'refresh_token':_0x23019e[_0xfe48('0x25')],'client_id':_0x23019e[_0xfe48('0x26')],'client_secret':_0x23019e[_0xfe48('0x27')],'grant_type':_0xfe48('0x28')},'json':!![]};return rp(_0x26b2d7)[_0xfe48('0x29')](function(_0x5e0010){accountsTokens[_0x23019e['id']]={'access_token':_0x5e0010[_0xfe48('0x1f')],'expires_in':moment()[_0xfe48('0x2a')](_0x5e0010[_0xfe48('0x1e')],'seconds')};_0x74b23a(_0x5e0010[_0xfe48('0x1f')]);})[_0xfe48('0x2b')](function(_0x583a29){logger['error']('Failing\x20creating\x20the\x20access_token',_0x583a29['stack']);_0x2dd606(_0x583a29);});});}function getUser(_0x4bcd09,_0xd113a4,_0x4c8f3c,_0x86a8ba){logger[_0xfe48('0x2c')](_0xfe48('0x2d'));return request({'method':_0xfe48('0x2e'),'uri':util[_0xfe48('0x2f')](_0xfe48('0x30'),_0xd113a4),'qs':{'type':_0xfe48('0x31')},'headers':{'Authorization':_0xfe48('0x32')+_0x4bcd09},'json':!![]})['then'](function(_0x7ffff2){if(_0x7ffff2[_0xfe48('0x33')]){var _0x817572=-0x1;if(_[_0xfe48('0x34')](_0x7ffff2[_0xfe48('0x33')])){if(!_[_0xfe48('0x1c')](_0x86a8ba)){_0x817572=_[_0xfe48('0x35')](_0x7ffff2['users'],function(_0x21898d){return _0x21898d[_0xfe48('0x36')]===_0x86a8ba;});}if(_0x817572>=0x0){logger['info'](_0xfe48('0x37'));}else{logger[_0xfe48('0x2c')](_0xfe48('0x38'));_0x817572=_[_0xfe48('0x35')](_0x7ffff2[_0xfe48('0x33')],function(_0x15548b){return _0x15548b[_0xfe48('0x39')][_0xfe48('0x18')]==='Administrator';});}return _0x7ffff2['users'][_0x817572];}else{if(_0x7ffff2[_0xfe48('0x3a')][_0xfe48('0x39')][_0xfe48('0x18')]===_0xfe48('0x3b')){logger['info'](_0xfe48('0x38'));user=_0x7ffff2['user'];return user;}else{logger[_0xfe48('0x3c')](_0xfe48('0x3d'),JSON[_0xfe48('0x3e')](_0x7ffff2));throw new Error(_0xfe48('0x3f')+JSON['stringify'](_0x7ffff2));}}}else{logger[_0xfe48('0x3c')](_0xfe48('0x3d'),JSON[_0xfe48('0x3e')](_0x7ffff2));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON['stringify'](_0x7ffff2));}})[_0xfe48('0x2b')](function(_0x285009){console[_0xfe48('0x3c')](_0x285009);});}function getZohoUser(_0x3a593b,_0x203952){return new BPromise(function(_0xff5548,_0x3354b2){request(_0x3a593b)[_0xfe48('0x29')](function(_0x23eae7){var _0x3e661a=null;if(_0x23eae7){_0x3e661a=_0x23eae7[_0xfe48('0x40')][0x0];_0x3e661a[_0xfe48('0x41')]=_0x203952;}_0xff5548(_0x3e661a);})[_0xfe48('0x2b')](function(_0x165064){_0x3354b2(_0x165064);});});}function createEndUser(_0x4a4b41,_0x50aef6,_0xbc6c02,_0x31b6e7,_0x1fbd4a,_0x1dc053){var _0xbc6c02=getName(_0xbc6c02);return request({'method':_0xfe48('0x24'),'uri':'https://www.zohoapis.'+_0x50aef6+'/crm/v2/'+_[_0xfe48('0x42')](_0x1dc053[_0xfe48('0x43')])+'s','body':{'data':[{'Last_Name':_0xbc6c02[0x1],'First_Name':_0xbc6c02[0x0],'Phone':_0x31b6e7,'Owner':{'name':!_[_0xfe48('0x1c')](_0x1fbd4a['role'][_0xfe48('0x18')])?_0x1fbd4a[_0xfe48('0x44')][_0xfe48('0x18')]:!_[_0xfe48('0x1c')](_0x1fbd4a[_0xfe48('0x45')])?_0x1fbd4a['first_name']+'\x20'+_0x1fbd4a['last_name']:_0x1fbd4a['last_name'],'id':_0x1fbd4a['id']}}]},'headers':{'Authorization':_0xfe48('0x32')+_0x4a4b41},'json':!![]})[_0xfe48('0x29')](function(_0x27f33b){if(_0x27f33b&&_0x27f33b[_0xfe48('0x40')][0x0][_0xfe48('0x46')]===_0xfe48('0x47')){var _0x218efa=_0x27f33b[_0xfe48('0x40')][0x0][_0xfe48('0x48')];_0x218efa[_0xfe48('0x41')]=_[_0xfe48('0x42')](_0x1dc053[_0xfe48('0x43')])+'s';return _0x218efa;}logger['error'](_0xfe48('0x3d'),JSON[_0xfe48('0x3e')](data));throw new Error(_0xfe48('0x49')+JSON[_0xfe48('0x3e')](data));})[_0xfe48('0x2b')](function(_0x2f51a7){console[_0xfe48('0x4a')](_0xfe48('0x4b'),_0x2f51a7);});}function getEndUser(_0x194c8b,_0x3bcb0e,_0x10abec,_0xc1ab60,_0x1a0b8f,_0x3c2087,_0x89f7e0){var _0x367e7c={'method':_0xfe48('0x2e'),'uri':'','headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x194c8b},'json':!![]};switch(_0x89f7e0[_0xfe48('0x4c')]){case _0xfe48('0x4d'):_0x367e7c[_0xfe48('0x4e')]='https://www.zohoapis.'+_0x3bcb0e+_0xfe48('0x4f')+_0x1a0b8f+'))';return getZohoUser(_0x367e7c,_0xfe48('0x50'))[_0xfe48('0x29')](function(_0x12931e){if(_0x12931e)return _0x12931e;_0x367e7c[_0xfe48('0x4e')]=_0xfe48('0x51')+_0x3bcb0e+_0xfe48('0x52')+_0x1a0b8f+'))';return getZohoUser(_0x367e7c,_0xfe48('0x53'))[_0xfe48('0x29')](function(_0x32b562){if(_0x32b562)return _0x32b562;if(_0x89f7e0[_0xfe48('0x43')]!='nothing'){return createEndUser(_0x194c8b,_0x3bcb0e,_0xc1ab60,_0x1a0b8f,_0x3c2087,_0x89f7e0);}else{return{};}});});break;case _0xfe48('0x54'):_0x367e7c[_0xfe48('0x4e')]='https://www.zohoapis.'+_0x3bcb0e+_0xfe48('0x4f')+_0x1a0b8f+'))';return getZohoUser(_0x367e7c,_0xfe48('0x50'))['then'](function(_0x543abe){if(_0x543abe)return _0x543abe;if(_0x89f7e0['moduleCreate']!=_0xfe48('0x55')){return createEndUser(_0x194c8b,_0x3bcb0e,_0xc1ab60,_0x1a0b8f,_0x3c2087,_0x89f7e0);}else{return{};}});break;case _0xfe48('0x56'):_0x367e7c[_0xfe48('0x4e')]='https://www.zohoapis.'+_0x3bcb0e+'/crm/v2/Leads/search?criteria=((Phone:equals:'+_0x1a0b8f+'))';return getZohoUser(_0x367e7c,_0xfe48('0x53'))[_0xfe48('0x29')](function(_0x657258){if(_0x657258)return _0x657258;if(_0x89f7e0[_0xfe48('0x43')]!='nothing'){return createEndUser(_0x194c8b,_0x3bcb0e,_0xc1ab60,_0x1a0b8f,_0x3c2087,_0x89f7e0);}else{return{};}});break;}}function getCall(_0xef9245,_0x51ce4e,_0x5cc113,_0x5f2260,_0x3efd27,_0x1d4d6b,_0x448a2c,_0x34a72e){logger[_0xfe48('0x2c')](_0xfe48('0x57'));var _0x190208={};_0x190208['Owner']={'name':!_[_0xfe48('0x1c')](_0x5f2260[_0xfe48('0x44')][_0xfe48('0x18')])&&!_[_0xfe48('0x1c')](_0x5f2260[_0xfe48('0x39')][_0xfe48('0x18')])&&_0x5f2260[_0xfe48('0x39')][_0xfe48('0x18')]===_0xfe48('0x58')?_0x5f2260[_0xfe48('0x44')][_0xfe48('0x18')]:!_[_0xfe48('0x1c')](_0x5f2260[_0xfe48('0x45')])?_0x5f2260['first_name']+'\x20'+_0x5f2260['last_name']:_0x5f2260['last_name'],'id':_0x5f2260['id']};_0x190208[_0xfe48('0x59')]=intUtil[_0xfe48('0x5a')](_0x1d4d6b[_0xfe48('0x5b')],_0x448a2c,'\x20');_0x190208[_0xfe48('0x5c')]=intUtil[_0xfe48('0x5a')](_0x1d4d6b[_0xfe48('0x5d')],_0x448a2c,'\x0a');if(_0x3efd27['enduserType']===_0xfe48('0x50')){_0x190208[_0xfe48('0x5e')]={'name':!_[_0xfe48('0x1c')](_0x3efd27[_0xfe48('0x5f')])?_0x3efd27['Full_Name']:!_[_0xfe48('0x1c')](_0x3efd27['First_Name'])?_0x3efd27[_0xfe48('0x60')]+'\x20'+_0x3efd27[_0xfe48('0x61')]:_0x3efd27[_0xfe48('0x61')],'id':_0x3efd27['id']};}if(_0x3efd27['enduserType']===_0xfe48('0x53')){_0x190208[_0xfe48('0x62')]={'name':!_['isNil'](_0x3efd27[_0xfe48('0x5f')])?_0x3efd27[_0xfe48('0x5f')]:!_['isNil'](_0x3efd27[_0xfe48('0x60')])?_0x3efd27['First_Name']+'\x20'+_0x3efd27[_0xfe48('0x61')]:_0x3efd27[_0xfe48('0x61')],'id':_0x3efd27['id']};_0x190208[_0xfe48('0x63')]=_[_0xfe48('0x42')](_0x3efd27[_0xfe48('0x41')]);}if(_0x448a2c[_0xfe48('0x64')]){_0x190208['Call_Duration']=moment[_0xfe48('0x65')](parseInt(_0x448a2c[_0xfe48('0x64')])*0x3e8)[_0xfe48('0x2f')]('mm:ss');}else if(_0x448a2c['answertime']&&_0x448a2c[_0xfe48('0x66')]){_0x190208[_0xfe48('0x67')]=moment['utc'](moment(_0x448a2c[_0xfe48('0x66')],_0xfe48('0x68'))[_0xfe48('0x69')](moment(_0x448a2c[_0xfe48('0x6a')],_0xfe48('0x68'))))[_0xfe48('0x2f')](_0xfe48('0x6b'));}switch(_0x448a2c[_0xfe48('0x6c')]){case _0xfe48('0x6d'):_0x190208[_0xfe48('0x6e')]=_0xfe48('0x6f');break;case _0xfe48('0x70'):case _0xfe48('0x71'):_0x190208['Call_Result']=_0xfe48('0x72');break;case _0xfe48('0x73'):_0x190208['Call_Result']='Rejected';break;case _0xfe48('0x74'):_0x190208[_0xfe48('0x6e')]='Abandoned';break;case _0xfe48('0x75'):_0x190208[_0xfe48('0x6e')]='Timeout';default:}_0x190208[_0xfe48('0x76')]=(_0x34a72e===_0xfe48('0x77')?moment(_0x448a2c[_0xfe48('0x6a')])[_0xfe48('0x2f')](_0xfe48('0x68')):moment(_0x448a2c[_0xfe48('0x78')])['format'](_0xfe48('0x68')))||moment()[_0xfe48('0x2f')](_0xfe48('0x68'));_0x190208[_0xfe48('0x79')]=_0x34a72e||'Inbound';_0x190208=_[_0xfe48('0x7a')](_0x190208,getCustomFields(_0x1d4d6b[_0xfe48('0x7b')],_0x448a2c));return request({'method':_0xfe48('0x24'),'uri':_0xfe48('0x51')+_0x51ce4e+_0xfe48('0x7c'),'headers':{'Authorization':'Zoho-oauthtoken\x20'+_0xef9245},'body':{'data':[_0x190208]},'json':!![]})['then'](function(_0x317264){if(_0x317264&&_0x317264[_0xfe48('0x40')][0x0][_0xfe48('0x46')]===_0xfe48('0x47')){logger[_0xfe48('0x2c')]('Call\x20created!');return{'id':_0x317264['data'][0x0][_0xfe48('0x48')]['id']};}})[_0xfe48('0x2b')](function(_0x146fe6){logger[_0xfe48('0x2c')]('err',_0x146fe6[_0xfe48('0x7d')]);console[_0xfe48('0x4a')](_0xfe48('0x7e'),_0x146fe6);});}exports['queue']=function(_0x2a9fab,_0x4f1a29,_0x480603,_0x9f9953,_0x4b5a72,_0x4e4a2f){var _0x199828,_0x3a9129,_0x387654;_0x4e4a2f[_0xfe48('0x7f')]=intUtil[_0xfe48('0x80')](_0x4e4a2f[_0xfe48('0x7f')]);_0x4e4a2f[_0xfe48('0x81')]=intUtil[_0xfe48('0x80')](_0x4e4a2f[_0xfe48('0x81')]);if(_0x4b5a72&&_0x4b5a72[_0xfe48('0x82')]){logger[_0xfe48('0x2c')](_0xfe48('0x83'),_0xfe48('0x84'));_0x4f1a29['recordingURL']=_0x4e4a2f[_0xfe48('0x81')]+'/api/voice/recordings/'+_0x4f1a29[_0xfe48('0x85')]+_0xfe48('0x86')+md5(_0x4f1a29[_0xfe48('0x85')]);}else{_0x4f1a29[_0xfe48('0x87')]='';}var _0x409af9=_0x4e4a2f[_0xfe48('0x7f')]===_0xfe48('0x88')?'eu':_0xfe48('0x89');return getAccessToken(_0x4e4a2f)[_0xfe48('0x29')](function(_0x3532e8){_0x387654=_0x3532e8;return getUser(_0x387654,_0x409af9,_0x4e4a2f,_0x9f9953['email']);})[_0xfe48('0x29')](function(_0x3b8957){_0x199828=_0x3b8957;logger[_0xfe48('0x2c')](_0xfe48('0x8a'),_0x199828['id']);return getEndUser(_0x387654,_0x409af9,_0x4e4a2f,_0x4f1a29[_0xfe48('0x8b')],_0x4f1a29[_0xfe48('0x8c')],_0x199828,_0x480603);})[_0xfe48('0x29')](function(_0x58e362){_0x3a9129=_0x58e362;return getCall(_0x387654,_0x409af9,_0x4e4a2f,_0x199828,_0x3a9129,_0x480603,_0x4f1a29,_0xfe48('0x8d'));})['then'](function(_0x5bfa70){if(_0x5bfa70){logger[_0xfe48('0x2c')]('The\x20Call\x20ID\x20is:',_0x5bfa70['id']);logger[_0xfe48('0x2c')]('[QUEUE]',_0xfe48('0x8e'));emit(util[_0xfe48('0x2f')](_0xfe48('0x8f'),_0x9f9953[_0xfe48('0x18')]),_0xfe48('0x90'),{'uri':'https://crm.'+_0x4e4a2f['host']+_0xfe48('0x91')+_0x5bfa70['id']});}})[_0xfe48('0x2b')](function(_0x560338){logger['error']('[QUEUE]',JSON['stringify'](_0x560338));});};exports[_0xfe48('0x77')]=function(_0x1310e2,_0x3d0cbe,_0x19608c,_0x591645,_0xeb0707,_0x15ae46,_0x5da8f5){var _0x39e9af,_0x464ed0,_0xd5ae42;_0x15ae46[_0xfe48('0x7f')]=intUtil['stripTrailingSlash'](_0x15ae46['host']);_0x15ae46[_0xfe48('0x81')]=intUtil[_0xfe48('0x80')](_0x15ae46['serverUrl']);if(_0x5da8f5&&_0x5da8f5['recordingFormat']&&_0x5da8f5['recordingFormat']!==_0xfe48('0x92')){logger[_0xfe48('0x2c')]('[OUTBOUND]',_0xfe48('0x84'));_0x3d0cbe['recordingURL']=_0x15ae46['serverUrl']+'/api/voice/recordings/'+_0x3d0cbe[_0xfe48('0x85')]+'/downloads?type=uniqueid&token='+md5(_0x3d0cbe[_0xfe48('0x85')]);}var _0x7ce72b=_0x15ae46['host']===_0xfe48('0x88')?'eu':'com';return getAccessToken(_0x15ae46)[_0xfe48('0x29')](function(_0x1c729f){_0xd5ae42=_0x1c729f;return getUser(_0xd5ae42,_0x7ce72b,_0x15ae46,_0x591645['email']);})['then'](function(_0x1138de){_0x39e9af=_0x1138de;logger['info'](_0xfe48('0x8a'),_0x39e9af['id']);return getEndUser(_0xd5ae42,_0x7ce72b,_0x15ae46,_0x3d0cbe[_0xfe48('0x93')],_0x3d0cbe[_0xfe48('0x94')],_0x39e9af,_0x19608c);})[_0xfe48('0x29')](function(_0x55115b){_0x464ed0=_0x55115b;return getCall(_0xd5ae42,_0x7ce72b,_0x15ae46,_0x39e9af,_0x464ed0,_0x19608c,_0x3d0cbe,_0xfe48('0x95'));})[_0xfe48('0x29')](function(_0x3c01c5){if(_0x3c01c5){logger['info']('The\x20Call\x20ID\x20is:',_0x3c01c5['id']);logger[_0xfe48('0x2c')]('[OUTBOUND]',_0xfe48('0x8e'));emit(util[_0xfe48('0x2f')](_0xfe48('0x8f'),_0x591645[_0xfe48('0x18')]),_0xfe48('0x90'),{'uri':_0xfe48('0x96')+_0x15ae46[_0xfe48('0x7f')]+_0xfe48('0x91')+_0x3c01c5['id']});}})[_0xfe48('0x2b')](function(_0x1fcc1b){logger[_0xfe48('0x3c')]('[OUTBOUND]',JSON[_0xfe48('0x3e')](_0x1fcc1b));});};exports['unmanaged']=function(_0x1cad0c,_0x5714f8,_0x50009e,_0x19a1f6,_0x374987,_0x1fa52e){var _0x5c90a6,_0x3f40e6,_0x26291f;_0x1fa52e['host']=intUtil[_0xfe48('0x80')](_0x1fa52e[_0xfe48('0x7f')]);_0x1fa52e[_0xfe48('0x81')]=intUtil[_0xfe48('0x80')](_0x1fa52e[_0xfe48('0x81')]);if(_0x374987&&_0x374987[_0xfe48('0x82')]){logger[_0xfe48('0x2c')]('['+_0x5714f8[_0xfe48('0x6c')][_0xfe48('0x97')]()+']',_0xfe48('0x84'));_0x5714f8[_0xfe48('0x87')]=_0x1fa52e[_0xfe48('0x81')]+'/api/voice/recordings/'+_0x5714f8['uniqueid']+_0xfe48('0x86')+md5(_0x5714f8[_0xfe48('0x85')]);}else{_0x5714f8[_0xfe48('0x87')]='';}var _0x475770=_0x1fa52e[_0xfe48('0x7f')]===_0xfe48('0x88')?'eu':'com';return getAccessToken(_0x1fa52e)[_0xfe48('0x29')](function(_0x2baa85){_0x26291f=_0x2baa85;return getUser(_0x26291f,_0x475770,_0x1fa52e);})[_0xfe48('0x29')](function(_0x2f5bb3){_0x5c90a6=_0x2f5bb3;logger[_0xfe48('0x2c')](_0xfe48('0x8a'),_0x5c90a6['id']);return getEndUser(_0x26291f,_0x475770,_0x1fa52e,_0x5714f8[_0xfe48('0x8b')],_0x5714f8[_0xfe48('0x8c')],_0x5c90a6,_0x50009e);})[_0xfe48('0x29')](function(_0x2a1c64){_0x3f40e6=_0x2a1c64;return getCall(_0x26291f,_0x475770,_0x1fa52e,_0x5c90a6,_0x3f40e6,_0x50009e,_0x5714f8,_0xfe48('0x8d'));})[_0xfe48('0x29')](function(_0x30920f){if(_0x30920f){logger[_0xfe48('0x2c')](_0xfe48('0x98'),_0x30920f['id']);}})[_0xfe48('0x2b')](function(_0xf8ba06){logger[_0xfe48('0x3c')]('['+_0x5714f8['lastevent'][_0xfe48('0x97')]()+']',JSON[_0xfe48('0x3e')](_0xf8ba06));});};