b85cd00fe33905143f3edbfcefb6a40d3c066a41
[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 _0xb903=['uri','/crm/v2/Contacts/search?criteria=((Phone:equals:','Contacts','Leads','nothing','contact','lead','Owner','Subject','getString','Subjects','Description','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','Call_Duration','utc','talktime','mm:ss','answertime','endtime','diff','starttime','YYYY-MM-DDTHH:mm:ss','lastevent','called','Call_Result','Called','connect','rejected','abandoned','Abandoned','timeout','Timeout','Call_Start_Time','agentcalledAt','Inbound','merge','Fields','/crm/v2/Calls','Call\x20created!','details','err','stack','queue','host','stripTrailingSlash','serverUrl','Recording\x20is\x20enabled!','recordingURL','/api/voice/recordings/','uniqueid','/downloads?type=uniqueid&token=','zoho.eu','com','email','The\x20User\x20ID\x20is:','calleridname','calleridnum','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','trigger:browser:url','https://crm.','/crm/EntityInfo.do?module=Calls&id=','[QUEUE]','outbound','recordingFormat','none','[OUTBOUND]','destcalleridname','Outbound','user:%s','unmanaged','monitor_format','toUpperCase','lodash','request-promise','md5','util','moment','ioredis','bluebird','../../../../config/environment','../../../../config/logger','zoho','redis','forEach','string','picklist','type','content','variable','variableName','idField','toString','customVariable','name','toLowerCase','Variable','indexOf','split','isNil','access_token','isBefore','expires_in','zone','https://accounts.zoho.com','https://accounts.zoho.com.au','https://accounts.zoho.eu','https://accounts.zoho.in','https://accounts.zoho.com.cn','POST','/oauth/v2/token','refreshToken','clientId','refresh_token','then','add','seconds','catch','Failing\x20creating\x20the\x20access_token','info','Search\x20user','GET','format','Zoho-oauthtoken\x20','users','findIndex','Agent\x20found!','Administrator','user','profile','Using\x20the\x20admin\x20account!','The\x20failing\x20result\x20is','stringify','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','error','data','enduserType','https://www.zohoapis.','/crm/v2/','startCase','moduleCreate','role','first_name','last_name','code','SUCCESS','Error:\x20','log','CREATE\x20ERROR'];(function(_0x3dd15e,_0x1f0015){var _0x231fd0=function(_0x4f680a){while(--_0x4f680a){_0x3dd15e['push'](_0x3dd15e['shift']());}};_0x231fd0(++_0x1f0015);}(_0xb903,0x185));var _0x3b90=function(_0x1eba2b,_0x3f8e79){_0x1eba2b=_0x1eba2b-0x0;var _0xf2f66c=_0xb903[_0x1eba2b];return _0xf2f66c;};'use strict';var _=require(_0x3b90('0x0'));var rp=require(_0x3b90('0x1'));var md5=require(_0x3b90('0x2'));var util=require(_0x3b90('0x3'));var intUtil=require('./util');var moment=require(_0x3b90('0x4'));var Redis=require(_0x3b90('0x5'));var BPromise=require(_0x3b90('0x6'));var config=require(_0x3b90('0x7'));var logger=require(_0x3b90('0x8'))(_0x3b90('0x9'));config[_0x3b90('0xa')]=_['defaults'](config[_0x3b90('0xa')],{'host':'localhost','port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0x3b90('0xa')]));function emit(_0x2e4c06,_0x42efe8,_0x1b1fbf){io['to'](_0x2e4c06)['emit'](_0x42efe8,_0x1b1fbf);}function request(_0x5cda1d){logger['debug']('[HTTP]',JSON['stringify'](_0x5cda1d));return rp(_0x5cda1d);}function getCustomFields(_0x55db3f,_0x336913){var _0x5af39c={};if(_0x55db3f['length']>0x0){_[_0x3b90('0xb')](_0x55db3f,function(_0x233509){if(_['includes']([_0x3b90('0xc'),_0x3b90('0xd')],_0x233509[_0x3b90('0xe')])&&_0x233509['idField']){_0x5af39c[_0x233509['idField']]=_0x233509[_0x3b90('0xf')]['toString']();}else if(_0x233509['type']===_0x3b90('0x10')&&_0x233509[_0x3b90('0x11')]&&_0x233509['idField']&&_0x336913[_0x233509['variableName']]){_0x5af39c[_0x233509[_0x3b90('0x12')]]=_0x336913[_0x233509[_0x3b90('0x11')]][_0x3b90('0x13')]();}else if(_0x233509[_0x3b90('0xe')]===_0x3b90('0x14')&&_0x233509['Variable']&&_0x233509['Variable'][_0x3b90('0x15')]&&_0x233509[_0x3b90('0x12')]&&_0x336913[_0x233509['Variable'][_0x3b90('0x15')][_0x3b90('0x16')]()]){_0x5af39c[_0x233509[_0x3b90('0x12')]]=_0x336913[_0x233509[_0x3b90('0x17')]['name'][_0x3b90('0x16')]()]['toString']();}});}return _0x5af39c;}function getName(_0xd8d873){if(_0xd8d873[_0x3b90('0x18')]('\x20')>0x0){var _0x535894=_0xd8d873[_0x3b90('0x19')](/ (.+)/);if(_0x535894[0x1]){return _0x535894;}}return[_0xd8d873,_0xd8d873];}var accountsTokens={};function getAccessToken(_0x12e1cf){return new Promise(function(_0x3642c0,_0x3ce411){if(!_[_0x3b90('0x1a')](accountsTokens[_0x12e1cf['id']])&&!_[_0x3b90('0x1a')](accountsTokens[_0x12e1cf['id']][_0x3b90('0x1b')])){if(moment()[_0x3b90('0x1c')](accountsTokens[_0x12e1cf['id']][_0x3b90('0x1d')])){_0x3642c0(accountsTokens[_0x12e1cf['id']][_0x3b90('0x1b')]);}}var _0x4e2175;switch(_0x12e1cf[_0x3b90('0x1e')]){case'US':_0x4e2175=_0x3b90('0x1f');break;case'AU':_0x4e2175=_0x3b90('0x20');break;case'EU':_0x4e2175=_0x3b90('0x21');break;case'IN':_0x4e2175=_0x3b90('0x22');break;case'CN':_0x4e2175=_0x3b90('0x23');break;default:_0x4e2175='https://accounts.zoho.eu';break;}var _0x4b308c={'method':_0x3b90('0x24'),'uri':_0x4e2175+_0x3b90('0x25'),'qs':{'refresh_token':_0x12e1cf[_0x3b90('0x26')],'client_id':_0x12e1cf[_0x3b90('0x27')],'client_secret':_0x12e1cf['clientSecret'],'grant_type':_0x3b90('0x28')},'json':!![]};return rp(_0x4b308c)[_0x3b90('0x29')](function(_0x1787d1){accountsTokens[_0x12e1cf['id']]={'access_token':_0x1787d1['access_token'],'expires_in':moment()[_0x3b90('0x2a')](_0x1787d1[_0x3b90('0x1d')],_0x3b90('0x2b'))};_0x3642c0(_0x1787d1[_0x3b90('0x1b')]);})[_0x3b90('0x2c')](function(_0x7adf75){logger['error'](_0x3b90('0x2d'),_0x7adf75['stack']);_0x3ce411(_0x7adf75);});});}function getUser(_0xaf453c,_0x9891e4,_0x1a193e,_0x38eed0){logger[_0x3b90('0x2e')](_0x3b90('0x2f'));return request({'method':_0x3b90('0x30'),'uri':util[_0x3b90('0x31')]('https://www.zohoapis.%s/crm/v2/users',_0x9891e4),'qs':{'type':'ActiveUsers'},'headers':{'Authorization':_0x3b90('0x32')+_0xaf453c},'json':!![]})[_0x3b90('0x29')](function(_0x23484a){if(_0x23484a[_0x3b90('0x33')]){var _0x522ede=-0x1;if(_['isArrayLikeObject'](_0x23484a[_0x3b90('0x33')])){if(!_[_0x3b90('0x1a')](_0x38eed0)){_0x522ede=_[_0x3b90('0x34')](_0x23484a['users'],function(_0x41bd39){return _0x41bd39['email']===_0x38eed0;});}if(_0x522ede>=0x0){logger['info'](_0x3b90('0x35'));}else{logger[_0x3b90('0x2e')]('Using\x20the\x20admin\x20account!');_0x522ede=_[_0x3b90('0x34')](_0x23484a[_0x3b90('0x33')],function(_0x3e30b8){return _0x3e30b8['profile']['name']===_0x3b90('0x36');});}return _0x23484a[_0x3b90('0x33')][_0x522ede];}else{if(_0x23484a[_0x3b90('0x37')][_0x3b90('0x38')]['name']==='Administrator'){logger[_0x3b90('0x2e')](_0x3b90('0x39'));user=_0x23484a['user'];return user;}else{logger['error'](_0x3b90('0x3a'),JSON[_0x3b90('0x3b')](_0x23484a));throw new Error(_0x3b90('0x3c')+JSON[_0x3b90('0x3b')](_0x23484a));}}}else{logger['error'](_0x3b90('0x3a'),JSON['stringify'](_0x23484a));throw new Error(_0x3b90('0x3c')+JSON[_0x3b90('0x3b')](_0x23484a));}})[_0x3b90('0x2c')](function(_0x20abf8){console[_0x3b90('0x3d')](_0x20abf8);});}function getZohoUser(_0x3bf148,_0x96f7f3){return new BPromise(function(_0x534bea,_0x17aeb8){request(_0x3bf148)[_0x3b90('0x29')](function(_0x2fd30c){var _0x303922=null;if(_0x2fd30c){_0x303922=_0x2fd30c[_0x3b90('0x3e')][0x0];_0x303922[_0x3b90('0x3f')]=_0x96f7f3;}_0x534bea(_0x303922);})[_0x3b90('0x2c')](function(_0x3b6194){_0x17aeb8(_0x3b6194);});});}function createEndUser(_0x356e14,_0x5063b9,_0x369d0d,_0x1b915d,_0x40ce3a,_0x23cf0f){var _0x369d0d=getName(_0x369d0d);return request({'method':_0x3b90('0x24'),'uri':_0x3b90('0x40')+_0x5063b9+_0x3b90('0x41')+_[_0x3b90('0x42')](_0x23cf0f[_0x3b90('0x43')])+'s','body':{'data':[{'Last_Name':_0x369d0d[0x1],'First_Name':_0x369d0d[0x0],'Phone':_0x1b915d,'Owner':{'name':!_[_0x3b90('0x1a')](_0x40ce3a[_0x3b90('0x44')][_0x3b90('0x15')])?_0x40ce3a[_0x3b90('0x44')][_0x3b90('0x15')]:!_[_0x3b90('0x1a')](_0x40ce3a[_0x3b90('0x45')])?_0x40ce3a[_0x3b90('0x45')]+'\x20'+_0x40ce3a[_0x3b90('0x46')]:_0x40ce3a[_0x3b90('0x46')],'id':_0x40ce3a['id']}}]},'headers':{'Authorization':_0x3b90('0x32')+_0x356e14},'json':!![]})['then'](function(_0x28d70b){if(_0x28d70b&&_0x28d70b[_0x3b90('0x3e')][0x0][_0x3b90('0x47')]===_0x3b90('0x48')){var _0x5a48a9=_0x28d70b[_0x3b90('0x3e')][0x0]['details'];_0x5a48a9['enduserType']=_[_0x3b90('0x42')](_0x23cf0f[_0x3b90('0x43')])+'s';return _0x5a48a9;}logger['error'](_0x3b90('0x3a'),JSON[_0x3b90('0x3b')](data));throw new Error(_0x3b90('0x49')+JSON[_0x3b90('0x3b')](data));})[_0x3b90('0x2c')](function(_0x3fd5a1){console[_0x3b90('0x4a')](_0x3b90('0x4b'),_0x3fd5a1);});}function getEndUser(_0x28882e,_0x59b693,_0x3f71b0,_0x2e8a90,_0x4df41c,_0x1e9a21,_0x12e061){var _0x335c55={'method':_0x3b90('0x30'),'uri':'','headers':{'Authorization':_0x3b90('0x32')+_0x28882e},'json':!![]};switch(_0x12e061['moduleSearch']){case'contact_lead':_0x335c55[_0x3b90('0x4c')]='https://www.zohoapis.'+_0x59b693+_0x3b90('0x4d')+_0x4df41c+'))';return getZohoUser(_0x335c55,_0x3b90('0x4e'))[_0x3b90('0x29')](function(_0x27d0a8){if(_0x27d0a8)return _0x27d0a8;_0x335c55[_0x3b90('0x4c')]='https://www.zohoapis.'+_0x59b693+'/crm/v2/Leads/search?criteria=((Phone:equals:'+_0x4df41c+'))';return getZohoUser(_0x335c55,_0x3b90('0x4f'))[_0x3b90('0x29')](function(_0x9e2ee5){if(_0x9e2ee5)return _0x9e2ee5;if(_0x12e061['moduleCreate']!=_0x3b90('0x50')){return createEndUser(_0x28882e,_0x59b693,_0x2e8a90,_0x4df41c,_0x1e9a21,_0x12e061);}else{return{};}});});break;case _0x3b90('0x51'):_0x335c55[_0x3b90('0x4c')]=_0x3b90('0x40')+_0x59b693+_0x3b90('0x4d')+_0x4df41c+'))';return getZohoUser(_0x335c55,_0x3b90('0x4e'))[_0x3b90('0x29')](function(_0x13b364){if(_0x13b364)return _0x13b364;if(_0x12e061[_0x3b90('0x43')]!='nothing'){return createEndUser(_0x28882e,_0x59b693,_0x2e8a90,_0x4df41c,_0x1e9a21,_0x12e061);}else{return{};}});break;case _0x3b90('0x52'):_0x335c55[_0x3b90('0x4c')]=_0x3b90('0x40')+_0x59b693+'/crm/v2/Leads/search?criteria=((Phone:equals:'+_0x4df41c+'))';return getZohoUser(_0x335c55,_0x3b90('0x4f'))['then'](function(_0x288fbb){if(_0x288fbb)return _0x288fbb;if(_0x12e061[_0x3b90('0x43')]!=_0x3b90('0x50')){return createEndUser(_0x28882e,_0x59b693,_0x2e8a90,_0x4df41c,_0x1e9a21,_0x12e061);}else{return{};}});break;}}function getCall(_0x56f95d,_0x2a3fe8,_0x1ec976,_0x5334b5,_0x499ec1,_0x9ff1f4,_0x24337e,_0x1eb16e){logger[_0x3b90('0x2e')]('Creating\x20new\x20call...');var _0x5ee7e2={};_0x5ee7e2[_0x3b90('0x53')]={'name':!_[_0x3b90('0x1a')](_0x5334b5[_0x3b90('0x44')][_0x3b90('0x15')])&&!_[_0x3b90('0x1a')](_0x5334b5[_0x3b90('0x38')][_0x3b90('0x15')])&&_0x5334b5[_0x3b90('0x38')][_0x3b90('0x15')]==='administrator'?_0x5334b5[_0x3b90('0x44')][_0x3b90('0x15')]:!_['isNil'](_0x5334b5[_0x3b90('0x45')])?_0x5334b5[_0x3b90('0x45')]+'\x20'+_0x5334b5['last_name']:_0x5334b5[_0x3b90('0x46')],'id':_0x5334b5['id']};_0x5ee7e2[_0x3b90('0x54')]=intUtil[_0x3b90('0x55')](_0x9ff1f4[_0x3b90('0x56')],_0x24337e,'\x20');_0x5ee7e2[_0x3b90('0x57')]=intUtil[_0x3b90('0x55')](_0x9ff1f4[_0x3b90('0x58')],_0x24337e,'\x0a');if(_0x499ec1['enduserType']===_0x3b90('0x4e')){_0x5ee7e2[_0x3b90('0x59')]={'name':!_[_0x3b90('0x1a')](_0x499ec1[_0x3b90('0x5a')])?_0x499ec1[_0x3b90('0x5a')]:!_[_0x3b90('0x1a')](_0x499ec1[_0x3b90('0x5b')])?_0x499ec1[_0x3b90('0x5b')]+'\x20'+_0x499ec1[_0x3b90('0x5c')]:_0x499ec1[_0x3b90('0x5c')],'id':_0x499ec1['id']};}if(_0x499ec1[_0x3b90('0x3f')]===_0x3b90('0x4f')){_0x5ee7e2[_0x3b90('0x5d')]={'name':!_[_0x3b90('0x1a')](_0x499ec1[_0x3b90('0x5a')])?_0x499ec1['Full_Name']:!_[_0x3b90('0x1a')](_0x499ec1['First_Name'])?_0x499ec1[_0x3b90('0x5b')]+'\x20'+_0x499ec1[_0x3b90('0x5c')]:_0x499ec1[_0x3b90('0x5c')],'id':_0x499ec1['id']};_0x5ee7e2[_0x3b90('0x5e')]=_[_0x3b90('0x42')](_0x499ec1[_0x3b90('0x3f')]);}if(_0x24337e['talktime']){_0x5ee7e2[_0x3b90('0x5f')]=moment[_0x3b90('0x60')](parseInt(_0x24337e[_0x3b90('0x61')])*0x3e8)[_0x3b90('0x31')](_0x3b90('0x62'));}else if(_0x24337e[_0x3b90('0x63')]&&_0x24337e['endtime']){_0x5ee7e2[_0x3b90('0x5f')]=moment[_0x3b90('0x60')](moment(_0x24337e[_0x3b90('0x64')],'YYYY-MM-DDTHH:mm:ss')[_0x3b90('0x65')](moment(_0x24337e[_0x3b90('0x66')],_0x3b90('0x67'))))[_0x3b90('0x31')](_0x3b90('0x62'));}switch(_0x24337e[_0x3b90('0x68')]){case _0x3b90('0x69'):_0x5ee7e2[_0x3b90('0x6a')]=_0x3b90('0x6b');break;case'complete':case _0x3b90('0x6c'):_0x5ee7e2['Call_Result']='Answered';break;case _0x3b90('0x6d'):_0x5ee7e2[_0x3b90('0x6a')]='Rejected';break;case _0x3b90('0x6e'):_0x5ee7e2[_0x3b90('0x6a')]=_0x3b90('0x6f');break;case _0x3b90('0x70'):_0x5ee7e2[_0x3b90('0x6a')]=_0x3b90('0x71');default:}_0x5ee7e2[_0x3b90('0x72')]=(_0x1eb16e==='outbound'?moment(_0x24337e['starttime'])[_0x3b90('0x31')]('YYYY-MM-DDTHH:mm:ss'):moment(_0x24337e[_0x3b90('0x73')])['format'](_0x3b90('0x67')))||moment()['format']('YYYY-MM-DDTHH:mm:ss');_0x5ee7e2['Call_Type']=_0x1eb16e||_0x3b90('0x74');_0x5ee7e2=_[_0x3b90('0x75')](_0x5ee7e2,getCustomFields(_0x9ff1f4[_0x3b90('0x76')],_0x24337e));return request({'method':_0x3b90('0x24'),'uri':_0x3b90('0x40')+_0x2a3fe8+_0x3b90('0x77'),'headers':{'Authorization':_0x3b90('0x32')+_0x56f95d},'body':{'data':[_0x5ee7e2]},'json':!![]})['then'](function(_0x5acf97){if(_0x5acf97&&_0x5acf97['data'][0x0][_0x3b90('0x47')]===_0x3b90('0x48')){logger['info'](_0x3b90('0x78'));return{'id':_0x5acf97[_0x3b90('0x3e')][0x0][_0x3b90('0x79')]['id']};}})[_0x3b90('0x2c')](function(_0x468ddb){logger[_0x3b90('0x2e')](_0x3b90('0x7a'),_0x468ddb[_0x3b90('0x7b')]);console[_0x3b90('0x4a')]('err',_0x468ddb);});}exports[_0x3b90('0x7c')]=function(_0x55dddd,_0x2bbbac,_0x2ddd93,_0x4b2c0f,_0x5b34f5,_0x389989){var _0x4337f0,_0x3f0f85,_0x2318d;_0x389989[_0x3b90('0x7d')]=intUtil[_0x3b90('0x7e')](_0x389989['host']);_0x389989[_0x3b90('0x7f')]=intUtil[_0x3b90('0x7e')](_0x389989[_0x3b90('0x7f')]);if(_0x5b34f5&&_0x5b34f5['monitor_format']){logger[_0x3b90('0x2e')]('[QUEUE]',_0x3b90('0x80'));_0x2bbbac[_0x3b90('0x81')]=_0x389989[_0x3b90('0x7f')]+_0x3b90('0x82')+_0x2bbbac[_0x3b90('0x83')]+_0x3b90('0x84')+md5(_0x2bbbac['uniqueid']);}else{_0x2bbbac[_0x3b90('0x81')]='';}var _0x230567=_0x389989[_0x3b90('0x7d')]===_0x3b90('0x85')?'eu':_0x3b90('0x86');return getAccessToken(_0x389989)[_0x3b90('0x29')](function(_0x23678f){_0x2318d=_0x23678f;return getUser(_0x2318d,_0x230567,_0x389989,_0x4b2c0f[_0x3b90('0x87')]);})['then'](function(_0x5f6bf9){_0x4337f0=_0x5f6bf9;logger[_0x3b90('0x2e')](_0x3b90('0x88'),_0x4337f0['id']);return getEndUser(_0x2318d,_0x230567,_0x389989,_0x2bbbac[_0x3b90('0x89')],_0x2bbbac[_0x3b90('0x8a')],_0x4337f0,_0x2ddd93);})[_0x3b90('0x29')](function(_0x1af213){_0x3f0f85=_0x1af213;return getCall(_0x2318d,_0x230567,_0x389989,_0x4337f0,_0x3f0f85,_0x2ddd93,_0x2bbbac,_0x3b90('0x74'));})['then'](function(_0x5b2469){if(_0x5b2469){logger[_0x3b90('0x2e')](_0x3b90('0x8b'),_0x5b2469['id']);logger[_0x3b90('0x2e')]('[QUEUE]',_0x3b90('0x8c'));emit(util['format']('user:%s',_0x4b2c0f[_0x3b90('0x15')]),_0x3b90('0x8d'),{'uri':_0x3b90('0x8e')+_0x389989[_0x3b90('0x7d')]+_0x3b90('0x8f')+_0x5b2469['id']});}})[_0x3b90('0x2c')](function(_0xb6678a){logger[_0x3b90('0x3d')](_0x3b90('0x90'),JSON[_0x3b90('0x3b')](_0xb6678a));});};exports[_0x3b90('0x91')]=function(_0x3a0a51,_0x2e621a,_0x241d6e,_0x122525,_0x4e8614,_0x212aa4,_0x98d7b0){var _0x4ea0b7,_0x2fa1ed,_0x47a50b;_0x212aa4[_0x3b90('0x7d')]=intUtil[_0x3b90('0x7e')](_0x212aa4[_0x3b90('0x7d')]);_0x212aa4['serverUrl']=intUtil[_0x3b90('0x7e')](_0x212aa4[_0x3b90('0x7f')]);if(_0x98d7b0&&_0x98d7b0[_0x3b90('0x92')]&&_0x98d7b0[_0x3b90('0x92')]!==_0x3b90('0x93')){logger[_0x3b90('0x2e')](_0x3b90('0x94'),_0x3b90('0x80'));_0x2e621a[_0x3b90('0x81')]=_0x212aa4[_0x3b90('0x7f')]+_0x3b90('0x82')+_0x2e621a[_0x3b90('0x83')]+'/downloads?type=uniqueid&token='+md5(_0x2e621a['uniqueid']);}var _0x497ea7=_0x212aa4[_0x3b90('0x7d')]===_0x3b90('0x85')?'eu':_0x3b90('0x86');return getAccessToken(_0x212aa4)[_0x3b90('0x29')](function(_0x156ffd){_0x47a50b=_0x156ffd;return getUser(_0x47a50b,_0x497ea7,_0x212aa4,_0x122525[_0x3b90('0x87')]);})[_0x3b90('0x29')](function(_0x3472c8){_0x4ea0b7=_0x3472c8;logger[_0x3b90('0x2e')](_0x3b90('0x88'),_0x4ea0b7['id']);return getEndUser(_0x47a50b,_0x497ea7,_0x212aa4,_0x2e621a[_0x3b90('0x95')],_0x2e621a['destcalleridnum'],_0x4ea0b7,_0x241d6e);})['then'](function(_0x405f12){_0x2fa1ed=_0x405f12;return getCall(_0x47a50b,_0x497ea7,_0x212aa4,_0x4ea0b7,_0x2fa1ed,_0x241d6e,_0x2e621a,_0x3b90('0x96'));})[_0x3b90('0x29')](function(_0x1dc7e8){if(_0x1dc7e8){logger[_0x3b90('0x2e')](_0x3b90('0x8b'),_0x1dc7e8['id']);logger[_0x3b90('0x2e')](_0x3b90('0x94'),_0x3b90('0x8c'));emit(util[_0x3b90('0x31')](_0x3b90('0x97'),_0x122525[_0x3b90('0x15')]),_0x3b90('0x8d'),{'uri':_0x3b90('0x8e')+_0x212aa4[_0x3b90('0x7d')]+_0x3b90('0x8f')+_0x1dc7e8['id']});}})[_0x3b90('0x2c')](function(_0x4603c9){logger['error'](_0x3b90('0x94'),JSON[_0x3b90('0x3b')](_0x4603c9));});};exports[_0x3b90('0x98')]=function(_0x34fdf0,_0x22d7cb,_0x5558f7,_0x27d58d,_0x3148c0,_0x320fc2){var _0x2f5dc0,_0x38af7a,_0x38076d;_0x320fc2['host']=intUtil[_0x3b90('0x7e')](_0x320fc2['host']);_0x320fc2['serverUrl']=intUtil[_0x3b90('0x7e')](_0x320fc2[_0x3b90('0x7f')]);if(_0x3148c0&&_0x3148c0[_0x3b90('0x99')]){logger[_0x3b90('0x2e')]('['+_0x22d7cb[_0x3b90('0x68')]['toUpperCase']()+']',_0x3b90('0x80'));_0x22d7cb[_0x3b90('0x81')]=_0x320fc2[_0x3b90('0x7f')]+_0x3b90('0x82')+_0x22d7cb[_0x3b90('0x83')]+_0x3b90('0x84')+md5(_0x22d7cb[_0x3b90('0x83')]);}else{_0x22d7cb[_0x3b90('0x81')]='';}var _0x2c2e24=_0x320fc2[_0x3b90('0x7d')]===_0x3b90('0x85')?'eu':_0x3b90('0x86');return getAccessToken(_0x320fc2)[_0x3b90('0x29')](function(_0x313b07){_0x38076d=_0x313b07;return getUser(_0x38076d,_0x2c2e24,_0x320fc2);})[_0x3b90('0x29')](function(_0x1af0ea){_0x2f5dc0=_0x1af0ea;logger['info'](_0x3b90('0x88'),_0x2f5dc0['id']);return getEndUser(_0x38076d,_0x2c2e24,_0x320fc2,_0x22d7cb[_0x3b90('0x89')],_0x22d7cb[_0x3b90('0x8a')],_0x2f5dc0,_0x5558f7);})[_0x3b90('0x29')](function(_0x23d3b6){_0x38af7a=_0x23d3b6;return getCall(_0x38076d,_0x2c2e24,_0x320fc2,_0x2f5dc0,_0x38af7a,_0x5558f7,_0x22d7cb,_0x3b90('0x74'));})['then'](function(_0x39f02f){if(_0x39f02f){logger[_0x3b90('0x2e')](_0x3b90('0x8b'),_0x39f02f['id']);}})[_0x3b90('0x2c')](function(_0x1ae34b){logger['error']('['+_0x22d7cb[_0x3b90('0x68')][_0x3b90('0x9a')]()+']',JSON[_0x3b90('0x3b')](_0x1ae34b));});};