1481be9fe3f3b5686e59934522d656c7ee3d1987
[motion2.git] / server / api / jscriptyProject / jscriptyProject.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 _0x52b8=['../../config/logger','api','../../config/environment','../../config/license/util','sendStatus','status','end','json','limit','undefined','offset','count','set','Content-Range','apply','reject','save','update','then','destroy','get','Projects','UserProfileResource','error','stack','name','send','map','JscriptyProject','rawAttributes','fieldName','type','key','query','keys','filters','intersection','attributes','model','fields','length','hasOwnProperty','sort','where','pick','merge','filter','includeAll','include','show','params','options','catch','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','UserProfileSection','userProfileId','autoAssociation','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','clone','find','omit','createdAt','updatedAt','role','getSessions','findOne','JscriptySessionReport','nolimit','order','ProjectId','findAll','rows','getAnswers','JscriptyAnswerReport','number','fromCharCode','toString','indexOf','replace','startTime','starttime','-createdAt','questionId','question','format','YYYY-MM-DD\x20HH:mm:ss','SessionId','push','isEmpty','now','writeFileSync','setHeader','Content-disposition','Jscripty_Project_%d_Summary_%s.csv','download','rimraf','fast-json-patch','request-promise','bluebird','util','to-csv','fs-extra','lodash','desk.js','querystring','papaparse','ioredis','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/license/hardware'];(function(_0x40911a,_0x55ec99){var _0x27e8e3=function(_0x2ba910){while(--_0x2ba910){_0x40911a['push'](_0x40911a['shift']());}};_0x27e8e3(++_0x55ec99);}(_0x52b8,0xd3));var _0x852b=function(_0x520b9c,_0x5e67de){_0x520b9c=_0x520b9c-0x0;var _0xbb852e=_0x52b8[_0x520b9c];return _0xbb852e;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0x852b('0x0'));var zipdir=require('zip-dir');var jsonpatch=require(_0x852b('0x1'));var rp=require(_0x852b('0x2'));var moment=require('moment');var BPromise=require(_0x852b('0x3'));var Mustache=require('mustache');var util=require(_0x852b('0x4'));var path=require('path');var sox=require('sox');var csv=require(_0x852b('0x5'));var ejs=require('ejs');var fs=require('fs');var fs_extra=require(_0x852b('0x6'));var _=require(_0x852b('0x7'));var squel=require('squel');var crypto=require('crypto');var jsforce=require('jsforce');var deskjs=require(_0x852b('0x8'));var toCsv=require(_0x852b('0x5'));var querystring=require(_0x852b('0x9'));var Papa=require(_0x852b('0xa'));var Redis=require(_0x852b('0xb'));var authService=require('../../components/auth/service');var qs=require(_0x852b('0xc'));var as=require(_0x852b('0xd'));var hardwareService=require(_0x852b('0xe'));var logger=require(_0x852b('0xf'))(_0x852b('0x10'));var utils=require('../../config/utils');var config=require(_0x852b('0x11'));var licenseUtil=require(_0x852b('0x12'));var db=require('../../mysqldb')['db'];function respondWithStatusCode(_0x4190a1,_0x2f08da){_0x2f08da=_0x2f08da||0xcc;return function(_0x548159){if(_0x548159){return _0x4190a1[_0x852b('0x13')](_0x2f08da);}return _0x4190a1[_0x852b('0x14')](_0x2f08da)[_0x852b('0x15')]();};}function respondWithResult(_0x4ab720,_0x454f35){_0x454f35=_0x454f35||0xc8;return function(_0x35e3f9){if(_0x35e3f9){return _0x4ab720[_0x852b('0x14')](_0x454f35)[_0x852b('0x16')](_0x35e3f9);}};}function respondWithFilteredResult(_0x18c602,_0x41c2f6){return function(_0x21cadf){if(_0x21cadf){var _0x15e51d=typeof _0x41c2f6['offset']==='undefined'&&typeof _0x41c2f6[_0x852b('0x17')]===_0x852b('0x18');var _0x31e624=_0x21cadf['count'];var _0x406a0b=_0x15e51d?0x0:_0x41c2f6[_0x852b('0x19')];var _0x299153=_0x15e51d?_0x21cadf[_0x852b('0x1a')]:_0x41c2f6[_0x852b('0x19')]+_0x41c2f6[_0x852b('0x17')];var _0x2b4886;if(_0x299153>=_0x31e624){_0x299153=_0x31e624;_0x2b4886=0xc8;}else{_0x2b4886=0xce;}_0x18c602[_0x852b('0x14')](_0x2b4886);return _0x18c602[_0x852b('0x1b')](_0x852b('0x1c'),_0x406a0b+'-'+_0x299153+'/'+_0x31e624)[_0x852b('0x16')](_0x21cadf);}return null;};}function patchUpdates(_0x15118e){return function(_0x42e921){try{jsonpatch[_0x852b('0x1d')](_0x42e921,_0x15118e,!![]);}catch(_0x3a99c2){return BPromise[_0x852b('0x1e')](_0x3a99c2);}return _0x42e921[_0x852b('0x1f')]();};}function saveUpdates(_0x3e3560,_0x163cfa){return function(_0x2c0371){if(_0x2c0371){return _0x2c0371[_0x852b('0x20')](_0x3e3560)[_0x852b('0x21')](function(_0x2edafa){return _0x2edafa;});}return null;};}function removeEntity(_0x1fbeae,_0x4a7624){return function(_0x5d948b){if(_0x5d948b){return _0x5d948b[_0x852b('0x22')]()[_0x852b('0x21')](function(){var _0x110e34=_0x5d948b[_0x852b('0x23')]({'plain':!![]});var _0x1e525d=_0x852b('0x24');return db[_0x852b('0x25')][_0x852b('0x22')]({'where':{'type':_0x1e525d,'resourceId':_0x110e34['id']}})[_0x852b('0x21')](function(){return _0x5d948b;});})[_0x852b('0x21')](function(){_0x1fbeae[_0x852b('0x14')](0xcc)[_0x852b('0x15')]();});}};}function handleEntityNotFound(_0x5b586e,_0x4f916c){return function(_0x5f3bd5){if(!_0x5f3bd5){_0x5b586e[_0x852b('0x13')](0x194);}return _0x5f3bd5;};}function handleError(_0xce3709,_0x33967b){_0x33967b=_0x33967b||0x1f4;return function(_0x399b1d){logger[_0x852b('0x26')](_0x399b1d[_0x852b('0x27')]);if(_0x399b1d[_0x852b('0x28')]){delete _0x399b1d[_0x852b('0x28')];}_0xce3709[_0x852b('0x14')](_0x33967b)[_0x852b('0x29')](_0x399b1d);};}exports['index']=function(_0x556bc4,_0x4a6527){var _0x48ae3f={},_0x4ca7ab={},_0x1ceb30={'count':0x0,'rows':[]};var _0x49abaa=_[_0x852b('0x2a')](db[_0x852b('0x2b')][_0x852b('0x2c')],function(_0x16cb7f){return{'name':_0x16cb7f[_0x852b('0x2d')],'type':_0x16cb7f[_0x852b('0x2e')][_0x852b('0x2f')]};});_0x4ca7ab['model']=_[_0x852b('0x2a')](_0x49abaa,_0x852b('0x28'));_0x4ca7ab[_0x852b('0x30')]=_[_0x852b('0x31')](_0x556bc4[_0x852b('0x30')]);_0x4ca7ab[_0x852b('0x32')]=_[_0x852b('0x33')](_0x4ca7ab['model'],_0x4ca7ab[_0x852b('0x30')]);_0x48ae3f[_0x852b('0x34')]=_[_0x852b('0x33')](_0x4ca7ab[_0x852b('0x35')],qs[_0x852b('0x36')](_0x556bc4['query'][_0x852b('0x36')]));_0x48ae3f[_0x852b('0x34')]=_0x48ae3f[_0x852b('0x34')][_0x852b('0x37')]?_0x48ae3f[_0x852b('0x34')]:_0x4ca7ab[_0x852b('0x35')];if(!_0x556bc4['query'][_0x852b('0x38')]('nolimit')){_0x48ae3f['limit']=qs['limit'](_0x556bc4[_0x852b('0x30')][_0x852b('0x17')]);_0x48ae3f['offset']=qs['offset'](_0x556bc4['query'][_0x852b('0x19')]);}_0x48ae3f['order']=qs[_0x852b('0x39')](_0x556bc4[_0x852b('0x30')][_0x852b('0x39')]);_0x48ae3f[_0x852b('0x3a')]=qs[_0x852b('0x32')](_[_0x852b('0x3b')](_0x556bc4[_0x852b('0x30')],_0x4ca7ab[_0x852b('0x32')]),_0x49abaa);if(_0x556bc4[_0x852b('0x30')]['filter']){_0x48ae3f[_0x852b('0x3a')]=_[_0x852b('0x3c')](_0x48ae3f[_0x852b('0x3a')],{'$or':_['map'](_0x49abaa,function(_0x42b27d){if(_0x42b27d[_0x852b('0x2e')]!=='VIRTUAL'){var _0x1f9bba={};_0x1f9bba[_0x42b27d[_0x852b('0x28')]]={'$like':'%'+_0x556bc4[_0x852b('0x30')][_0x852b('0x3d')]+'%'};return _0x1f9bba;}})});}_0x48ae3f=_['merge']({},_0x48ae3f,_0x556bc4['options']);var _0x24e5fa={'where':_0x48ae3f[_0x852b('0x3a')]};return db[_0x852b('0x2b')]['count'](_0x24e5fa)[_0x852b('0x21')](function(_0xaba252){_0x1ceb30[_0x852b('0x1a')]=_0xaba252;if(_0x556bc4['query'][_0x852b('0x3e')]){_0x48ae3f[_0x852b('0x3f')]=[{'all':!![]}];}return db[_0x852b('0x2b')]['findAll'](_0x48ae3f);})['then'](function(_0x148646){_0x1ceb30['rows']=_0x148646;return _0x1ceb30;})['then'](respondWithFilteredResult(_0x4a6527,_0x48ae3f))['catch'](handleError(_0x4a6527,null));};exports[_0x852b('0x40')]=function(_0x557bb9,_0x4d3286){var _0x2725aa={'raw':![],'where':{'id':_0x557bb9[_0x852b('0x41')]['id']}},_0x32f2a8={};_0x32f2a8[_0x852b('0x35')]=_[_0x852b('0x31')](db[_0x852b('0x2b')]['rawAttributes']);_0x32f2a8[_0x852b('0x30')]=_['keys'](_0x557bb9[_0x852b('0x30')]);_0x32f2a8[_0x852b('0x32')]=_[_0x852b('0x33')](_0x32f2a8['model'],_0x32f2a8[_0x852b('0x30')]);_0x2725aa[_0x852b('0x34')]=_[_0x852b('0x33')](_0x32f2a8[_0x852b('0x35')],qs[_0x852b('0x36')](_0x557bb9[_0x852b('0x30')][_0x852b('0x36')]));_0x2725aa[_0x852b('0x34')]=_0x2725aa[_0x852b('0x34')][_0x852b('0x37')]?_0x2725aa[_0x852b('0x34')]:_0x32f2a8[_0x852b('0x35')];if(_0x557bb9[_0x852b('0x30')][_0x852b('0x3e')]){_0x2725aa['include']=[{'all':!![]}];}_0x2725aa=_[_0x852b('0x3c')]({},_0x2725aa,_0x557bb9[_0x852b('0x42')]);return db['JscriptyProject']['find'](_0x2725aa)[_0x852b('0x21')](handleEntityNotFound(_0x4d3286,null))[_0x852b('0x21')](respondWithResult(_0x4d3286,null))[_0x852b('0x43')](handleError(_0x4d3286,null));};exports[_0x852b('0x44')]=function(_0x434bfa,_0x13e498){return db[_0x852b('0x2b')][_0x852b('0x44')](_0x434bfa[_0x852b('0x45')],{})['then'](function(_0x12db22){var _0x2b7929=_0x434bfa[_0x852b('0x46')][_0x852b('0x23')]({'plain':!![]});if(!_0x2b7929)throw new Error(_0x852b('0x47'));if(_0x2b7929['role']===_0x852b('0x46')){var _0x9b1392=_0x12db22['get']({'plain':!![]});var _0x1d53b8=_0x852b('0x24');return db[_0x852b('0x48')]['find']({'where':{'name':_0x1d53b8,'userProfileId':_0x2b7929[_0x852b('0x49')]},'raw':!![]})[_0x852b('0x21')](function(_0x3f6883){if(_0x3f6883&&_0x3f6883[_0x852b('0x4a')]===0x0){return db[_0x852b('0x25')][_0x852b('0x44')]({'name':_0x9b1392['name'],'resourceId':_0x9b1392['id'],'type':_0x3f6883[_0x852b('0x28')],'sectionId':_0x3f6883['id']},{})['then'](function(){return _0x12db22;});}else{return _0x12db22;}})[_0x852b('0x43')](function(_0x3353e6){logger[_0x852b('0x26')](_0x852b('0x4b'),_0x3353e6);throw _0x3353e6;});}return _0x12db22;})[_0x852b('0x21')](respondWithResult(_0x13e498,0xc9))[_0x852b('0x43')](handleError(_0x13e498,null));};exports[_0x852b('0x4c')]=function(_0x4af1db,_0x67cab7){var _0x9e69ca={'where':{'id':_0x4af1db[_0x852b('0x41')]['id']}},_0x52b409={};_0x52b409[_0x852b('0x35')]=_[_0x852b('0x31')](db[_0x852b('0x2b')][_0x852b('0x2c')]);_0x9e69ca['attributes']=_[_0x852b('0x33')](_0x52b409[_0x852b('0x35')],qs[_0x852b('0x36')](_0x4af1db[_0x852b('0x30')][_0x852b('0x36')]));_0x9e69ca[_0x852b('0x34')]=_0x9e69ca[_0x852b('0x34')][_0x852b('0x37')]?_0x9e69ca[_0x852b('0x34')]:_0x52b409[_0x852b('0x35')];if(_0x4af1db[_0x852b('0x30')]['includeAll']){_0x9e69ca[_0x852b('0x3f')]=[{'all':!![]}];}_0x9e69ca=_[_0x852b('0x3c')]({},_0x9e69ca,_0x4af1db[_0x852b('0x42')]);return db['JscriptyProject'][_0x852b('0x4d')](_0x9e69ca)[_0x852b('0x21')](handleEntityNotFound(_0x67cab7,null))[_0x852b('0x21')](function(_0x3a8631){if(_0x3a8631){var _0xe925b5=_0x3a8631[_0x852b('0x23')]({'plain':!![]});_0xe925b5=qs[_0x852b('0x4e')](_0xe925b5,['id',_0x852b('0x4f'),_0x852b('0x50')]);_0x4af1db[_0x852b('0x45')]=_[_0x852b('0x4e')](_0x4af1db[_0x852b('0x45')],['id',_0x852b('0x4f'),_0x852b('0x50')]);return db[_0x852b('0x2b')][_0x852b('0x44')](_[_0x852b('0x3c')](_0xe925b5,_0x4af1db[_0x852b('0x45')]),{'include':_0x4af1db[_0x852b('0x30')]['includeAll']?[{'all':!![]}]:undefined})[_0x852b('0x21')](function(_0x2cefba){var _0x4896a6=_0x4af1db[_0x852b('0x46')][_0x852b('0x23')]({'plain':!![]});if(!_0x4896a6)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x4896a6[_0x852b('0x51')]==='user'){var _0x5e4480=_0x2cefba[_0x852b('0x23')]({'plain':!![]});var _0x1008af=_0x852b('0x24');return db[_0x852b('0x48')][_0x852b('0x4d')]({'where':{'name':_0x1008af,'userProfileId':_0x4896a6[_0x852b('0x49')]},'raw':!![]})[_0x852b('0x21')](function(_0x45ca30){if(_0x45ca30&&_0x45ca30[_0x852b('0x4a')]===0x0){return db['UserProfileResource'][_0x852b('0x44')]({'name':_0x5e4480['name'],'resourceId':_0x5e4480['id'],'type':_0x45ca30[_0x852b('0x28')],'sectionId':_0x45ca30['id']},{})['then'](function(){return _0x2cefba;});}else{return _0x2cefba;}})[_0x852b('0x43')](function(_0x459c9c){logger['error'](_0x852b('0x4b'),_0x459c9c);throw _0x459c9c;});}return _0x2cefba;});}})[_0x852b('0x21')](respondWithResult(_0x67cab7,0xc9))[_0x852b('0x43')](handleError(_0x67cab7,null));};exports[_0x852b('0x20')]=function(_0x10a8a9,_0x4bbbbd){if(_0x10a8a9[_0x852b('0x45')]['id']){delete _0x10a8a9[_0x852b('0x45')]['id'];}return db['JscriptyProject'][_0x852b('0x4d')]({'where':{'id':_0x10a8a9[_0x852b('0x41')]['id']}})[_0x852b('0x21')](handleEntityNotFound(_0x4bbbbd,null))[_0x852b('0x21')](saveUpdates(_0x10a8a9[_0x852b('0x45')],null))[_0x852b('0x21')](respondWithResult(_0x4bbbbd,null))[_0x852b('0x43')](handleError(_0x4bbbbd,null));};exports['destroy']=function(_0x563199,_0x1fc0f6){return db[_0x852b('0x2b')][_0x852b('0x4d')]({'where':{'id':_0x563199['params']['id']}})[_0x852b('0x21')](handleEntityNotFound(_0x1fc0f6,null))[_0x852b('0x21')](removeEntity(_0x1fc0f6,null))['catch'](handleError(_0x1fc0f6,null));};exports[_0x852b('0x52')]=function(_0x51f72d,_0x481516,_0x33ed4e){var _0x588cca={'raw':!![],'where':{}};var _0x3f85a6={};var _0x46eb6c={'count':0x0,'rows':[]};return db[_0x852b('0x2b')][_0x852b('0x53')]({'where':{'id':_0x51f72d[_0x852b('0x41')]['id']}})[_0x852b('0x21')](handleEntityNotFound(_0x481516,null))[_0x852b('0x21')](function(_0x241efd){if(_0x241efd){_0x3f85a6[_0x852b('0x35')]=_[_0x852b('0x31')](db[_0x852b('0x54')][_0x852b('0x2c')]);_0x3f85a6[_0x852b('0x30')]=_[_0x852b('0x31')](_0x51f72d[_0x852b('0x30')]);_0x3f85a6[_0x852b('0x32')]=_['intersection'](_0x3f85a6[_0x852b('0x35')],_0x3f85a6[_0x852b('0x30')]);_0x588cca['attributes']=_[_0x852b('0x33')](_0x3f85a6['model'],qs['fields'](_0x51f72d[_0x852b('0x30')]['fields']));_0x588cca[_0x852b('0x34')]=_0x588cca[_0x852b('0x34')][_0x852b('0x37')]?_0x588cca[_0x852b('0x34')]:_0x3f85a6[_0x852b('0x35')];if(!_0x51f72d[_0x852b('0x30')]['hasOwnProperty'](_0x852b('0x55'))){_0x588cca[_0x852b('0x17')]=qs[_0x852b('0x17')](_0x51f72d[_0x852b('0x30')][_0x852b('0x17')]);_0x588cca[_0x852b('0x19')]=qs['offset'](_0x51f72d[_0x852b('0x30')][_0x852b('0x19')]);}_0x588cca[_0x852b('0x56')]=qs[_0x852b('0x39')](_0x51f72d[_0x852b('0x30')][_0x852b('0x39')]);_0x588cca['where']=qs[_0x852b('0x32')](_[_0x852b('0x3b')](_0x51f72d[_0x852b('0x30')],_0x3f85a6[_0x852b('0x32')]));_0x588cca[_0x852b('0x3a')][_0x852b('0x57')]=_0x241efd['id'];if(_0x51f72d[_0x852b('0x30')][_0x852b('0x3d')]){_0x588cca[_0x852b('0x3a')]=_['merge'](_0x588cca[_0x852b('0x3a')],{'$or':_[_0x852b('0x2a')](_0x588cca['attributes'],function(_0x220ad5){var _0xbcd620={};_0xbcd620[_0x220ad5]={'$like':'%'+_0x51f72d[_0x852b('0x30')][_0x852b('0x3d')]+'%'};return _0xbcd620;})});}_0x588cca=_[_0x852b('0x3c')]({},_0x588cca,_0x51f72d[_0x852b('0x42')]);return db[_0x852b('0x54')][_0x852b('0x1a')]({'where':_0x588cca[_0x852b('0x3a')]})[_0x852b('0x21')](function(_0x1cd09c){_0x46eb6c[_0x852b('0x1a')]=_0x1cd09c;if(_0x51f72d[_0x852b('0x30')][_0x852b('0x3e')]){_0x588cca[_0x852b('0x3f')]=[{'all':!![]}];}return db[_0x852b('0x54')][_0x852b('0x58')](_0x588cca);})['then'](function(_0x3c44cd){_0x46eb6c[_0x852b('0x59')]=_0x3c44cd;return _0x46eb6c;});}})[_0x852b('0x21')](respondWithFilteredResult(_0x481516,_0x588cca))[_0x852b('0x43')](handleError(_0x481516,null));};exports[_0x852b('0x5a')]=function(_0xd4ee47,_0x5c0c8d,_0x31f12e){var _0x147494={'raw':!![],'where':{}};var _0x13e566={};var _0x5bb0ef={'count':0x0,'rows':[]};return db['JscriptyProject'][_0x852b('0x53')]({'where':{'id':_0xd4ee47['params']['id']}})[_0x852b('0x21')](handleEntityNotFound(_0x5c0c8d,null))[_0x852b('0x21')](function(_0x4665eb){if(_0x4665eb){_0x13e566['model']=_[_0x852b('0x31')](db['JscriptyAnswerReport'][_0x852b('0x2c')]);_0x13e566['query']=_[_0x852b('0x31')](_0xd4ee47['query']);_0x13e566[_0x852b('0x32')]=_[_0x852b('0x33')](_0x13e566[_0x852b('0x35')],_0x13e566[_0x852b('0x30')]);_0x147494['attributes']=_[_0x852b('0x33')](_0x13e566['model'],qs[_0x852b('0x36')](_0xd4ee47[_0x852b('0x30')][_0x852b('0x36')]));_0x147494['attributes']=_0x147494[_0x852b('0x34')]['length']?_0x147494[_0x852b('0x34')]:_0x13e566[_0x852b('0x35')];if(!_0xd4ee47[_0x852b('0x30')][_0x852b('0x38')]('nolimit')){_0x147494['limit']=qs[_0x852b('0x17')](_0xd4ee47[_0x852b('0x30')][_0x852b('0x17')]);_0x147494['offset']=qs['offset'](_0xd4ee47[_0x852b('0x30')][_0x852b('0x19')]);}_0x147494['order']=qs[_0x852b('0x39')](_0xd4ee47[_0x852b('0x30')][_0x852b('0x39')]);_0x147494[_0x852b('0x3a')]=qs[_0x852b('0x32')](_[_0x852b('0x3b')](_0xd4ee47['query'],_0x13e566[_0x852b('0x32')]));_0x147494[_0x852b('0x3a')][_0x852b('0x57')]=_0x4665eb['id'];if(_0xd4ee47['query'][_0x852b('0x3d')]){_0x147494[_0x852b('0x3a')]=_['merge'](_0x147494[_0x852b('0x3a')],{'$or':_[_0x852b('0x2a')](_0x147494[_0x852b('0x34')],function(_0x1e71df){var _0x3f1400={};_0x3f1400[_0x1e71df]={'$like':'%'+_0xd4ee47[_0x852b('0x30')]['filter']+'%'};return _0x3f1400;})});}_0x147494=_[_0x852b('0x3c')]({},_0x147494,_0xd4ee47[_0x852b('0x42')]);return db[_0x852b('0x5b')][_0x852b('0x1a')]({'where':_0x147494[_0x852b('0x3a')]})['then'](function(_0x4d36a5){_0x5bb0ef[_0x852b('0x1a')]=_0x4d36a5;if(_0xd4ee47[_0x852b('0x30')][_0x852b('0x3e')]){_0x147494[_0x852b('0x3f')]=[{'all':!![]}];}return db['JscriptyAnswerReport'][_0x852b('0x58')](_0x147494);})['then'](function(_0x3bdb59){_0x5bb0ef[_0x852b('0x59')]=_0x3bdb59;return _0x5bb0ef;});}})['then'](respondWithFilteredResult(_0x5c0c8d,_0x147494))[_0x852b('0x43')](handleError(_0x5c0c8d,null));};function char(_0x2c647e){return _0x852b('0x5c')===typeof _0x2c647e?String[_0x852b('0x5d')][_0x852b('0x1d')](null,arguments):_0x2c647e;}function needsEncapsulation(_0x56a350){return!!_0x56a350&&(_0x56a350[_0x852b('0x5e')]()[_0x852b('0x5f')](char(0xd))>=0x0||_0x56a350[_0x852b('0x5e')]()[_0x852b('0x5f')](char(0xa))>=0x0||_0x56a350[_0x852b('0x5e')]()['indexOf'](char(0x2c))>=0x0||_0x56a350['toString']()[_0x852b('0x5f')](char(0x22))>=0x0);}function encapsulate(_0x5bbfad){var _0x4e9de6=char(0x22),_0x2fae3a='\x5c'+char(0x22),_0x341644=_0x5bbfad[_0x852b('0x5e')]()[_0x852b('0x60')](new RegExp(_0x4e9de6,'g'),_0x2fae3a);return _0x4e9de6+_0x341644+_0x4e9de6;}exports['getSummary']=function(_0xf8888,_0x1253e2,_0x59a01c){var _0x254563,_0x29b9e1;var _0x28ba2e={'where':{'ProjectId':_0xf8888[_0x852b('0x41')]['id']}};if(_0xf8888[_0x852b('0x30')][_0x852b('0x61')]){_0x28ba2e[_0x852b('0x3a')][_0x852b('0x62')]=JSON['parse'](_0xf8888[_0x852b('0x30')][_0x852b('0x61')]);}return db[_0x852b('0x54')][_0x852b('0x58')](_0x28ba2e)[_0x852b('0x21')](handleEntityNotFound(_0x1253e2,null))[_0x852b('0x21')](function(_0x2dd6b4){if(_0x2dd6b4){_0x254563=_0x2dd6b4;return db['JscriptyQuestionReport'][_0x852b('0x58')]({'where':{'SessionId':{'$in':_[_0x852b('0x2a')](_0x254563,'id')},'ProjectId':_0xf8888[_0x852b('0x41')]['id']},'order':_0x852b('0x63')});}})['then'](handleEntityNotFound(_0x1253e2,null))['then'](function(_0x2076a8){if(_0x2076a8){_0x29b9e1=_0x2076a8;var _0x24b1f0={};for(var _0x4aefd9=0x0,_0x14946e=_0x29b9e1[_0x852b('0x37')];_0x4aefd9<_0x14946e;_0x4aefd9++){if(!_0x24b1f0[_0x852b('0x38')](_0x29b9e1[_0x4aefd9][_0x852b('0x64')])){_0x24b1f0[_0x29b9e1[_0x4aefd9]['questionId']]=needsEncapsulation(_0x29b9e1[_0x4aefd9]['question'])?encapsulate(_0x29b9e1[_0x4aefd9][_0x852b('0x65')]):_0x29b9e1[_0x4aefd9][_0x852b('0x65')];}}var _0x2c328a=[],_0x1f08ff={};for(var _0x53cf78=0x0,_0x4d942c=_0x254563[_0x852b('0x37')];_0x53cf78<_0x4d942c;_0x53cf78++){_0x1f08ff={'ProjectId':_0xf8888['params']['id'],'SessionId':_0x254563[_0x53cf78]['id'],'StartTime':moment(_0x254563[_0x53cf78][_0x852b('0x62')])[_0x852b('0x66')](_0x852b('0x67'))};for(var _0x15693a=0x0,_0x2184cc=_0x29b9e1['length'];_0x15693a<_0x2184cc;_0x15693a++){if(_0x29b9e1[_0x15693a][_0x852b('0x68')]==_0x254563[_0x53cf78]['id']&&_0x24b1f0[_0x852b('0x38')](_0x29b9e1[_0x15693a]['questionId'])){_0x1f08ff[_0x24b1f0[_0x29b9e1[_0x15693a]['questionId']]]=_0x29b9e1[_0x15693a]['answer'];}}for(var _0x130e19 in _0x24b1f0){if(!_0x1f08ff[_0x852b('0x38')](_0x24b1f0[_0x130e19])){_0x1f08ff[_0x24b1f0[_0x130e19]]=null;}}_0x2c328a[_0x852b('0x69')](_0x1f08ff);}return _0x2c328a;}})['then'](function(_0x1143e9){if(!_[_0x852b('0x6a')](_0x1143e9)){var _0x24fa41=toCsv(_0x1143e9);var _0x1a36b4=Date[_0x852b('0x6b')]();fs[_0x852b('0x6c')](util[_0x852b('0x66')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0xf8888['params']['id'],_0x1a36b4),_0x24fa41);_0x1253e2[_0x852b('0x6d')](_0x852b('0x6e'),'attachment;\x20filename='+util[_0x852b('0x66')](_0x852b('0x6f'),_0xf8888[_0x852b('0x41')]['id'],_0x1a36b4));_0x1253e2[_0x852b('0x6d')]('Content-type','text/csv');return _0x1253e2[_0x852b('0x70')](util[_0x852b('0x66')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0xf8888[_0x852b('0x41')]['id'],_0x1a36b4));}else{return _0x1253e2[_0x852b('0x13')](0xcc);}})['catch'](handleError(_0x1253e2,null));};