Built motion from commit 43538d75.|2.5.35
[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 _0x4597=['unmanaged','toUpperCase','calleridname','lodash','request-promise','md5','util','./util','moment','bluebird','../../../../config/environment','../../../../config/logger','zoho','redis','defaults','localhost','emit','[HTTP]','length','forEach','includes','string','picklist','type','idField','toString','variable','variableName','customVariable','Variable','name','toLowerCase','indexOf','split','isNil','access_token','isBefore','expires_in','https://accounts.zoho.com','https://accounts.zoho.in','https://accounts.zoho.com.cn','https://accounts.zoho.eu','POST','refreshToken','clientId','refresh_token','add','seconds','catch','error','Failing\x20creating\x20the\x20access_token','info','Search\x20user','GET','https://www.zohoapis.%s/crm/v2/users','ActiveUsers','Zoho-oauthtoken\x20','then','users','isArrayLikeObject','findIndex','email','Agent\x20found!','Using\x20the\x20admin\x20account!','profile','Administrator','user','stringify','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','The\x20failing\x20result\x20is','data','https://www.zohoapis.','/crm/v2/','startCase','moduleCreate','first_name','last_name','code','SUCCESS','details','enduserType','Error:\x20','log','contact_lead','uri','/crm/v2/Contacts/search?criteria=((Phone:equals:','Contacts','/crm/v2/Leads/search?criteria=((Phone:equals:','Leads','nothing','contact','lead','Owner','role','administrator','getString','Subjects','Description','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','talktime','Call_Duration','utc','mm:ss','answertime','endtime','YYYY-MM-DDTHH:mm:ss','starttime','format','lastevent','called','Call_Result','Called','complete','Answered','rejected','Rejected','Abandoned','Timeout','Call_Start_Time','outbound','Call_Type','Inbound','Fields','/crm/v2/Calls','Call\x20created!','err','stack','queue','host','stripTrailingSlash','serverUrl','monitor_format','[QUEUE]','Recording\x20is\x20enabled!','recordingURL','/api/voice/recordings/','uniqueid','/downloads?type=uniqueid&token=','zoho.eu','com','The\x20User\x20ID\x20is:','calleridnum','user:%s','trigger:browser:url','https://crm.','/crm/EntityInfo.do?module=Calls&id=','recordingFormat','none','[OUTBOUND]','destcalleridname','destcalleridnum','Outbound','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...'];(function(_0x56916d,_0x37b935){var _0x2b7f1f=function(_0x206eb1){while(--_0x206eb1){_0x56916d['push'](_0x56916d['shift']());}};_0x2b7f1f(++_0x37b935);}(_0x4597,0x1e3));var _0x7459=function(_0x3423b9,_0x492eea){_0x3423b9=_0x3423b9-0x0;var _0x48f7ac=_0x4597[_0x3423b9];return _0x48f7ac;};'use strict';var _=require(_0x7459('0x0'));var rp=require(_0x7459('0x1'));var md5=require(_0x7459('0x2'));var util=require(_0x7459('0x3'));var intUtil=require(_0x7459('0x4'));var moment=require(_0x7459('0x5'));var Redis=require('ioredis');var BPromise=require(_0x7459('0x6'));var config=require(_0x7459('0x7'));var logger=require(_0x7459('0x8'))(_0x7459('0x9'));config[_0x7459('0xa')]=_[_0x7459('0xb')](config[_0x7459('0xa')],{'host':_0x7459('0xc'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0x7459('0xa')]));function emit(_0x2fcde8,_0x568c16,_0x2989eb){io['to'](_0x2fcde8)[_0x7459('0xd')](_0x568c16,_0x2989eb);}function request(_0x4692d6){logger['debug'](_0x7459('0xe'),JSON['stringify'](_0x4692d6));return rp(_0x4692d6);}function getCustomFields(_0x1e95d7,_0x543b84){var _0x378f5d={};if(_0x1e95d7[_0x7459('0xf')]>0x0){_[_0x7459('0x10')](_0x1e95d7,function(_0x2d3a85){if(_[_0x7459('0x11')]([_0x7459('0x12'),_0x7459('0x13')],_0x2d3a85[_0x7459('0x14')])&&_0x2d3a85[_0x7459('0x15')]){_0x378f5d[_0x2d3a85['idField']]=_0x2d3a85['content'][_0x7459('0x16')]();}else if(_0x2d3a85['type']===_0x7459('0x17')&&_0x2d3a85['variableName']&&_0x2d3a85['idField']&&_0x543b84[_0x2d3a85[_0x7459('0x18')]]){_0x378f5d[_0x2d3a85[_0x7459('0x15')]]=_0x543b84[_0x2d3a85[_0x7459('0x18')]][_0x7459('0x16')]();}else if(_0x2d3a85['type']===_0x7459('0x19')&&_0x2d3a85[_0x7459('0x1a')]&&_0x2d3a85[_0x7459('0x1a')]['name']&&_0x2d3a85['idField']&&_0x543b84[_0x2d3a85[_0x7459('0x1a')]['name']['toLowerCase']()]){_0x378f5d[_0x2d3a85[_0x7459('0x15')]]=_0x543b84[_0x2d3a85[_0x7459('0x1a')][_0x7459('0x1b')][_0x7459('0x1c')]()][_0x7459('0x16')]();}});}return _0x378f5d;}function getName(_0x59d51c){if(_0x59d51c[_0x7459('0x1d')]('\x20')>0x0){var _0x2e505a=_0x59d51c[_0x7459('0x1e')](/ (.+)/);if(_0x2e505a[0x1]){return _0x2e505a;}}return[_0x59d51c,_0x59d51c];}var accountsTokens={};function getAccessToken(_0x477820){return new Promise(function(_0x53a526,_0x54853b){if(!_['isNil'](accountsTokens[_0x477820['id']])&&!_[_0x7459('0x1f')](accountsTokens[_0x477820['id']][_0x7459('0x20')])){if(moment()[_0x7459('0x21')](accountsTokens[_0x477820['id']][_0x7459('0x22')])){_0x53a526(accountsTokens[_0x477820['id']]['access_token']);}}var _0x4e6f70;switch(_0x477820['zone']){case'US':_0x4e6f70=_0x7459('0x23');break;case'AU':_0x4e6f70='https://accounts.zoho.com.au';break;case'EU':_0x4e6f70='https://accounts.zoho.eu';break;case'IN':_0x4e6f70=_0x7459('0x24');break;case'CN':_0x4e6f70=_0x7459('0x25');break;default:_0x4e6f70=_0x7459('0x26');break;}var _0x2b9ecb={'method':_0x7459('0x27'),'uri':_0x4e6f70+'/oauth/v2/token','qs':{'refresh_token':_0x477820[_0x7459('0x28')],'client_id':_0x477820[_0x7459('0x29')],'client_secret':_0x477820['clientSecret'],'grant_type':_0x7459('0x2a')},'json':!![]};return rp(_0x2b9ecb)['then'](function(_0x3b3a2f){accountsTokens[_0x477820['id']]={'access_token':_0x3b3a2f[_0x7459('0x20')],'expires_in':moment()[_0x7459('0x2b')](_0x3b3a2f[_0x7459('0x22')],_0x7459('0x2c'))};_0x53a526(_0x3b3a2f[_0x7459('0x20')]);})[_0x7459('0x2d')](function(_0x4fbe00){logger[_0x7459('0x2e')](_0x7459('0x2f'),_0x4fbe00['stack']);_0x54853b(_0x4fbe00);});});}function getUser(_0x5202c4,_0x40a16e,_0x2e12b7,_0x65e6ea){logger[_0x7459('0x30')](_0x7459('0x31'));return request({'method':_0x7459('0x32'),'uri':util['format'](_0x7459('0x33'),_0x40a16e),'qs':{'type':_0x7459('0x34')},'headers':{'Authorization':_0x7459('0x35')+_0x5202c4},'json':!![]})[_0x7459('0x36')](function(_0x1a0e49){if(_0x1a0e49[_0x7459('0x37')]){var _0x21d364=-0x1;if(_[_0x7459('0x38')](_0x1a0e49[_0x7459('0x37')])){if(!_[_0x7459('0x1f')](_0x65e6ea)){_0x21d364=_[_0x7459('0x39')](_0x1a0e49['users'],function(_0x43a0b6){return _0x43a0b6[_0x7459('0x3a')]===_0x65e6ea;});}if(_0x21d364>=0x0){logger['info'](_0x7459('0x3b'));}else{logger[_0x7459('0x30')](_0x7459('0x3c'));_0x21d364=_[_0x7459('0x39')](_0x1a0e49[_0x7459('0x37')],function(_0x530fcc){return _0x530fcc[_0x7459('0x3d')][_0x7459('0x1b')]===_0x7459('0x3e');});}return _0x1a0e49['users'][_0x21d364];}else{if(_0x1a0e49['user'][_0x7459('0x3d')][_0x7459('0x1b')]==='Administrator'){logger[_0x7459('0x30')]('Using\x20the\x20admin\x20account!');user=_0x1a0e49[_0x7459('0x3f')];return user;}else{logger[_0x7459('0x2e')]('The\x20failing\x20result\x20is',JSON[_0x7459('0x40')](_0x1a0e49));throw new Error(_0x7459('0x41')+JSON[_0x7459('0x40')](_0x1a0e49));}}}else{logger['error'](_0x7459('0x42'),JSON[_0x7459('0x40')](_0x1a0e49));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON[_0x7459('0x40')](_0x1a0e49));}})[_0x7459('0x2d')](function(_0x9fabe6){console[_0x7459('0x2e')](_0x9fabe6);});}function getZohoUser(_0x129d63,_0x47eb2a){return new BPromise(function(_0x80aaa0,_0x569c92){request(_0x129d63)['then'](function(_0x5bbe5e){var _0x133606=null;if(_0x5bbe5e){_0x133606=_0x5bbe5e[_0x7459('0x43')][0x0];_0x133606['enduserType']=_0x47eb2a;}_0x80aaa0(_0x133606);})[_0x7459('0x2d')](function(_0x1e9d48){_0x569c92(_0x1e9d48);});});}function createEndUser(_0x15f218,_0x84c73b,_0x5a1a03,_0x2f5fd7,_0x564903,_0x11ec00){var _0x5a1a03=getName(_0x5a1a03);return request({'method':_0x7459('0x27'),'uri':_0x7459('0x44')+_0x84c73b+_0x7459('0x45')+_[_0x7459('0x46')](_0x11ec00[_0x7459('0x47')])+'s','body':{'data':[{'Last_Name':_0x5a1a03[0x1],'First_Name':_0x5a1a03[0x0],'Phone':_0x2f5fd7,'Owner':{'name':!_[_0x7459('0x1f')](_0x564903['role'][_0x7459('0x1b')])?_0x564903['role']['name']:!_['isNil'](_0x564903[_0x7459('0x48')])?_0x564903[_0x7459('0x48')]+'\x20'+_0x564903[_0x7459('0x49')]:_0x564903[_0x7459('0x49')],'id':_0x564903['id']}}]},'headers':{'Authorization':_0x7459('0x35')+_0x15f218},'json':!![]})[_0x7459('0x36')](function(_0x465dc6){if(_0x465dc6&&_0x465dc6[_0x7459('0x43')][0x0][_0x7459('0x4a')]===_0x7459('0x4b')){var _0x1bfe21=_0x465dc6[_0x7459('0x43')][0x0][_0x7459('0x4c')];_0x1bfe21[_0x7459('0x4d')]=_['startCase'](_0x11ec00[_0x7459('0x47')])+'s';return _0x1bfe21;}logger[_0x7459('0x2e')](_0x7459('0x42'),JSON[_0x7459('0x40')](data));throw new Error(_0x7459('0x4e')+JSON[_0x7459('0x40')](data));})['catch'](function(_0x2857ca){console[_0x7459('0x4f')]('CREATE\x20ERROR',_0x2857ca);});}function getEndUser(_0x3b4672,_0x58e022,_0x3bf80b,_0x27a8c1,_0x5d24ed,_0x216653,_0xa69758){var _0x5034cc={'method':_0x7459('0x32'),'uri':'','headers':{'Authorization':_0x7459('0x35')+_0x3b4672},'json':!![]};switch(_0xa69758['moduleSearch']){case _0x7459('0x50'):_0x5034cc[_0x7459('0x51')]=_0x7459('0x44')+_0x58e022+_0x7459('0x52')+_0x5d24ed+'))';return getZohoUser(_0x5034cc,_0x7459('0x53'))[_0x7459('0x36')](function(_0x26fc91){if(_0x26fc91)return _0x26fc91;_0x5034cc[_0x7459('0x51')]='https://www.zohoapis.'+_0x58e022+_0x7459('0x54')+_0x5d24ed+'))';return getZohoUser(_0x5034cc,_0x7459('0x55'))[_0x7459('0x36')](function(_0x5b6987){if(_0x5b6987)return _0x5b6987;if(_0xa69758['moduleCreate']!=_0x7459('0x56')){return createEndUser(_0x3b4672,_0x58e022,_0x27a8c1,_0x5d24ed,_0x216653,_0xa69758);}else{return{};}});});break;case _0x7459('0x57'):_0x5034cc[_0x7459('0x51')]='https://www.zohoapis.'+_0x58e022+_0x7459('0x52')+_0x5d24ed+'))';return getZohoUser(_0x5034cc,_0x7459('0x53'))['then'](function(_0x130838){if(_0x130838)return _0x130838;if(_0xa69758[_0x7459('0x47')]!=_0x7459('0x56')){return createEndUser(_0x3b4672,_0x58e022,_0x27a8c1,_0x5d24ed,_0x216653,_0xa69758);}else{return{};}});break;case _0x7459('0x58'):_0x5034cc[_0x7459('0x51')]=_0x7459('0x44')+_0x58e022+_0x7459('0x54')+_0x5d24ed+'))';return getZohoUser(_0x5034cc,'Leads')[_0x7459('0x36')](function(_0xed00f7){if(_0xed00f7)return _0xed00f7;if(_0xa69758[_0x7459('0x47')]!='nothing'){return createEndUser(_0x3b4672,_0x58e022,_0x27a8c1,_0x5d24ed,_0x216653,_0xa69758);}else{return{};}});break;}}function getCall(_0x730191,_0x10ec2f,_0x2015d6,_0x5e4a44,_0x357085,_0x52523c,_0x53c755,_0x5e9b77){logger[_0x7459('0x30')]('Creating\x20new\x20call...');var _0x4bbff1={};_0x4bbff1[_0x7459('0x59')]={'name':!_[_0x7459('0x1f')](_0x5e4a44[_0x7459('0x5a')][_0x7459('0x1b')])&&!_[_0x7459('0x1f')](_0x5e4a44['profile'][_0x7459('0x1b')])&&_0x5e4a44[_0x7459('0x3d')][_0x7459('0x1b')]===_0x7459('0x5b')?_0x5e4a44['role'][_0x7459('0x1b')]:!_[_0x7459('0x1f')](_0x5e4a44[_0x7459('0x48')])?_0x5e4a44[_0x7459('0x48')]+'\x20'+_0x5e4a44['last_name']:_0x5e4a44['last_name'],'id':_0x5e4a44['id']};_0x4bbff1['Subject']=intUtil[_0x7459('0x5c')](_0x52523c[_0x7459('0x5d')],_0x53c755,'\x20');_0x4bbff1[_0x7459('0x5e')]=intUtil[_0x7459('0x5c')](_0x52523c[_0x7459('0x5f')],_0x53c755,'\x0a');if(_0x357085[_0x7459('0x4d')]===_0x7459('0x53')){_0x4bbff1[_0x7459('0x60')]={'name':!_['isNil'](_0x357085[_0x7459('0x61')])?_0x357085[_0x7459('0x61')]:!_[_0x7459('0x1f')](_0x357085['First_Name'])?_0x357085[_0x7459('0x62')]+'\x20'+_0x357085[_0x7459('0x63')]:_0x357085[_0x7459('0x63')],'id':_0x357085['id']};}if(_0x357085['enduserType']===_0x7459('0x55')){_0x4bbff1[_0x7459('0x64')]={'name':!_[_0x7459('0x1f')](_0x357085['Full_Name'])?_0x357085[_0x7459('0x61')]:!_[_0x7459('0x1f')](_0x357085[_0x7459('0x62')])?_0x357085[_0x7459('0x62')]+'\x20'+_0x357085['Last_Name']:_0x357085['Last_Name'],'id':_0x357085['id']};_0x4bbff1[_0x7459('0x65')]=_[_0x7459('0x46')](_0x357085[_0x7459('0x4d')]);}if(_0x53c755[_0x7459('0x66')]){_0x4bbff1[_0x7459('0x67')]=moment[_0x7459('0x68')](parseInt(_0x53c755[_0x7459('0x66')])*0x3e8)['format'](_0x7459('0x69'));}else if(_0x53c755[_0x7459('0x6a')]&&_0x53c755[_0x7459('0x6b')]){_0x4bbff1[_0x7459('0x67')]=moment[_0x7459('0x68')](moment(_0x53c755[_0x7459('0x6b')],_0x7459('0x6c'))['diff'](moment(_0x53c755[_0x7459('0x6d')],'YYYY-MM-DDTHH:mm:ss')))[_0x7459('0x6e')](_0x7459('0x69'));}switch(_0x53c755[_0x7459('0x6f')]){case _0x7459('0x70'):_0x4bbff1[_0x7459('0x71')]=_0x7459('0x72');break;case _0x7459('0x73'):case'connect':_0x4bbff1['Call_Result']=_0x7459('0x74');break;case _0x7459('0x75'):_0x4bbff1[_0x7459('0x71')]=_0x7459('0x76');break;case'abandoned':_0x4bbff1[_0x7459('0x71')]=_0x7459('0x77');break;case'timeout':_0x4bbff1[_0x7459('0x71')]=_0x7459('0x78');default:}_0x4bbff1[_0x7459('0x79')]=(_0x5e9b77===_0x7459('0x7a')?moment(_0x53c755[_0x7459('0x6d')])[_0x7459('0x6e')](_0x7459('0x6c')):moment(_0x53c755['agentcalledAt'])[_0x7459('0x6e')](_0x7459('0x6c')))||moment()[_0x7459('0x6e')](_0x7459('0x6c'));_0x4bbff1[_0x7459('0x7b')]=_0x5e9b77||_0x7459('0x7c');_0x4bbff1=_['merge'](_0x4bbff1,getCustomFields(_0x52523c[_0x7459('0x7d')],_0x53c755));return request({'method':_0x7459('0x27'),'uri':_0x7459('0x44')+_0x10ec2f+_0x7459('0x7e'),'headers':{'Authorization':_0x7459('0x35')+_0x730191},'body':{'data':[_0x4bbff1]},'json':!![]})[_0x7459('0x36')](function(_0x54c29d){if(_0x54c29d&&_0x54c29d[_0x7459('0x43')][0x0]['code']===_0x7459('0x4b')){logger[_0x7459('0x30')](_0x7459('0x7f'));return{'id':_0x54c29d['data'][0x0]['details']['id']};}})[_0x7459('0x2d')](function(_0x492ef3){logger[_0x7459('0x30')](_0x7459('0x80'),_0x492ef3[_0x7459('0x81')]);console[_0x7459('0x4f')](_0x7459('0x80'),_0x492ef3);});}exports[_0x7459('0x82')]=function(_0x3d165b,_0x514f11,_0x4fdafc,_0xb05ca6,_0x1fccc3,_0x1d021e){var _0x1e6e54,_0x2839b0,_0x13149a;_0x1d021e[_0x7459('0x83')]=intUtil[_0x7459('0x84')](_0x1d021e[_0x7459('0x83')]);_0x1d021e[_0x7459('0x85')]=intUtil[_0x7459('0x84')](_0x1d021e[_0x7459('0x85')]);if(_0x1fccc3&&_0x1fccc3[_0x7459('0x86')]){logger[_0x7459('0x30')](_0x7459('0x87'),_0x7459('0x88'));_0x514f11[_0x7459('0x89')]=_0x1d021e[_0x7459('0x85')]+_0x7459('0x8a')+_0x514f11[_0x7459('0x8b')]+_0x7459('0x8c')+md5(_0x514f11[_0x7459('0x8b')]);}else{_0x514f11[_0x7459('0x89')]='';}var _0x3b3119=_0x1d021e[_0x7459('0x83')]===_0x7459('0x8d')?'eu':_0x7459('0x8e');return getAccessToken(_0x1d021e)[_0x7459('0x36')](function(_0xee8eaf){_0x13149a=_0xee8eaf;return getUser(_0x13149a,_0x3b3119,_0x1d021e,_0xb05ca6[_0x7459('0x3a')]);})['then'](function(_0x330329){_0x1e6e54=_0x330329;logger[_0x7459('0x30')](_0x7459('0x8f'),_0x1e6e54['id']);return getEndUser(_0x13149a,_0x3b3119,_0x1d021e,_0x514f11['calleridname'],_0x514f11[_0x7459('0x90')],_0x1e6e54,_0x4fdafc);})[_0x7459('0x36')](function(_0x2dd9ad){_0x2839b0=_0x2dd9ad;return getCall(_0x13149a,_0x3b3119,_0x1d021e,_0x1e6e54,_0x2839b0,_0x4fdafc,_0x514f11,'Inbound');})['then'](function(_0x1f7d30){if(_0x1f7d30){logger['info']('The\x20Call\x20ID\x20is:',_0x1f7d30['id']);logger[_0x7459('0x30')](_0x7459('0x87'),'Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...');emit(util[_0x7459('0x6e')](_0x7459('0x91'),_0xb05ca6['name']),_0x7459('0x92'),{'uri':_0x7459('0x93')+_0x1d021e[_0x7459('0x83')]+_0x7459('0x94')+_0x1f7d30['id']});}})[_0x7459('0x2d')](function(_0x1e65a3){logger[_0x7459('0x2e')](_0x7459('0x87'),JSON['stringify'](_0x1e65a3));});};exports[_0x7459('0x7a')]=function(_0x462964,_0x4ab9c7,_0x141c3c,_0x59555f,_0x338340,_0x1007d0,_0x1209a5){var _0x5f12ef,_0x30eb74,_0x3812e3;_0x1007d0['host']=intUtil[_0x7459('0x84')](_0x1007d0[_0x7459('0x83')]);_0x1007d0[_0x7459('0x85')]=intUtil[_0x7459('0x84')](_0x1007d0[_0x7459('0x85')]);if(_0x1209a5&&_0x1209a5[_0x7459('0x95')]&&_0x1209a5['recordingFormat']!==_0x7459('0x96')){logger['info'](_0x7459('0x97'),_0x7459('0x88'));_0x4ab9c7[_0x7459('0x89')]=_0x1007d0['serverUrl']+_0x7459('0x8a')+_0x4ab9c7[_0x7459('0x8b')]+'/downloads?type=uniqueid&token='+md5(_0x4ab9c7[_0x7459('0x8b')]);}var _0x529457=_0x1007d0[_0x7459('0x83')]==='zoho.eu'?'eu':_0x7459('0x8e');return getAccessToken(_0x1007d0)[_0x7459('0x36')](function(_0x288b3a){_0x3812e3=_0x288b3a;return getUser(_0x3812e3,_0x529457,_0x1007d0,_0x59555f['email']);})[_0x7459('0x36')](function(_0xa5bb95){_0x5f12ef=_0xa5bb95;logger['info'](_0x7459('0x8f'),_0x5f12ef['id']);return getEndUser(_0x3812e3,_0x529457,_0x1007d0,_0x4ab9c7[_0x7459('0x98')],_0x4ab9c7[_0x7459('0x99')],_0x5f12ef,_0x141c3c);})[_0x7459('0x36')](function(_0x52b55a){_0x30eb74=_0x52b55a;return getCall(_0x3812e3,_0x529457,_0x1007d0,_0x5f12ef,_0x30eb74,_0x141c3c,_0x4ab9c7,_0x7459('0x9a'));})[_0x7459('0x36')](function(_0x1e217c){if(_0x1e217c){logger[_0x7459('0x30')](_0x7459('0x9b'),_0x1e217c['id']);logger[_0x7459('0x30')](_0x7459('0x97'),_0x7459('0x9c'));emit(util[_0x7459('0x6e')]('user:%s',_0x59555f[_0x7459('0x1b')]),_0x7459('0x92'),{'uri':_0x7459('0x93')+_0x1007d0[_0x7459('0x83')]+_0x7459('0x94')+_0x1e217c['id']});}})[_0x7459('0x2d')](function(_0x53b066){logger['error'](_0x7459('0x97'),JSON[_0x7459('0x40')](_0x53b066));});};exports[_0x7459('0x9d')]=function(_0x307d37,_0x419586,_0x51408f,_0xd725c6,_0x5ad9d0,_0x1f37cf){var _0x2f9a67,_0x4ab7a7,_0x52c9ad;_0x1f37cf[_0x7459('0x83')]=intUtil[_0x7459('0x84')](_0x1f37cf[_0x7459('0x83')]);_0x1f37cf[_0x7459('0x85')]=intUtil['stripTrailingSlash'](_0x1f37cf['serverUrl']);if(_0x5ad9d0&&_0x5ad9d0[_0x7459('0x86')]){logger[_0x7459('0x30')]('['+_0x419586['lastevent'][_0x7459('0x9e')]()+']','Recording\x20is\x20enabled!');_0x419586['recordingURL']=_0x1f37cf[_0x7459('0x85')]+_0x7459('0x8a')+_0x419586[_0x7459('0x8b')]+'/downloads?type=uniqueid&token='+md5(_0x419586[_0x7459('0x8b')]);}else{_0x419586['recordingURL']='';}var _0x5582ba=_0x1f37cf['host']===_0x7459('0x8d')?'eu':'com';return getAccessToken(_0x1f37cf)['then'](function(_0x1143a0){_0x52c9ad=_0x1143a0;return getUser(_0x52c9ad,_0x5582ba,_0x1f37cf);})[_0x7459('0x36')](function(_0x14ef86){_0x2f9a67=_0x14ef86;logger[_0x7459('0x30')]('The\x20User\x20ID\x20is:',_0x2f9a67['id']);return getEndUser(_0x52c9ad,_0x5582ba,_0x1f37cf,_0x419586[_0x7459('0x9f')],_0x419586[_0x7459('0x90')],_0x2f9a67,_0x51408f);})[_0x7459('0x36')](function(_0x1377b9){_0x4ab7a7=_0x1377b9;return getCall(_0x52c9ad,_0x5582ba,_0x1f37cf,_0x2f9a67,_0x4ab7a7,_0x51408f,_0x419586,_0x7459('0x7c'));})[_0x7459('0x36')](function(_0x2b76f8){if(_0x2b76f8){logger['info'](_0x7459('0x9b'),_0x2b76f8['id']);}})[_0x7459('0x2d')](function(_0xc5e0e7){logger[_0x7459('0x2e')]('['+_0x419586['lastevent']['toUpperCase']()+']',JSON[_0x7459('0x40')](_0xc5e0e7));});};