8b5e1102e8bb85136a5a28ee0e525b9c24f0c391
[motion2.git] / server / api / cloudProvider / cloudProvider.controller.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 _0x132d=['findAll','rows','service','MicrosoftAzure','decryptString','data3','catch','show','params','keys','find','create','body','Name\x20parameter\x20not\x20specified','Service\x20parameter\x20not\x20specified','values','Invalid\x20service\x20parameter.\x20Allowed\x20values:\x20','join','encryptString','oauth2MicrosoftAuthorize','findOne','user','state','Invalid\x20state\x20parameter','from','toString','ascii','parse','isValidIdToken','oauth2Claims','Unable\x20to\x20validate\x20id_token','getOauth2MicrosoftAccessToken','data5','refresh_token','startRefreshInterval','microsoftAuthorization:success','microsoftAuthorization:error','message','Authentication\x20failed\x20for\x20cloud\x20provider\x20#%s,\x20err:%s','lodash','ioredis','../../components/parsers/qs','../../components/encryptor','redis','localhost','socket.io-emitter','sendStatus','status','end','json','offset','undefined','limit','count','update','then','destroy','error','stack','name','send','padEnd','slice','index','map','rawAttributes','type','key','model','query','filters','intersection','fields','attributes','length','hasOwnProperty','nolimit','order','sort','where','filter','merge','VIRTUAL','options','CloudProvider','includeAll','include'];(function(_0x2712ef,_0x385b2f){var _0x269483=function(_0x26c93a){while(--_0x26c93a){_0x2712ef['push'](_0x2712ef['shift']());}};_0x269483(++_0x385b2f);}(_0x132d,0x12c));var _0xd132=function(_0x1ed0d3,_0x7fceb2){_0x1ed0d3=_0x1ed0d3-0x0;var _0x3a1c39=_0x132d[_0x1ed0d3];return _0x3a1c39;};'use strict';var _=require(_0xd132('0x0'));var Redis=require(_0xd132('0x1'));var qs=require(_0xd132('0x2'));var encryptor=require(_0xd132('0x3'));var config=require('../../config/environment');var logger=require('../../config/logger')('api');var db=require('../../mysqldb')['db'];var oauth=require('./cloudProvider.oauth');config['redis']=_['defaults'](config[_0xd132('0x4')],{'host':_0xd132('0x5'),'port':0x18eb});var socket=require(_0xd132('0x6'))(new Redis(config['redis']));var redis=new Redis(config[_0xd132('0x4')]);function respondWithStatusCode(_0x49f1f7,_0x321ff3){_0x321ff3=_0x321ff3||0xcc;return function(_0x275200){if(_0x275200){return _0x49f1f7[_0xd132('0x7')](_0x321ff3);}return _0x49f1f7[_0xd132('0x8')](_0x321ff3)[_0xd132('0x9')]();};}function respondWithResult(_0x48fba5,_0x108f8c){_0x108f8c=_0x108f8c||0xc8;return function(_0x5cb2cb){if(_0x5cb2cb){return _0x48fba5['status'](_0x108f8c)[_0xd132('0xa')](_0x5cb2cb);}};}function respondWithFilteredResult(_0x351dfe,_0x3db38f){return function(_0x221006){if(_0x221006){var _0x431ca3=typeof _0x3db38f[_0xd132('0xb')]===_0xd132('0xc')&&typeof _0x3db38f[_0xd132('0xd')]===_0xd132('0xc');var _0x19d4f6=_0x221006[_0xd132('0xe')];var _0x7073fe=_0x431ca3?0x0:_0x3db38f['offset'];var _0x36035f=_0x431ca3?_0x221006['count']:_0x3db38f[_0xd132('0xb')]+_0x3db38f[_0xd132('0xd')];var _0x3ca403;if(_0x36035f>=_0x19d4f6){_0x36035f=_0x19d4f6;_0x3ca403=0xc8;}else{_0x3ca403=0xce;}_0x351dfe[_0xd132('0x8')](_0x3ca403);return _0x351dfe['set']('Content-Range',_0x7073fe+'-'+_0x36035f+'/'+_0x19d4f6)[_0xd132('0xa')](_0x221006);}return null;};}function saveUpdates(_0x26a337){return function(_0x51d49d){if(_0x51d49d){return _0x51d49d[_0xd132('0xf')](_0x26a337)[_0xd132('0x10')](function(_0x3e9333){return _0x3e9333;});}return null;};}function removeEntity(_0x19ddb2){return function(_0x3030cc){if(_0x3030cc){return _0x3030cc[_0xd132('0x11')]()[_0xd132('0x10')](function(){_0x19ddb2[_0xd132('0x8')](0xcc)[_0xd132('0x9')]();});}};}function handleEntityNotFound(_0x23a2bf){return function(_0x3c38f3){if(!_0x3c38f3){_0x23a2bf[_0xd132('0x7')](0x194);}return _0x3c38f3;};}function handleError(_0x13abbb,_0x5324c8){_0x5324c8=_0x5324c8||0x1f4;return function(_0x49a2e8){logger[_0xd132('0x12')](_0x49a2e8[_0xd132('0x13')]);if(_0x49a2e8[_0xd132('0x14')]){delete _0x49a2e8[_0xd132('0x14')];}_0x13abbb[_0xd132('0x8')](_0x5324c8)[_0xd132('0x15')](_0x49a2e8);};}function maskClientSecret(_0x1a8f51){return _[_0xd132('0x16')](_0x1a8f51[_0xd132('0x17')](0x0,0x3),0x14,'*');}exports[_0xd132('0x18')]=function(_0x192f5f,_0x4dfa8c){var _0x2829fc={},_0xaf4a85={},_0x4fff1d={'count':0x0,'rows':[]};var _0x42169c=_[_0xd132('0x19')](db['CloudProvider'][_0xd132('0x1a')],function(_0x588ce9){return{'name':_0x588ce9['fieldName'],'type':_0x588ce9[_0xd132('0x1b')][_0xd132('0x1c')]};});_0xaf4a85[_0xd132('0x1d')]=_['map'](_0x42169c,_0xd132('0x14'));_0xaf4a85[_0xd132('0x1e')]=_['keys'](_0x192f5f['query']);_0xaf4a85[_0xd132('0x1f')]=_[_0xd132('0x20')](_0xaf4a85[_0xd132('0x1d')],_0xaf4a85[_0xd132('0x1e')]);_0x2829fc['attributes']=_[_0xd132('0x20')](_0xaf4a85[_0xd132('0x1d')],qs['fields'](_0x192f5f['query'][_0xd132('0x21')]));_0x2829fc[_0xd132('0x22')]=_0x2829fc[_0xd132('0x22')][_0xd132('0x23')]?_0x2829fc['attributes']:_0xaf4a85[_0xd132('0x1d')];if(!_0x192f5f[_0xd132('0x1e')][_0xd132('0x24')](_0xd132('0x25'))){_0x2829fc[_0xd132('0xd')]=qs['limit'](_0x192f5f['query'][_0xd132('0xd')]);_0x2829fc[_0xd132('0xb')]=qs[_0xd132('0xb')](_0x192f5f[_0xd132('0x1e')][_0xd132('0xb')]);}_0x2829fc[_0xd132('0x26')]=qs[_0xd132('0x27')](_0x192f5f[_0xd132('0x1e')]['sort']);_0x2829fc[_0xd132('0x28')]=qs[_0xd132('0x1f')](_['pick'](_0x192f5f[_0xd132('0x1e')],_0xaf4a85['filters']),_0x42169c);if(_0x192f5f[_0xd132('0x1e')][_0xd132('0x29')]){_0x2829fc[_0xd132('0x28')]=_[_0xd132('0x2a')](_0x2829fc[_0xd132('0x28')],{'$or':_[_0xd132('0x19')](_0x42169c,function(_0x306ede){if(_0x306ede[_0xd132('0x1b')]!==_0xd132('0x2b')){var _0xffc9f8={};_0xffc9f8[_0x306ede[_0xd132('0x14')]]={'$like':'%'+_0x192f5f[_0xd132('0x1e')][_0xd132('0x29')]+'%'};return _0xffc9f8;}})});}_0x2829fc=_['merge']({},_0x2829fc,_0x192f5f[_0xd132('0x2c')]);var _0x4c0c0c={'where':_0x2829fc[_0xd132('0x28')]};return db[_0xd132('0x2d')][_0xd132('0xe')](_0x4c0c0c)['then'](function(_0x5af103){_0x4fff1d['count']=_0x5af103;if(_0x192f5f[_0xd132('0x1e')][_0xd132('0x2e')]){_0x2829fc[_0xd132('0x2f')]=[{'all':!![]}];}return db['CloudProvider'][_0xd132('0x30')](_0x2829fc);})['then'](function(_0x39a48f){_0x4fff1d[_0xd132('0x31')]=_[_0xd132('0x19')](_0x39a48f,function(_0x2cf57c){if(_0x2cf57c[_0xd132('0x32')]===_0xd132('0x33')){var _0x895e1d=encryptor[_0xd132('0x34')](_0x2cf57c[_0xd132('0x35')]);_0x2cf57c['data3']=maskClientSecret(_0x895e1d);}return _0x2cf57c;});return _0x4fff1d;})[_0xd132('0x10')](respondWithFilteredResult(_0x4dfa8c,_0x2829fc))[_0xd132('0x36')](handleError(_0x4dfa8c,null));};exports[_0xd132('0x37')]=function(_0x34eed5,_0x2f127a){var _0x3e0cf8={'raw':!![],'where':{'id':_0x34eed5[_0xd132('0x38')]['id']}},_0x2f5024={};_0x2f5024[_0xd132('0x1d')]=_[_0xd132('0x39')](db['CloudProvider'][_0xd132('0x1a')]);_0x2f5024[_0xd132('0x1e')]=_[_0xd132('0x39')](_0x34eed5['query']);_0x2f5024['filters']=_['intersection'](_0x2f5024[_0xd132('0x1d')],_0x2f5024[_0xd132('0x1e')]);_0x3e0cf8[_0xd132('0x22')]=_[_0xd132('0x20')](_0x2f5024['model'],qs['fields'](_0x34eed5[_0xd132('0x1e')][_0xd132('0x21')]));_0x3e0cf8['attributes']=_0x3e0cf8['attributes'][_0xd132('0x23')]?_0x3e0cf8[_0xd132('0x22')]:_0x2f5024[_0xd132('0x1d')];if(_0x34eed5[_0xd132('0x1e')]['includeAll']){_0x3e0cf8[_0xd132('0x2f')]=[{'all':!![]}];}_0x3e0cf8=_[_0xd132('0x2a')]({},_0x3e0cf8,_0x34eed5['options']);return db[_0xd132('0x2d')][_0xd132('0x3a')](_0x3e0cf8)['then'](handleEntityNotFound(_0x2f127a,null))[_0xd132('0x10')](function(_0x5147f2){if(_0x5147f2[_0xd132('0x32')]==='MicrosoftAzure'){var _0x120f66=encryptor[_0xd132('0x34')](_0x5147f2[_0xd132('0x35')]);_0x5147f2[_0xd132('0x35')]=maskClientSecret(_0x120f66);}return _0x5147f2;})[_0xd132('0x10')](respondWithResult(_0x2f127a,null))[_0xd132('0x36')](handleError(_0x2f127a,null));};exports[_0xd132('0x3b')]=function(_0x18e532,_0x2e5f40){if(!_0x18e532[_0xd132('0x3c')][_0xd132('0x14')])throw new Error(_0xd132('0x3d'));if(!_0x18e532[_0xd132('0x3c')][_0xd132('0x32')])throw new Error(_0xd132('0x3e'));var _0x5ac326=db[_0xd132('0x2d')][_0xd132('0x1a')][_0xd132('0x32')][_0xd132('0x3f')];if(!_0x5ac326['includes'](_0x18e532[_0xd132('0x3c')][_0xd132('0x32')]))throw new Error(_0xd132('0x40')+_0x5ac326[_0xd132('0x41')](',\x20'));if(_0x18e532[_0xd132('0x3c')]['service']===_0xd132('0x33')&&_0x18e532[_0xd132('0x3c')][_0xd132('0x35')]){_0x18e532[_0xd132('0x3c')][_0xd132('0x35')]=encryptor[_0xd132('0x42')](_0x18e532[_0xd132('0x3c')][_0xd132('0x35')]);}return db[_0xd132('0x2d')][_0xd132('0x3b')](_0x18e532[_0xd132('0x3c')],{})[_0xd132('0x10')](respondWithResult(_0x2e5f40,0xc9))['catch'](handleError(_0x2e5f40,null));};exports[_0xd132('0xf')]=function(_0x2190a7,_0x1194a6){if(_0x2190a7['body']['id']){delete _0x2190a7[_0xd132('0x3c')]['id'];}return db[_0xd132('0x2d')][_0xd132('0x3a')]({'where':{'id':_0x2190a7['params']['id']}})[_0xd132('0x10')](handleEntityNotFound(_0x1194a6,null))[_0xd132('0x10')](function(_0x2d083f){if(_0x2d083f[_0xd132('0x32')]==='MicrosoftAzure'&&_0x2190a7['body'][_0xd132('0x35')]){_0x2190a7[_0xd132('0x3c')][_0xd132('0x35')]=encryptor[_0xd132('0x42')](_0x2190a7[_0xd132('0x3c')][_0xd132('0x35')]);}return _0x2d083f;})[_0xd132('0x10')](saveUpdates(_0x2190a7[_0xd132('0x3c')],null))[_0xd132('0x10')](respondWithResult(_0x1194a6,null))[_0xd132('0x36')](handleError(_0x1194a6,null));};exports[_0xd132('0x11')]=function(_0x3bd9fc,_0x3b670a){return db['CloudProvider']['find']({'where':{'id':_0x3bd9fc[_0xd132('0x38')]['id']}})[_0xd132('0x10')](handleEntityNotFound(_0x3b670a,null))[_0xd132('0x10')](removeEntity(_0x3b670a,null))[_0xd132('0x36')](handleError(_0x3b670a,null));};exports[_0xd132('0x43')]=function(_0xbdcb7,_0x1f9a8a){return db[_0xd132('0x2d')][_0xd132('0x44')]({'where':{'id':_0xbdcb7[_0xd132('0x38')]['id']},'raw':!![]})[_0xd132('0x10')](function(_0x3de3fb){if(!_0x3de3fb)return _0x1f9a8a[_0xd132('0x7')](0x194);return{'url':oauth['generateMicrosoftAuthorizationUrl'](_0x3de3fb,_0xbdcb7[_0xd132('0x45')]['id'])};})['then'](respondWithResult(_0x1f9a8a,null))['catch'](handleError(_0x1f9a8a,null));};exports['oauth2MicrosoftCallback']=function(_0x4f9837,_0x517ffa){var _0x87836f=_0x4f9837['body'];var _0x2124a2;var _0x1320e8;if(_0x87836f[_0xd132('0x12')])throw _0x87836f;redis['get'](_0x87836f[_0xd132('0x46')])[_0xd132('0x10')](function(_0x3e9de7){if(!_0x3e9de7)throw new Error(_0xd132('0x47'));_0x2124a2=JSON['parse'](_0x3e9de7);var _0x39b1d2=Buffer[_0xd132('0x48')](_0x87836f[_0xd132('0x46')],'base64')[_0xd132('0x49')](_0xd132('0x4a'));_0x1320e8=JSON[_0xd132('0x4b')](_0x39b1d2);if(!oauth[_0xd132('0x4c')](_0x87836f['id_token'],_0x2124a2[_0xd132('0x4d')]))throw new Error(_0xd132('0x4e'));redis['del'](_0x87836f['state']);return oauth[_0xd132('0x4f')](_0x87836f['code'],_0x2124a2);})[_0xd132('0x10')](function(_0x5113c5){_0x2124a2[_0xd132('0x50')]=_0x5113c5['access_token'];_0x2124a2['data6']=_0x5113c5[_0xd132('0x51')];return db[_0xd132('0x2d')][_0xd132('0xf')]({'data5':_0x2124a2['data5'],'data6':_0x2124a2['data6']},{'where':{'id':_0x2124a2['id']}});})[_0xd132('0x10')](function(){oauth[_0xd132('0x52')](_0x2124a2);socket['emit'](_0xd132('0x53'),{'id':_0x1320e8['id']});return;})[_0xd132('0x10')](respondWithStatusCode(_0x517ffa,null))[_0xd132('0x36')](function(_0x6e7720){if(_0x1320e8){socket['emit'](_0xd132('0x54'),{'id':_0x1320e8['id']});}if(!_0x2124a2){logger[_0xd132('0x12')]('Invalid\x20authentication\x20state\x20parameter',_0x6e7720);return _0x517ffa[_0xd132('0x8')](0x1f4)['send'](_0x6e7720[_0xd132('0x55')]);}logger['error'](_0xd132('0x56'),_0x2124a2['id'],JSON['stringify'](_0x6e7720));});};