f9ba414e52af76e05cf82f10b2ceb3db8c591cc2
[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 _0xa101=['diff','starttime','lastevent','called','Call_Result','connect','Answered','rejected','Rejected','abandoned','Abandoned','timeout','Timeout','outbound','Call_Type','Inbound','/crm/v2/Calls','SUCCESS','Call\x20created!','err','host','stripTrailingSlash','serverUrl','[QUEUE]','Recording\x20is\x20enabled!','recordingURL','uniqueid','com','The\x20User\x20ID\x20is:','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','user:%s','trigger:browser:url','none','[OUTBOUND]','/api/voice/recordings/','/downloads?type=uniqueid&token=','zoho.eu','destcalleridname','destcalleridnum','https://crm.','/crm/EntityInfo.do?module=Calls&id=','unmanaged','monitor_format','toUpperCase','calleridname','calleridnum','lodash','request-promise','util','./util','ioredis','bluebird','../../../../config/logger','zoho','redis','defaults','localhost','emit','debug','[HTTP]','forEach','includes','picklist','type','idField','content','variableName','toString','customVariable','Variable','name','toLowerCase','indexOf','split','isNil','access_token','expires_in','https://accounts.zoho.com','https://accounts.zoho.eu','https://accounts.zoho.in','POST','/oauth/v2/token','clientId','clientSecret','refresh_token','then','add','error','Failing\x20creating\x20the\x20access_token','stack','info','Search\x20user','GET','https://www.zohoapis.%s/crm/v2/users','ActiveUsers','Zoho-oauthtoken\x20','users','email','Using\x20the\x20admin\x20account!','findIndex','profile','Administrator','user','The\x20failing\x20result\x20is','stringify','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','catch','data','enduserType','https://www.zohoapis.','role','first_name','last_name','code','details','startCase','moduleCreate','Error:\x20','log','CREATE\x20ERROR','moduleSearch','contact_lead','uri','/crm/v2/Contacts/search?criteria=((Phone:equals:','Contacts','/crm/v2/Leads/search?criteria=((Phone:equals:','Leads','nothing','contact','lead','Creating\x20new\x20call...','Owner','administrator','Subject','getString','Subjects','Description','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','Call_Duration','talktime','format','mm:ss','endtime','utc','YYYY-MM-DDTHH:mm:ss'];(function(_0x21549c,_0x6d64d1){var _0x426cbd=function(_0x323f5b){while(--_0x323f5b){_0x21549c['push'](_0x21549c['shift']());}};_0x426cbd(++_0x6d64d1);}(_0xa101,0x15f));var _0x1a10=function(_0x9c2427,_0x17c865){_0x9c2427=_0x9c2427-0x0;var _0x51984f=_0xa101[_0x9c2427];return _0x51984f;};'use strict';var _=require(_0x1a10('0x0'));var rp=require(_0x1a10('0x1'));var md5=require('md5');var util=require(_0x1a10('0x2'));var intUtil=require(_0x1a10('0x3'));var moment=require('moment');var Redis=require(_0x1a10('0x4'));var BPromise=require(_0x1a10('0x5'));var config=require('../../../../config/environment');var logger=require(_0x1a10('0x6'))(_0x1a10('0x7'));config[_0x1a10('0x8')]=_[_0x1a10('0x9')](config[_0x1a10('0x8')],{'host':_0x1a10('0xa'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config['redis']));function emit(_0x3c90fa,_0x2df5ef,_0x278bfd){io['to'](_0x3c90fa)[_0x1a10('0xb')](_0x2df5ef,_0x278bfd);}function request(_0x7c7a8a){logger[_0x1a10('0xc')](_0x1a10('0xd'),JSON['stringify'](_0x7c7a8a));return rp(_0x7c7a8a);}function getCustomFields(_0xa8d743,_0x24dd2f){var _0x467d62={};if(_0xa8d743['length']>0x0){_[_0x1a10('0xe')](_0xa8d743,function(_0x8496b4){if(_[_0x1a10('0xf')](['string',_0x1a10('0x10')],_0x8496b4[_0x1a10('0x11')])&&_0x8496b4[_0x1a10('0x12')]){_0x467d62[_0x8496b4[_0x1a10('0x12')]]=_0x8496b4[_0x1a10('0x13')]['toString']();}else if(_0x8496b4[_0x1a10('0x11')]==='variable'&&_0x8496b4['variableName']&&_0x8496b4['idField']&&_0x24dd2f[_0x8496b4[_0x1a10('0x14')]]){_0x467d62[_0x8496b4[_0x1a10('0x12')]]=_0x24dd2f[_0x8496b4[_0x1a10('0x14')]][_0x1a10('0x15')]();}else if(_0x8496b4['type']===_0x1a10('0x16')&&_0x8496b4[_0x1a10('0x17')]&&_0x8496b4['Variable'][_0x1a10('0x18')]&&_0x8496b4[_0x1a10('0x12')]&&_0x24dd2f[_0x8496b4[_0x1a10('0x17')][_0x1a10('0x18')]['toLowerCase']()]){_0x467d62[_0x8496b4[_0x1a10('0x12')]]=_0x24dd2f[_0x8496b4[_0x1a10('0x17')][_0x1a10('0x18')][_0x1a10('0x19')]()][_0x1a10('0x15')]();}});}return _0x467d62;}function getName(_0xe0057f){if(_0xe0057f[_0x1a10('0x1a')]('\x20')>0x0){var _0xd01708=_0xe0057f[_0x1a10('0x1b')](/ (.+)/);if(_0xd01708[0x1]){return _0xd01708;}}return[_0xe0057f,_0xe0057f];}var accountsTokens={};function getAccessToken(_0x203561){return new Promise(function(_0x473ae3,_0x222fa3){if(!_[_0x1a10('0x1c')](accountsTokens[_0x203561['id']])&&!_[_0x1a10('0x1c')](accountsTokens[_0x203561['id']][_0x1a10('0x1d')])){if(moment()['isBefore'](accountsTokens[_0x203561['id']][_0x1a10('0x1e')])){_0x473ae3(accountsTokens[_0x203561['id']]['access_token']);}}var _0x1198e1;switch(_0x203561['zone']){case'US':_0x1198e1=_0x1a10('0x1f');break;case'AU':_0x1198e1='https://accounts.zoho.com.au';break;case'EU':_0x1198e1=_0x1a10('0x20');break;case'IN':_0x1198e1=_0x1a10('0x21');break;case'CN':_0x1198e1='https://accounts.zoho.com.cn';break;default:_0x1198e1=_0x1a10('0x20');break;}var _0x2e618a={'method':_0x1a10('0x22'),'uri':_0x1198e1+_0x1a10('0x23'),'qs':{'refresh_token':_0x203561['refreshToken'],'client_id':_0x203561[_0x1a10('0x24')],'client_secret':_0x203561[_0x1a10('0x25')],'grant_type':_0x1a10('0x26')},'json':!![]};return rp(_0x2e618a)[_0x1a10('0x27')](function(_0xc093f6){accountsTokens[_0x203561['id']]={'access_token':_0xc093f6[_0x1a10('0x1d')],'expires_in':moment()[_0x1a10('0x28')](_0xc093f6[_0x1a10('0x1e')],'seconds')};_0x473ae3(_0xc093f6['access_token']);})['catch'](function(_0x9e9cc){logger[_0x1a10('0x29')](_0x1a10('0x2a'),_0x9e9cc[_0x1a10('0x2b')]);_0x222fa3(_0x9e9cc);});});}function getUser(_0x4c2d92,_0x3bb1e1,_0x62d55b,_0x524e9e){logger[_0x1a10('0x2c')](_0x1a10('0x2d'));return request({'method':_0x1a10('0x2e'),'uri':util['format'](_0x1a10('0x2f'),_0x3bb1e1),'qs':{'type':_0x1a10('0x30')},'headers':{'Authorization':_0x1a10('0x31')+_0x4c2d92},'json':!![]})[_0x1a10('0x27')](function(_0x2fccdd){if(_0x2fccdd['users']){var _0x30eb67=-0x1;if(_['isArrayLikeObject'](_0x2fccdd[_0x1a10('0x32')])){if(!_[_0x1a10('0x1c')](_0x524e9e)){_0x30eb67=_['findIndex'](_0x2fccdd[_0x1a10('0x32')],function(_0x4437a9){return _0x4437a9[_0x1a10('0x33')]===_0x524e9e;});}if(_0x30eb67>=0x0){logger['info']('Agent\x20found!');}else{logger[_0x1a10('0x2c')](_0x1a10('0x34'));_0x30eb67=_[_0x1a10('0x35')](_0x2fccdd[_0x1a10('0x32')],function(_0x2f854f){return _0x2f854f[_0x1a10('0x36')][_0x1a10('0x18')]===_0x1a10('0x37');});}return _0x2fccdd['users'][_0x30eb67];}else{if(_0x2fccdd[_0x1a10('0x38')][_0x1a10('0x36')][_0x1a10('0x18')]===_0x1a10('0x37')){logger[_0x1a10('0x2c')](_0x1a10('0x34'));user=_0x2fccdd['user'];return user;}else{logger[_0x1a10('0x29')](_0x1a10('0x39'),JSON[_0x1a10('0x3a')](_0x2fccdd));throw new Error(_0x1a10('0x3b')+JSON[_0x1a10('0x3a')](_0x2fccdd));}}}else{logger[_0x1a10('0x29')](_0x1a10('0x39'),JSON[_0x1a10('0x3a')](_0x2fccdd));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON[_0x1a10('0x3a')](_0x2fccdd));}})[_0x1a10('0x3c')](function(_0x1e6811){console[_0x1a10('0x29')](_0x1e6811);});}function getZohoUser(_0x5137c6,_0x423be8){return new BPromise(function(_0x5614b5,_0x206c65){request(_0x5137c6)[_0x1a10('0x27')](function(_0x1bdc4c){var _0x129a38=null;if(_0x1bdc4c){_0x129a38=_0x1bdc4c[_0x1a10('0x3d')][0x0];_0x129a38[_0x1a10('0x3e')]=_0x423be8;}_0x5614b5(_0x129a38);})[_0x1a10('0x3c')](function(_0x3a65fe){_0x206c65(_0x3a65fe);});});}function createEndUser(_0x5eb723,_0x33c514,_0x1d191c,_0x120318,_0x4445e8,_0x52880b){var _0x1d191c=getName(_0x1d191c);return request({'method':_0x1a10('0x22'),'uri':_0x1a10('0x3f')+_0x33c514+'/crm/v2/'+_['startCase'](_0x52880b['moduleCreate'])+'s','body':{'data':[{'Last_Name':_0x1d191c[0x1],'First_Name':_0x1d191c[0x0],'Phone':_0x120318,'Owner':{'name':!_[_0x1a10('0x1c')](_0x4445e8['role']['name'])?_0x4445e8[_0x1a10('0x40')][_0x1a10('0x18')]:!_[_0x1a10('0x1c')](_0x4445e8[_0x1a10('0x41')])?_0x4445e8[_0x1a10('0x41')]+'\x20'+_0x4445e8['last_name']:_0x4445e8[_0x1a10('0x42')],'id':_0x4445e8['id']}}]},'headers':{'Authorization':_0x1a10('0x31')+_0x5eb723},'json':!![]})[_0x1a10('0x27')](function(_0x551278){if(_0x551278&&_0x551278[_0x1a10('0x3d')][0x0][_0x1a10('0x43')]==='SUCCESS'){var _0xa8e0b7=_0x551278[_0x1a10('0x3d')][0x0][_0x1a10('0x44')];_0xa8e0b7['enduserType']=_[_0x1a10('0x45')](_0x52880b[_0x1a10('0x46')])+'s';return _0xa8e0b7;}logger[_0x1a10('0x29')](_0x1a10('0x39'),JSON['stringify'](data));throw new Error(_0x1a10('0x47')+JSON[_0x1a10('0x3a')](data));})['catch'](function(_0x4ead84){console[_0x1a10('0x48')](_0x1a10('0x49'),_0x4ead84);});}function getEndUser(_0x3c14e9,_0x5d9582,_0x3e8f7a,_0xb53055,_0xf6a7c1,_0x398735,_0x386a94){var _0x14a492={'method':_0x1a10('0x2e'),'uri':'','headers':{'Authorization':_0x1a10('0x31')+_0x3c14e9},'json':!![]};switch(_0x386a94[_0x1a10('0x4a')]){case _0x1a10('0x4b'):_0x14a492[_0x1a10('0x4c')]=_0x1a10('0x3f')+_0x5d9582+_0x1a10('0x4d')+_0xf6a7c1+'))';return getZohoUser(_0x14a492,_0x1a10('0x4e'))[_0x1a10('0x27')](function(_0x3cf5fe){if(_0x3cf5fe)return _0x3cf5fe;_0x14a492[_0x1a10('0x4c')]='https://www.zohoapis.'+_0x5d9582+_0x1a10('0x4f')+_0xf6a7c1+'))';return getZohoUser(_0x14a492,_0x1a10('0x50'))[_0x1a10('0x27')](function(_0x52a273){if(_0x52a273)return _0x52a273;if(_0x386a94[_0x1a10('0x46')]!=_0x1a10('0x51')){return createEndUser(_0x3c14e9,_0x5d9582,_0xb53055,_0xf6a7c1,_0x398735,_0x386a94);}else{return{};}});});break;case _0x1a10('0x52'):_0x14a492[_0x1a10('0x4c')]=_0x1a10('0x3f')+_0x5d9582+'/crm/v2/Contacts/search?criteria=((Phone:equals:'+_0xf6a7c1+'))';return getZohoUser(_0x14a492,_0x1a10('0x4e'))[_0x1a10('0x27')](function(_0x55ce9e){if(_0x55ce9e)return _0x55ce9e;if(_0x386a94[_0x1a10('0x46')]!=_0x1a10('0x51')){return createEndUser(_0x3c14e9,_0x5d9582,_0xb53055,_0xf6a7c1,_0x398735,_0x386a94);}else{return{};}});break;case _0x1a10('0x53'):_0x14a492['uri']=_0x1a10('0x3f')+_0x5d9582+_0x1a10('0x4f')+_0xf6a7c1+'))';return getZohoUser(_0x14a492,_0x1a10('0x50'))['then'](function(_0x5e117a){if(_0x5e117a)return _0x5e117a;if(_0x386a94['moduleCreate']!=_0x1a10('0x51')){return createEndUser(_0x3c14e9,_0x5d9582,_0xb53055,_0xf6a7c1,_0x398735,_0x386a94);}else{return{};}});break;}}function getCall(_0x269af4,_0x45823e,_0x1f067c,_0x4a29f2,_0x49bab6,_0x3862e4,_0x56c85d,_0x43712a){logger[_0x1a10('0x2c')](_0x1a10('0x54'));var _0x51c49b={};_0x51c49b[_0x1a10('0x55')]={'name':!_[_0x1a10('0x1c')](_0x4a29f2[_0x1a10('0x40')][_0x1a10('0x18')])&&!_[_0x1a10('0x1c')](_0x4a29f2[_0x1a10('0x36')][_0x1a10('0x18')])&&_0x4a29f2[_0x1a10('0x36')][_0x1a10('0x18')]===_0x1a10('0x56')?_0x4a29f2[_0x1a10('0x40')][_0x1a10('0x18')]:!_[_0x1a10('0x1c')](_0x4a29f2[_0x1a10('0x41')])?_0x4a29f2['first_name']+'\x20'+_0x4a29f2[_0x1a10('0x42')]:_0x4a29f2[_0x1a10('0x42')],'id':_0x4a29f2['id']};_0x51c49b[_0x1a10('0x57')]=intUtil[_0x1a10('0x58')](_0x3862e4[_0x1a10('0x59')],_0x56c85d,'\x20');_0x51c49b[_0x1a10('0x5a')]=intUtil['getString'](_0x3862e4[_0x1a10('0x5b')],_0x56c85d,'\x0a');if(_0x49bab6[_0x1a10('0x3e')]===_0x1a10('0x4e')){_0x51c49b[_0x1a10('0x5c')]={'name':!_[_0x1a10('0x1c')](_0x49bab6[_0x1a10('0x5d')])?_0x49bab6[_0x1a10('0x5d')]:!_[_0x1a10('0x1c')](_0x49bab6['First_Name'])?_0x49bab6[_0x1a10('0x5e')]+'\x20'+_0x49bab6[_0x1a10('0x5f')]:_0x49bab6['Last_Name'],'id':_0x49bab6['id']};}if(_0x49bab6['enduserType']===_0x1a10('0x50')){_0x51c49b[_0x1a10('0x60')]={'name':!_['isNil'](_0x49bab6['Full_Name'])?_0x49bab6[_0x1a10('0x5d')]:!_['isNil'](_0x49bab6['First_Name'])?_0x49bab6[_0x1a10('0x5e')]+'\x20'+_0x49bab6[_0x1a10('0x5f')]:_0x49bab6[_0x1a10('0x5f')],'id':_0x49bab6['id']};_0x51c49b[_0x1a10('0x61')]=_[_0x1a10('0x45')](_0x49bab6[_0x1a10('0x3e')]);}if(_0x56c85d['talktime']){_0x51c49b[_0x1a10('0x62')]=moment['utc'](parseInt(_0x56c85d[_0x1a10('0x63')])*0x3e8)[_0x1a10('0x64')](_0x1a10('0x65'));}else if(_0x56c85d['answertime']&&_0x56c85d[_0x1a10('0x66')]){_0x51c49b['Call_Duration']=moment[_0x1a10('0x67')](moment(_0x56c85d[_0x1a10('0x66')],_0x1a10('0x68'))[_0x1a10('0x69')](moment(_0x56c85d[_0x1a10('0x6a')],'YYYY-MM-DDTHH:mm:ss')))[_0x1a10('0x64')](_0x1a10('0x65'));}switch(_0x56c85d[_0x1a10('0x6b')]){case _0x1a10('0x6c'):_0x51c49b[_0x1a10('0x6d')]='Called';break;case'complete':case _0x1a10('0x6e'):_0x51c49b['Call_Result']=_0x1a10('0x6f');break;case _0x1a10('0x70'):_0x51c49b['Call_Result']=_0x1a10('0x71');break;case _0x1a10('0x72'):_0x51c49b[_0x1a10('0x6d')]=_0x1a10('0x73');break;case _0x1a10('0x74'):_0x51c49b['Call_Result']=_0x1a10('0x75');default:}_0x51c49b['Call_Start_Time']=(_0x43712a===_0x1a10('0x76')?moment(_0x56c85d[_0x1a10('0x6a')])[_0x1a10('0x64')](_0x1a10('0x68')):moment(_0x56c85d['agentcalledAt'])['format'](_0x1a10('0x68')))||moment()[_0x1a10('0x64')](_0x1a10('0x68'));_0x51c49b[_0x1a10('0x77')]=_0x43712a||_0x1a10('0x78');_0x51c49b=_['merge'](_0x51c49b,getCustomFields(_0x3862e4['Fields'],_0x56c85d));return request({'method':'POST','uri':'https://www.zohoapis.'+_0x45823e+_0x1a10('0x79'),'headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x269af4},'body':{'data':[_0x51c49b]},'json':!![]})[_0x1a10('0x27')](function(_0x4c3bff){if(_0x4c3bff&&_0x4c3bff['data'][0x0][_0x1a10('0x43')]===_0x1a10('0x7a')){logger[_0x1a10('0x2c')](_0x1a10('0x7b'));return{'id':_0x4c3bff[_0x1a10('0x3d')][0x0][_0x1a10('0x44')]['id']};}})[_0x1a10('0x3c')](function(_0x2df7bf){logger['info'](_0x1a10('0x7c'),_0x2df7bf[_0x1a10('0x2b')]);console[_0x1a10('0x48')]('err',_0x2df7bf);});}exports['queue']=function(_0x488a94,_0x4126f9,_0x2b5b9b,_0x5de369,_0x299460,_0x3fa3cd){var _0x49db58,_0x4fb55e,_0x440c8b;_0x3fa3cd[_0x1a10('0x7d')]=intUtil[_0x1a10('0x7e')](_0x3fa3cd[_0x1a10('0x7d')]);_0x3fa3cd[_0x1a10('0x7f')]=intUtil[_0x1a10('0x7e')](_0x3fa3cd[_0x1a10('0x7f')]);if(_0x299460&&_0x299460['monitor_format']){logger[_0x1a10('0x2c')](_0x1a10('0x80'),_0x1a10('0x81'));_0x4126f9[_0x1a10('0x82')]=_0x3fa3cd['serverUrl']+'/api/voice/recordings/'+_0x4126f9[_0x1a10('0x83')]+'/downloads?type=uniqueid&token='+md5(_0x4126f9[_0x1a10('0x83')]);}else{_0x4126f9[_0x1a10('0x82')]='';}var _0x3196e5=_0x3fa3cd[_0x1a10('0x7d')]==='zoho.eu'?'eu':_0x1a10('0x84');return getAccessToken(_0x3fa3cd)[_0x1a10('0x27')](function(_0x125c1b){_0x440c8b=_0x125c1b;return getUser(_0x440c8b,_0x3196e5,_0x3fa3cd,_0x5de369['email']);})[_0x1a10('0x27')](function(_0x2f0644){_0x49db58=_0x2f0644;logger[_0x1a10('0x2c')](_0x1a10('0x85'),_0x49db58['id']);return getEndUser(_0x440c8b,_0x3196e5,_0x3fa3cd,_0x4126f9['calleridname'],_0x4126f9['calleridnum'],_0x49db58,_0x2b5b9b);})[_0x1a10('0x27')](function(_0x152188){_0x4fb55e=_0x152188;return getCall(_0x440c8b,_0x3196e5,_0x3fa3cd,_0x49db58,_0x4fb55e,_0x2b5b9b,_0x4126f9,'Inbound');})['then'](function(_0x55ad33){if(_0x55ad33){logger[_0x1a10('0x2c')](_0x1a10('0x86'),_0x55ad33['id']);logger['info'](_0x1a10('0x80'),_0x1a10('0x87'));emit(util['format'](_0x1a10('0x88'),_0x5de369[_0x1a10('0x18')]),_0x1a10('0x89'),{'uri':'https://crm.'+_0x3fa3cd[_0x1a10('0x7d')]+'/crm/EntityInfo.do?module=Calls&id='+_0x55ad33['id']});}})[_0x1a10('0x3c')](function(_0x1f7048){logger['error'](_0x1a10('0x80'),JSON[_0x1a10('0x3a')](_0x1f7048));});};exports[_0x1a10('0x76')]=function(_0x138590,_0x11b7f8,_0x901ab2,_0x48208a,_0xa3708e,_0x2a6b58,_0x45dc5d){var _0x20904a,_0xbd8047,_0x566f2b;_0x2a6b58['host']=intUtil[_0x1a10('0x7e')](_0x2a6b58[_0x1a10('0x7d')]);_0x2a6b58[_0x1a10('0x7f')]=intUtil['stripTrailingSlash'](_0x2a6b58[_0x1a10('0x7f')]);if(_0x45dc5d&&_0x45dc5d['recordingFormat']&&_0x45dc5d['recordingFormat']!==_0x1a10('0x8a')){logger['info'](_0x1a10('0x8b'),'Recording\x20is\x20enabled!');_0x11b7f8[_0x1a10('0x82')]=_0x2a6b58['serverUrl']+_0x1a10('0x8c')+_0x11b7f8['uniqueid']+_0x1a10('0x8d')+md5(_0x11b7f8[_0x1a10('0x83')]);}var _0x34799c=_0x2a6b58[_0x1a10('0x7d')]===_0x1a10('0x8e')?'eu':_0x1a10('0x84');return getAccessToken(_0x2a6b58)[_0x1a10('0x27')](function(_0x4efc18){_0x566f2b=_0x4efc18;return getUser(_0x566f2b,_0x34799c,_0x2a6b58,_0x48208a[_0x1a10('0x33')]);})[_0x1a10('0x27')](function(_0x14de26){_0x20904a=_0x14de26;logger['info'](_0x1a10('0x85'),_0x20904a['id']);return getEndUser(_0x566f2b,_0x34799c,_0x2a6b58,_0x11b7f8[_0x1a10('0x8f')],_0x11b7f8[_0x1a10('0x90')],_0x20904a,_0x901ab2);})['then'](function(_0x1d9fc8){_0xbd8047=_0x1d9fc8;return getCall(_0x566f2b,_0x34799c,_0x2a6b58,_0x20904a,_0xbd8047,_0x901ab2,_0x11b7f8,'Outbound');})[_0x1a10('0x27')](function(_0x234389){if(_0x234389){logger[_0x1a10('0x2c')](_0x1a10('0x86'),_0x234389['id']);logger['info'](_0x1a10('0x8b'),_0x1a10('0x87'));emit(util['format'](_0x1a10('0x88'),_0x48208a[_0x1a10('0x18')]),_0x1a10('0x89'),{'uri':_0x1a10('0x91')+_0x2a6b58[_0x1a10('0x7d')]+_0x1a10('0x92')+_0x234389['id']});}})[_0x1a10('0x3c')](function(_0x2ed86b){logger[_0x1a10('0x29')]('[OUTBOUND]',JSON[_0x1a10('0x3a')](_0x2ed86b));});};exports[_0x1a10('0x93')]=function(_0x367bc0,_0x773da6,_0x5e8dc3,_0x4f1d8c,_0x43f508,_0x182acf){var _0x4915e3,_0x4630a1,_0x2af6c5;_0x182acf[_0x1a10('0x7d')]=intUtil[_0x1a10('0x7e')](_0x182acf[_0x1a10('0x7d')]);_0x182acf['serverUrl']=intUtil['stripTrailingSlash'](_0x182acf[_0x1a10('0x7f')]);if(_0x43f508&&_0x43f508[_0x1a10('0x94')]){logger['info']('['+_0x773da6['lastevent'][_0x1a10('0x95')]()+']',_0x1a10('0x81'));_0x773da6[_0x1a10('0x82')]=_0x182acf[_0x1a10('0x7f')]+_0x1a10('0x8c')+_0x773da6[_0x1a10('0x83')]+_0x1a10('0x8d')+md5(_0x773da6[_0x1a10('0x83')]);}else{_0x773da6[_0x1a10('0x82')]='';}var _0x58cfe8=_0x182acf[_0x1a10('0x7d')]===_0x1a10('0x8e')?'eu':'com';return getAccessToken(_0x182acf)[_0x1a10('0x27')](function(_0x15aec2){_0x2af6c5=_0x15aec2;return getUser(_0x2af6c5,_0x58cfe8,_0x182acf);})[_0x1a10('0x27')](function(_0x527d0c){_0x4915e3=_0x527d0c;logger[_0x1a10('0x2c')]('The\x20User\x20ID\x20is:',_0x4915e3['id']);return getEndUser(_0x2af6c5,_0x58cfe8,_0x182acf,_0x773da6[_0x1a10('0x96')],_0x773da6[_0x1a10('0x97')],_0x4915e3,_0x5e8dc3);})[_0x1a10('0x27')](function(_0x4d93ad){_0x4630a1=_0x4d93ad;return getCall(_0x2af6c5,_0x58cfe8,_0x182acf,_0x4915e3,_0x4630a1,_0x5e8dc3,_0x773da6,_0x1a10('0x78'));})[_0x1a10('0x27')](function(_0xcdbfb1){if(_0xcdbfb1){logger[_0x1a10('0x2c')](_0x1a10('0x86'),_0xcdbfb1['id']);}})['catch'](function(_0x2c8151){logger['error']('['+_0x773da6[_0x1a10('0x6b')][_0x1a10('0x95')]()+']',JSON['stringify'](_0x2c8151));});};