d635c1b6d9211eed601d175e55f7d076b329eb91
[motion2.git] / server / api / squareOdbc / squareOdbc.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 _0xe111=['attributes','intersection','fields','length','hasOwnProperty','nolimit','order','sort','where','pick','merge','filter','options','includeAll','include','rows','catch','show','find','create','body','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','user','UserProfileSection','userProfileId','autoAssociation','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','params','odbc','dsn','eml-format','rimraf','fast-json-patch','request-promise','moment','bluebird','util','path','sox','to-csv','ejs','lodash','squel','crypto','desk.js','papaparse','ioredis','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','../../config/environment','../../config/license/util','sendStatus','status','end','offset','limit','count','Content-Range','json','apply','reject','save','then','destroy','get','UserProfileResource','error','stack','name','send','index','map','SquareOdbc','rawAttributes','fieldName','type','key','model','keys','query','filters'];(function(_0x378720,_0xa711f1){var _0x47920a=function(_0xc5056){while(--_0xc5056){_0x378720['push'](_0x378720['shift']());}};_0x47920a(++_0xa711f1);}(_0xe111,0x173));var _0x1e11=function(_0x3dd15e,_0x1f0015){_0x3dd15e=_0x3dd15e-0x0;var _0x231fd0=_0xe111[_0x3dd15e];return _0x231fd0;};'use strict';var emlformat=require(_0x1e11('0x0'));var rimraf=require(_0x1e11('0x1'));var zipdir=require('zip-dir');var jsonpatch=require(_0x1e11('0x2'));var rp=require(_0x1e11('0x3'));var moment=require(_0x1e11('0x4'));var BPromise=require(_0x1e11('0x5'));var Mustache=require('mustache');var util=require(_0x1e11('0x6'));var path=require(_0x1e11('0x7'));var sox=require(_0x1e11('0x8'));var csv=require(_0x1e11('0x9'));var ejs=require(_0x1e11('0xa'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0x1e11('0xb'));var squel=require(_0x1e11('0xc'));var crypto=require(_0x1e11('0xd'));var jsforce=require('jsforce');var deskjs=require(_0x1e11('0xe'));var toCsv=require(_0x1e11('0x9'));var querystring=require('querystring');var Papa=require(_0x1e11('0xf'));var Redis=require(_0x1e11('0x10'));var authService=require('../../components/auth/service');var qs=require(_0x1e11('0x11'));var as=require(_0x1e11('0x12'));var hardwareService=require('../../config/license/hardware');var logger=require(_0x1e11('0x13'))(_0x1e11('0x14'));var utils=require(_0x1e11('0x15'));var config=require(_0x1e11('0x16'));var licenseUtil=require(_0x1e11('0x17'));var db=require('../../mysqldb')['db'];function respondWithStatusCode(_0x21a69c,_0x297ce1){_0x297ce1=_0x297ce1||0xcc;return function(_0x54a0e5){if(_0x54a0e5){return _0x21a69c[_0x1e11('0x18')](_0x297ce1);}return _0x21a69c[_0x1e11('0x19')](_0x297ce1)[_0x1e11('0x1a')]();};}function respondWithResult(_0x283b58,_0xbd9c65){_0xbd9c65=_0xbd9c65||0xc8;return function(_0x5e569b){if(_0x5e569b){return _0x283b58['status'](_0xbd9c65)['json'](_0x5e569b);}};}function respondWithFilteredResult(_0x33780b,_0x4de927){return function(_0x23a8c0){if(_0x23a8c0){var _0x11efd2=typeof _0x4de927[_0x1e11('0x1b')]==='undefined'&&typeof _0x4de927[_0x1e11('0x1c')]==='undefined';var _0x72b7d5=_0x23a8c0[_0x1e11('0x1d')];var _0xcf854e=_0x11efd2?0x0:_0x4de927[_0x1e11('0x1b')];var _0x3a5341=_0x11efd2?_0x23a8c0['count']:_0x4de927[_0x1e11('0x1b')]+_0x4de927[_0x1e11('0x1c')];var _0x580f2f;if(_0x3a5341>=_0x72b7d5){_0x3a5341=_0x72b7d5;_0x580f2f=0xc8;}else{_0x580f2f=0xce;}_0x33780b[_0x1e11('0x19')](_0x580f2f);return _0x33780b['set'](_0x1e11('0x1e'),_0xcf854e+'-'+_0x3a5341+'/'+_0x72b7d5)[_0x1e11('0x1f')](_0x23a8c0);}return null;};}function patchUpdates(_0xc31a30){return function(_0x42c77b){try{jsonpatch[_0x1e11('0x20')](_0x42c77b,_0xc31a30,!![]);}catch(_0xca1f78){return BPromise[_0x1e11('0x21')](_0xca1f78);}return _0x42c77b[_0x1e11('0x22')]();};}function saveUpdates(_0x20bca0,_0x1711c4){return function(_0x3289ff){if(_0x3289ff){return _0x3289ff['update'](_0x20bca0)[_0x1e11('0x23')](function(_0x5e0bac){return _0x5e0bac;});}return null;};}function removeEntity(_0x4e20ac,_0x6c7704){return function(_0x2a4ae8){if(_0x2a4ae8){return _0x2a4ae8[_0x1e11('0x24')]()[_0x1e11('0x23')](function(){var _0x5106e3=_0x2a4ae8[_0x1e11('0x25')]({'plain':!![]});var _0xc0c32f='ODBC';return db[_0x1e11('0x26')]['destroy']({'where':{'type':_0xc0c32f,'resourceId':_0x5106e3['id']}})['then'](function(){return _0x2a4ae8;});})['then'](function(){_0x4e20ac[_0x1e11('0x19')](0xcc)[_0x1e11('0x1a')]();});}};}function handleEntityNotFound(_0x2a0636,_0x482714){return function(_0x4b4fd5){if(!_0x4b4fd5){_0x2a0636[_0x1e11('0x18')](0x194);}return _0x4b4fd5;};}function handleError(_0x2ef1d5,_0x46958d){_0x46958d=_0x46958d||0x1f4;return function(_0x29024a){logger[_0x1e11('0x27')](_0x29024a[_0x1e11('0x28')]);if(_0x29024a['name']){delete _0x29024a[_0x1e11('0x29')];}_0x2ef1d5['status'](_0x46958d)[_0x1e11('0x2a')](_0x29024a);};}exports[_0x1e11('0x2b')]=function(_0x3cda37,_0x57459e){var _0xf0c366={},_0x5af41f={},_0x4b171d={'count':0x0,'rows':[]};var _0x25b634=_[_0x1e11('0x2c')](db[_0x1e11('0x2d')][_0x1e11('0x2e')],function(_0x18c830){return{'name':_0x18c830[_0x1e11('0x2f')],'type':_0x18c830[_0x1e11('0x30')][_0x1e11('0x31')]};});_0x5af41f[_0x1e11('0x32')]=_[_0x1e11('0x2c')](_0x25b634,_0x1e11('0x29'));_0x5af41f['query']=_[_0x1e11('0x33')](_0x3cda37[_0x1e11('0x34')]);_0x5af41f[_0x1e11('0x35')]=_['intersection'](_0x5af41f[_0x1e11('0x32')],_0x5af41f[_0x1e11('0x34')]);_0xf0c366[_0x1e11('0x36')]=_[_0x1e11('0x37')](_0x5af41f[_0x1e11('0x32')],qs[_0x1e11('0x38')](_0x3cda37[_0x1e11('0x34')][_0x1e11('0x38')]));_0xf0c366[_0x1e11('0x36')]=_0xf0c366[_0x1e11('0x36')][_0x1e11('0x39')]?_0xf0c366['attributes']:_0x5af41f['model'];if(!_0x3cda37['query'][_0x1e11('0x3a')](_0x1e11('0x3b'))){_0xf0c366[_0x1e11('0x1c')]=qs[_0x1e11('0x1c')](_0x3cda37[_0x1e11('0x34')][_0x1e11('0x1c')]);_0xf0c366[_0x1e11('0x1b')]=qs[_0x1e11('0x1b')](_0x3cda37[_0x1e11('0x34')][_0x1e11('0x1b')]);}_0xf0c366[_0x1e11('0x3c')]=qs[_0x1e11('0x3d')](_0x3cda37[_0x1e11('0x34')][_0x1e11('0x3d')]);_0xf0c366[_0x1e11('0x3e')]=qs[_0x1e11('0x35')](_[_0x1e11('0x3f')](_0x3cda37['query'],_0x5af41f[_0x1e11('0x35')]),_0x25b634);if(_0x3cda37[_0x1e11('0x34')]['filter']){_0xf0c366[_0x1e11('0x3e')]=_[_0x1e11('0x40')](_0xf0c366[_0x1e11('0x3e')],{'$or':_[_0x1e11('0x2c')](_0x25b634,function(_0x526683){if(_0x526683[_0x1e11('0x30')]!=='VIRTUAL'){var _0xda43e8={};_0xda43e8[_0x526683[_0x1e11('0x29')]]={'$like':'%'+_0x3cda37[_0x1e11('0x34')][_0x1e11('0x41')]+'%'};return _0xda43e8;}})});}_0xf0c366=_[_0x1e11('0x40')]({},_0xf0c366,_0x3cda37[_0x1e11('0x42')]);var _0x454d63={'where':_0xf0c366['where']};return db['SquareOdbc'][_0x1e11('0x1d')](_0x454d63)[_0x1e11('0x23')](function(_0x3a5a76){_0x4b171d['count']=_0x3a5a76;if(_0x3cda37['query'][_0x1e11('0x43')]){_0xf0c366[_0x1e11('0x44')]=[{'all':!![]}];}return db[_0x1e11('0x2d')]['findAll'](_0xf0c366);})['then'](function(_0x4fcd9f){_0x4b171d[_0x1e11('0x45')]=_0x4fcd9f;return _0x4b171d;})[_0x1e11('0x23')](respondWithFilteredResult(_0x57459e,_0xf0c366))[_0x1e11('0x46')](handleError(_0x57459e,null));};exports[_0x1e11('0x47')]=function(_0x5342ba,_0xb2ca15){var _0x35e37a={'raw':!![],'where':{'id':_0x5342ba['params']['id']}},_0x5c2762={};_0x5c2762[_0x1e11('0x32')]=_['keys'](db[_0x1e11('0x2d')][_0x1e11('0x2e')]);_0x5c2762[_0x1e11('0x34')]=_['keys'](_0x5342ba[_0x1e11('0x34')]);_0x5c2762['filters']=_[_0x1e11('0x37')](_0x5c2762['model'],_0x5c2762[_0x1e11('0x34')]);_0x35e37a[_0x1e11('0x36')]=_[_0x1e11('0x37')](_0x5c2762[_0x1e11('0x32')],qs[_0x1e11('0x38')](_0x5342ba[_0x1e11('0x34')][_0x1e11('0x38')]));_0x35e37a['attributes']=_0x35e37a['attributes'][_0x1e11('0x39')]?_0x35e37a['attributes']:_0x5c2762[_0x1e11('0x32')];if(_0x5342ba[_0x1e11('0x34')][_0x1e11('0x43')]){_0x35e37a[_0x1e11('0x44')]=[{'all':!![]}];}_0x35e37a=_[_0x1e11('0x40')]({},_0x35e37a,_0x5342ba[_0x1e11('0x42')]);return db[_0x1e11('0x2d')][_0x1e11('0x48')](_0x35e37a)[_0x1e11('0x23')](handleEntityNotFound(_0xb2ca15,null))[_0x1e11('0x23')](respondWithResult(_0xb2ca15,null))[_0x1e11('0x46')](handleError(_0xb2ca15,null));};exports['create']=function(_0x23aa2d,_0x17c524){return db[_0x1e11('0x2d')][_0x1e11('0x49')](_0x23aa2d[_0x1e11('0x4a')],{})['then'](function(_0x449aad){var _0x46dac1=_0x23aa2d['user'][_0x1e11('0x25')]({'plain':!![]});if(!_0x46dac1)throw new Error(_0x1e11('0x4b'));if(_0x46dac1[_0x1e11('0x4c')]===_0x1e11('0x4d')){var _0x5d9e43=_0x449aad[_0x1e11('0x25')]({'plain':!![]});var _0x4b1286='ODBC';return db[_0x1e11('0x4e')][_0x1e11('0x48')]({'where':{'name':_0x4b1286,'userProfileId':_0x46dac1[_0x1e11('0x4f')]},'raw':!![]})[_0x1e11('0x23')](function(_0x20c94d){if(_0x20c94d&&_0x20c94d[_0x1e11('0x50')]===0x0){return db[_0x1e11('0x26')][_0x1e11('0x49')]({'name':_0x5d9e43[_0x1e11('0x29')],'resourceId':_0x5d9e43['id'],'type':_0x20c94d[_0x1e11('0x29')],'sectionId':_0x20c94d['id']},{})[_0x1e11('0x23')](function(){return _0x449aad;});}else{return _0x449aad;}})[_0x1e11('0x46')](function(_0x5abf53){logger['error'](_0x1e11('0x51'),_0x5abf53);throw _0x5abf53;});}return _0x449aad;})['then'](respondWithResult(_0x17c524,0xc9))[_0x1e11('0x46')](handleError(_0x17c524,null));};exports['update']=function(_0x3d7d1c,_0x254c34){if(_0x3d7d1c['body']['id']){delete _0x3d7d1c[_0x1e11('0x4a')]['id'];}return db['SquareOdbc'][_0x1e11('0x48')]({'where':{'id':_0x3d7d1c[_0x1e11('0x52')]['id']}})['then'](handleEntityNotFound(_0x254c34,null))[_0x1e11('0x23')](saveUpdates(_0x3d7d1c[_0x1e11('0x4a')],null))[_0x1e11('0x23')](respondWithResult(_0x254c34,null))[_0x1e11('0x46')](handleError(_0x254c34,null));};exports[_0x1e11('0x24')]=function(_0x3920ea,_0x56e8d1){return db[_0x1e11('0x2d')][_0x1e11('0x48')]({'where':{'id':_0x3920ea[_0x1e11('0x52')]['id']}})['then'](handleEntityNotFound(_0x56e8d1,null))[_0x1e11('0x23')](removeEntity(_0x56e8d1,null))[_0x1e11('0x46')](handleError(_0x56e8d1,null));};exports['test']=function(_0x24739b,_0x117e8d,_0xb82014){var _0x15556e;return db[_0x1e11('0x2d')][_0x1e11('0x48')]({'where':{'id':_0x24739b[_0x1e11('0x52')]['id']},'attributes':['id','dsn']})[_0x1e11('0x23')](handleEntityNotFound(_0x117e8d,null))[_0x1e11('0x23')](function(_0xe6cde4){if(_0xe6cde4){var _0x5bd05a=require(_0x1e11('0x53'))();_0x5bd05a['openSync'](_0xe6cde4[_0x1e11('0x54')]);_0x5bd05a['closeSync']();return _0xe6cde4;}})['then'](respondWithResult(_0x117e8d,null))[_0x1e11('0x46')](handleError(_0x117e8d,null));};