85e8427e440ef6bfa44acc07da5bdcd49452183e
[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 _0x40a3=['sox','to-csv','ejs','lodash','squel','jsforce','desk.js','querystring','papaparse','../../components/auth/service','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','../../config/utils','../../config/environment','../../mysqldb','sendStatus','status','end','json','offset','undefined','count','limit','set','apply','save','update','then','get','Projects','UserProfileResource','destroy','error','stack','name','index','map','JscriptyProject','rawAttributes','fieldName','type','key','model','keys','query','filters','intersection','fields','attributes','length','order','sort','where','pick','filter','merge','VIRTUAL','includeAll','findAll','rows','catch','params','find','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','UserProfileSection','userProfileId','autoAssociation','include','options','omit','createdAt','updatedAt','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','getSessions','nolimit','JscriptySessionReport','getAnswers','findOne','JscriptyAnswerReport','ProjectId','number','fromCharCode','toString','indexOf','getSummary','starttime','JscriptyQuestionReport','-createdAt','hasOwnProperty','questionId','question','format','SessionId','answer','isEmpty','now','writeFileSync','/tmp/Jscripty_Project_%d_Summary_%s.csv','Content-disposition','Jscripty_Project_%d_Summary_%s.csv','setHeader','Content-type','text/csv','download','eml-format','request-promise','bluebird','mustache','util','path'];(function(_0x3b2573,_0x3c93f0){var _0xceb236=function(_0x67dc6){while(--_0x67dc6){_0x3b2573['push'](_0x3b2573['shift']());}};_0xceb236(++_0x3c93f0);}(_0x40a3,0x153));var _0x340a=function(_0x423da1,_0x596d06){_0x423da1=_0x423da1-0x0;var _0xe6eeaf=_0x40a3[_0x423da1];return _0xe6eeaf;};'use strict';var emlformat=require(_0x340a('0x0'));var rimraf=require('rimraf');var zipdir=require('zip-dir');var jsonpatch=require('fast-json-patch');var rp=require(_0x340a('0x1'));var moment=require('moment');var BPromise=require(_0x340a('0x2'));var Mustache=require(_0x340a('0x3'));var util=require(_0x340a('0x4'));var path=require(_0x340a('0x5'));var sox=require(_0x340a('0x6'));var csv=require(_0x340a('0x7'));var ejs=require(_0x340a('0x8'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0x340a('0x9'));var squel=require(_0x340a('0xa'));var crypto=require('crypto');var jsforce=require(_0x340a('0xb'));var deskjs=require(_0x340a('0xc'));var toCsv=require(_0x340a('0x7'));var querystring=require(_0x340a('0xd'));var Papa=require(_0x340a('0xe'));var Redis=require('ioredis');var authService=require(_0x340a('0xf'));var qs=require(_0x340a('0x10'));var as=require(_0x340a('0x11'));var hardwareService=require('../../config/license/hardware');var logger=require(_0x340a('0x12'))('api');var utils=require(_0x340a('0x13'));var config=require(_0x340a('0x14'));var licenseUtil=require('../../config/license/util');var db=require(_0x340a('0x15'))['db'];function respondWithStatusCode(_0x45b078,_0x315bc7){_0x315bc7=_0x315bc7||0xcc;return function(_0x3e7b35){if(_0x3e7b35){return _0x45b078[_0x340a('0x16')](_0x315bc7);}return _0x45b078[_0x340a('0x17')](_0x315bc7)[_0x340a('0x18')]();};}function respondWithResult(_0x393484,_0x2f9105){_0x2f9105=_0x2f9105||0xc8;return function(_0x150fe7){if(_0x150fe7){return _0x393484[_0x340a('0x17')](_0x2f9105)[_0x340a('0x19')](_0x150fe7);}};}function respondWithFilteredResult(_0xa1b711,_0xe93d15){return function(_0x435879){if(_0x435879){var _0x4caee8=typeof _0xe93d15[_0x340a('0x1a')]==='undefined'&&typeof _0xe93d15['limit']===_0x340a('0x1b');var _0x1a2ab1=_0x435879[_0x340a('0x1c')];var _0x18c94d=_0x4caee8?0x0:_0xe93d15[_0x340a('0x1a')];var _0x4587f7=_0x4caee8?_0x435879[_0x340a('0x1c')]:_0xe93d15[_0x340a('0x1a')]+_0xe93d15[_0x340a('0x1d')];var _0x29da7e;if(_0x4587f7>=_0x1a2ab1){_0x4587f7=_0x1a2ab1;_0x29da7e=0xc8;}else{_0x29da7e=0xce;}_0xa1b711['status'](_0x29da7e);return _0xa1b711[_0x340a('0x1e')]('Content-Range',_0x18c94d+'-'+_0x4587f7+'/'+_0x1a2ab1)[_0x340a('0x19')](_0x435879);}return null;};}function patchUpdates(_0x30f383){return function(_0x24c49e){try{jsonpatch[_0x340a('0x1f')](_0x24c49e,_0x30f383,!![]);}catch(_0x5b3aeb){return BPromise['reject'](_0x5b3aeb);}return _0x24c49e[_0x340a('0x20')]();};}function saveUpdates(_0xddb829,_0x4a8c22){return function(_0x18fe5d){if(_0x18fe5d){return _0x18fe5d[_0x340a('0x21')](_0xddb829)[_0x340a('0x22')](function(_0x47a572){return _0x47a572;});}return null;};}function removeEntity(_0x5b4e51,_0x3b3ada){return function(_0xf0fd20){if(_0xf0fd20){return _0xf0fd20['destroy']()[_0x340a('0x22')](function(){var _0x2ca1d9=_0xf0fd20[_0x340a('0x23')]({'plain':!![]});var _0x12bb94=_0x340a('0x24');return db[_0x340a('0x25')][_0x340a('0x26')]({'where':{'type':_0x12bb94,'resourceId':_0x2ca1d9['id']}})[_0x340a('0x22')](function(){return _0xf0fd20;});})[_0x340a('0x22')](function(){_0x5b4e51['status'](0xcc)[_0x340a('0x18')]();});}};}function handleEntityNotFound(_0x4c59ff,_0x259c95){return function(_0x4337f7){if(!_0x4337f7){_0x4c59ff['sendStatus'](0x194);}return _0x4337f7;};}function handleError(_0x5226c6,_0x52399d){_0x52399d=_0x52399d||0x1f4;return function(_0x151a15){logger[_0x340a('0x27')](_0x151a15[_0x340a('0x28')]);if(_0x151a15['name']){delete _0x151a15[_0x340a('0x29')];}_0x5226c6[_0x340a('0x17')](_0x52399d)['send'](_0x151a15);};}exports[_0x340a('0x2a')]=function(_0x3f2157,_0x233f65){var _0x31cc57={},_0x3ad80f={},_0x40a061={'count':0x0,'rows':[]};var _0x50646e=_[_0x340a('0x2b')](db[_0x340a('0x2c')][_0x340a('0x2d')],function(_0x40eed6){return{'name':_0x40eed6[_0x340a('0x2e')],'type':_0x40eed6[_0x340a('0x2f')][_0x340a('0x30')]};});_0x3ad80f[_0x340a('0x31')]=_[_0x340a('0x2b')](_0x50646e,_0x340a('0x29'));_0x3ad80f['query']=_[_0x340a('0x32')](_0x3f2157[_0x340a('0x33')]);_0x3ad80f[_0x340a('0x34')]=_[_0x340a('0x35')](_0x3ad80f['model'],_0x3ad80f[_0x340a('0x33')]);_0x31cc57['attributes']=_[_0x340a('0x35')](_0x3ad80f['model'],qs[_0x340a('0x36')](_0x3f2157['query']['fields']));_0x31cc57[_0x340a('0x37')]=_0x31cc57['attributes'][_0x340a('0x38')]?_0x31cc57[_0x340a('0x37')]:_0x3ad80f[_0x340a('0x31')];if(!_0x3f2157[_0x340a('0x33')]['hasOwnProperty']('nolimit')){_0x31cc57['limit']=qs[_0x340a('0x1d')](_0x3f2157[_0x340a('0x33')]['limit']);_0x31cc57['offset']=qs[_0x340a('0x1a')](_0x3f2157[_0x340a('0x33')]['offset']);}_0x31cc57[_0x340a('0x39')]=qs[_0x340a('0x3a')](_0x3f2157[_0x340a('0x33')][_0x340a('0x3a')]);_0x31cc57[_0x340a('0x3b')]=qs[_0x340a('0x34')](_[_0x340a('0x3c')](_0x3f2157[_0x340a('0x33')],_0x3ad80f[_0x340a('0x34')]),_0x50646e);if(_0x3f2157[_0x340a('0x33')][_0x340a('0x3d')]){_0x31cc57[_0x340a('0x3b')]=_[_0x340a('0x3e')](_0x31cc57['where'],{'$or':_[_0x340a('0x2b')](_0x50646e,function(_0x2f92a1){if(_0x2f92a1[_0x340a('0x2f')]!==_0x340a('0x3f')){var _0xfb41f9={};_0xfb41f9[_0x2f92a1[_0x340a('0x29')]]={'$like':'%'+_0x3f2157[_0x340a('0x33')][_0x340a('0x3d')]+'%'};return _0xfb41f9;}})});}_0x31cc57=_[_0x340a('0x3e')]({},_0x31cc57,_0x3f2157['options']);var _0x102bf9={'where':_0x31cc57[_0x340a('0x3b')]};return db['JscriptyProject'][_0x340a('0x1c')](_0x102bf9)[_0x340a('0x22')](function(_0x2414b7){_0x40a061[_0x340a('0x1c')]=_0x2414b7;if(_0x3f2157['query'][_0x340a('0x40')]){_0x31cc57['include']=[{'all':!![]}];}return db[_0x340a('0x2c')][_0x340a('0x41')](_0x31cc57);})[_0x340a('0x22')](function(_0x53f628){_0x40a061[_0x340a('0x42')]=_0x53f628;return _0x40a061;})[_0x340a('0x22')](respondWithFilteredResult(_0x233f65,_0x31cc57))[_0x340a('0x43')](handleError(_0x233f65,null));};exports['show']=function(_0x4b63ea,_0x1fcdf7){var _0x39a26d={'raw':![],'where':{'id':_0x4b63ea[_0x340a('0x44')]['id']}},_0x56d421={};_0x56d421[_0x340a('0x31')]=_[_0x340a('0x32')](db[_0x340a('0x2c')][_0x340a('0x2d')]);_0x56d421['query']=_[_0x340a('0x32')](_0x4b63ea[_0x340a('0x33')]);_0x56d421[_0x340a('0x34')]=_[_0x340a('0x35')](_0x56d421[_0x340a('0x31')],_0x56d421[_0x340a('0x33')]);_0x39a26d[_0x340a('0x37')]=_[_0x340a('0x35')](_0x56d421[_0x340a('0x31')],qs[_0x340a('0x36')](_0x4b63ea['query'][_0x340a('0x36')]));_0x39a26d[_0x340a('0x37')]=_0x39a26d[_0x340a('0x37')]['length']?_0x39a26d[_0x340a('0x37')]:_0x56d421[_0x340a('0x31')];if(_0x4b63ea[_0x340a('0x33')]['includeAll']){_0x39a26d['include']=[{'all':!![]}];}_0x39a26d=_[_0x340a('0x3e')]({},_0x39a26d,_0x4b63ea['options']);return db[_0x340a('0x2c')][_0x340a('0x45')](_0x39a26d)[_0x340a('0x22')](handleEntityNotFound(_0x1fcdf7,null))[_0x340a('0x22')](respondWithResult(_0x1fcdf7,null))[_0x340a('0x43')](handleError(_0x1fcdf7,null));};exports[_0x340a('0x46')]=function(_0x40b124,_0xe3ff17){return db[_0x340a('0x2c')]['create'](_0x40b124[_0x340a('0x47')],{})['then'](function(_0x254fd2){var _0x2fe3c5=_0x40b124[_0x340a('0x48')][_0x340a('0x23')]({'plain':!![]});if(!_0x2fe3c5)throw new Error(_0x340a('0x49'));if(_0x2fe3c5[_0x340a('0x4a')]===_0x340a('0x48')){var _0x217493=_0x254fd2[_0x340a('0x23')]({'plain':!![]});var _0x4bf599=_0x340a('0x24');return db[_0x340a('0x4b')][_0x340a('0x45')]({'where':{'name':_0x4bf599,'userProfileId':_0x2fe3c5[_0x340a('0x4c')]},'raw':!![]})[_0x340a('0x22')](function(_0x554e3f){if(_0x554e3f&&_0x554e3f[_0x340a('0x4d')]===0x0){return db[_0x340a('0x25')][_0x340a('0x46')]({'name':_0x217493[_0x340a('0x29')],'resourceId':_0x217493['id'],'type':_0x554e3f[_0x340a('0x29')],'sectionId':_0x554e3f['id']},{})[_0x340a('0x22')](function(){return _0x254fd2;});}else{return _0x254fd2;}})[_0x340a('0x43')](function(_0x567bc7){logger[_0x340a('0x27')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x567bc7);throw _0x567bc7;});}return _0x254fd2;})[_0x340a('0x22')](respondWithResult(_0xe3ff17,0xc9))['catch'](handleError(_0xe3ff17,null));};exports['clone']=function(_0x33019f,_0x54f539){var _0xd32403={'where':{'id':_0x33019f[_0x340a('0x44')]['id']}},_0x1067f6={};_0x1067f6['model']=_['keys'](db[_0x340a('0x2c')][_0x340a('0x2d')]);_0xd32403[_0x340a('0x37')]=_[_0x340a('0x35')](_0x1067f6[_0x340a('0x31')],qs[_0x340a('0x36')](_0x33019f[_0x340a('0x33')][_0x340a('0x36')]));_0xd32403[_0x340a('0x37')]=_0xd32403['attributes'][_0x340a('0x38')]?_0xd32403['attributes']:_0x1067f6[_0x340a('0x31')];if(_0x33019f['query'][_0x340a('0x40')]){_0xd32403[_0x340a('0x4e')]=[{'all':!![]}];}_0xd32403=_['merge']({},_0xd32403,_0x33019f[_0x340a('0x4f')]);return db[_0x340a('0x2c')][_0x340a('0x45')](_0xd32403)['then'](handleEntityNotFound(_0x54f539,null))[_0x340a('0x22')](function(_0x1e31e0){if(_0x1e31e0){var _0x4d3470=_0x1e31e0[_0x340a('0x23')]({'plain':!![]});_0x4d3470=qs[_0x340a('0x50')](_0x4d3470,['id',_0x340a('0x51'),_0x340a('0x52')]);_0x33019f[_0x340a('0x47')]=_[_0x340a('0x50')](_0x33019f[_0x340a('0x47')],['id',_0x340a('0x51'),_0x340a('0x52')]);return db[_0x340a('0x2c')][_0x340a('0x46')](_[_0x340a('0x3e')](_0x4d3470,_0x33019f[_0x340a('0x47')]),{'include':_0x33019f['query'][_0x340a('0x40')]?[{'all':!![]}]:undefined})[_0x340a('0x22')](function(_0x433cf0){var _0x23cadf=_0x33019f[_0x340a('0x48')][_0x340a('0x23')]({'plain':!![]});if(!_0x23cadf)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x23cadf[_0x340a('0x4a')]==='user'){var _0x467700=_0x433cf0[_0x340a('0x23')]({'plain':!![]});var _0x374319=_0x340a('0x24');return db[_0x340a('0x4b')][_0x340a('0x45')]({'where':{'name':_0x374319,'userProfileId':_0x23cadf[_0x340a('0x4c')]},'raw':!![]})[_0x340a('0x22')](function(_0x42e67e){if(_0x42e67e&&_0x42e67e[_0x340a('0x4d')]===0x0){return db[_0x340a('0x25')]['create']({'name':_0x467700[_0x340a('0x29')],'resourceId':_0x467700['id'],'type':_0x42e67e[_0x340a('0x29')],'sectionId':_0x42e67e['id']},{})[_0x340a('0x22')](function(){return _0x433cf0;});}else{return _0x433cf0;}})['catch'](function(_0xc47389){logger[_0x340a('0x27')](_0x340a('0x53'),_0xc47389);throw _0xc47389;});}return _0x433cf0;});}})['then'](respondWithResult(_0x54f539,0xc9))[_0x340a('0x43')](handleError(_0x54f539,null));};exports[_0x340a('0x21')]=function(_0x24bd9b,_0x19eee5){if(_0x24bd9b[_0x340a('0x47')]['id']){delete _0x24bd9b['body']['id'];}return db[_0x340a('0x2c')][_0x340a('0x45')]({'where':{'id':_0x24bd9b[_0x340a('0x44')]['id']}})[_0x340a('0x22')](handleEntityNotFound(_0x19eee5,null))['then'](saveUpdates(_0x24bd9b['body'],null))['then'](respondWithResult(_0x19eee5,null))['catch'](handleError(_0x19eee5,null));};exports[_0x340a('0x26')]=function(_0x1d083a,_0x3c02fa){return db[_0x340a('0x2c')][_0x340a('0x45')]({'where':{'id':_0x1d083a[_0x340a('0x44')]['id']}})[_0x340a('0x22')](handleEntityNotFound(_0x3c02fa,null))[_0x340a('0x22')](removeEntity(_0x3c02fa,null))[_0x340a('0x43')](handleError(_0x3c02fa,null));};exports[_0x340a('0x54')]=function(_0x26ecc9,_0x475003,_0x3f2c2a){var _0x246d96={'raw':!![],'where':{}};var _0x16d8e7={};var _0x509333={'count':0x0,'rows':[]};return db[_0x340a('0x2c')]['findOne']({'where':{'id':_0x26ecc9[_0x340a('0x44')]['id']}})[_0x340a('0x22')](handleEntityNotFound(_0x475003,null))[_0x340a('0x22')](function(_0x1b5ef4){if(_0x1b5ef4){_0x16d8e7['model']=_[_0x340a('0x32')](db['JscriptySessionReport'][_0x340a('0x2d')]);_0x16d8e7[_0x340a('0x33')]=_[_0x340a('0x32')](_0x26ecc9[_0x340a('0x33')]);_0x16d8e7['filters']=_[_0x340a('0x35')](_0x16d8e7['model'],_0x16d8e7[_0x340a('0x33')]);_0x246d96[_0x340a('0x37')]=_['intersection'](_0x16d8e7[_0x340a('0x31')],qs[_0x340a('0x36')](_0x26ecc9[_0x340a('0x33')][_0x340a('0x36')]));_0x246d96[_0x340a('0x37')]=_0x246d96[_0x340a('0x37')][_0x340a('0x38')]?_0x246d96[_0x340a('0x37')]:_0x16d8e7[_0x340a('0x31')];if(!_0x26ecc9[_0x340a('0x33')]['hasOwnProperty'](_0x340a('0x55'))){_0x246d96[_0x340a('0x1d')]=qs[_0x340a('0x1d')](_0x26ecc9[_0x340a('0x33')][_0x340a('0x1d')]);_0x246d96[_0x340a('0x1a')]=qs[_0x340a('0x1a')](_0x26ecc9['query'][_0x340a('0x1a')]);}_0x246d96[_0x340a('0x39')]=qs[_0x340a('0x3a')](_0x26ecc9[_0x340a('0x33')]['sort']);_0x246d96[_0x340a('0x3b')]=qs[_0x340a('0x34')](_[_0x340a('0x3c')](_0x26ecc9[_0x340a('0x33')],_0x16d8e7[_0x340a('0x34')]));_0x246d96[_0x340a('0x3b')]['ProjectId']=_0x1b5ef4['id'];if(_0x26ecc9[_0x340a('0x33')][_0x340a('0x3d')]){_0x246d96[_0x340a('0x3b')]=_[_0x340a('0x3e')](_0x246d96['where'],{'$or':_['map'](_0x246d96[_0x340a('0x37')],function(_0x5020e2){var _0x562555={};_0x562555[_0x5020e2]={'$like':'%'+_0x26ecc9[_0x340a('0x33')][_0x340a('0x3d')]+'%'};return _0x562555;})});}_0x246d96=_['merge']({},_0x246d96,_0x26ecc9[_0x340a('0x4f')]);return db[_0x340a('0x56')][_0x340a('0x1c')]({'where':_0x246d96['where']})[_0x340a('0x22')](function(_0x422cf1){_0x509333[_0x340a('0x1c')]=_0x422cf1;if(_0x26ecc9[_0x340a('0x33')]['includeAll']){_0x246d96['include']=[{'all':!![]}];}return db[_0x340a('0x56')][_0x340a('0x41')](_0x246d96);})[_0x340a('0x22')](function(_0x271f15){_0x509333[_0x340a('0x42')]=_0x271f15;return _0x509333;});}})[_0x340a('0x22')](respondWithFilteredResult(_0x475003,_0x246d96))[_0x340a('0x43')](handleError(_0x475003,null));};exports[_0x340a('0x57')]=function(_0x25b57b,_0x317e8f,_0x4eebea){var _0x178c25={'raw':!![],'where':{}};var _0x309dc3={};var _0x180efd={'count':0x0,'rows':[]};return db[_0x340a('0x2c')][_0x340a('0x58')]({'where':{'id':_0x25b57b['params']['id']}})['then'](handleEntityNotFound(_0x317e8f,null))['then'](function(_0xb1780){if(_0xb1780){_0x309dc3[_0x340a('0x31')]=_[_0x340a('0x32')](db[_0x340a('0x59')]['rawAttributes']);_0x309dc3['query']=_['keys'](_0x25b57b[_0x340a('0x33')]);_0x309dc3[_0x340a('0x34')]=_[_0x340a('0x35')](_0x309dc3[_0x340a('0x31')],_0x309dc3[_0x340a('0x33')]);_0x178c25['attributes']=_[_0x340a('0x35')](_0x309dc3[_0x340a('0x31')],qs['fields'](_0x25b57b[_0x340a('0x33')][_0x340a('0x36')]));_0x178c25[_0x340a('0x37')]=_0x178c25[_0x340a('0x37')][_0x340a('0x38')]?_0x178c25[_0x340a('0x37')]:_0x309dc3[_0x340a('0x31')];if(!_0x25b57b['query']['hasOwnProperty'](_0x340a('0x55'))){_0x178c25[_0x340a('0x1d')]=qs[_0x340a('0x1d')](_0x25b57b[_0x340a('0x33')][_0x340a('0x1d')]);_0x178c25['offset']=qs['offset'](_0x25b57b[_0x340a('0x33')]['offset']);}_0x178c25[_0x340a('0x39')]=qs[_0x340a('0x3a')](_0x25b57b['query'][_0x340a('0x3a')]);_0x178c25[_0x340a('0x3b')]=qs[_0x340a('0x34')](_['pick'](_0x25b57b['query'],_0x309dc3[_0x340a('0x34')]));_0x178c25[_0x340a('0x3b')][_0x340a('0x5a')]=_0xb1780['id'];if(_0x25b57b[_0x340a('0x33')]['filter']){_0x178c25[_0x340a('0x3b')]=_[_0x340a('0x3e')](_0x178c25['where'],{'$or':_[_0x340a('0x2b')](_0x178c25[_0x340a('0x37')],function(_0x137ba8){var _0x51a0e1={};_0x51a0e1[_0x137ba8]={'$like':'%'+_0x25b57b[_0x340a('0x33')][_0x340a('0x3d')]+'%'};return _0x51a0e1;})});}_0x178c25=_[_0x340a('0x3e')]({},_0x178c25,_0x25b57b[_0x340a('0x4f')]);return db[_0x340a('0x59')][_0x340a('0x1c')]({'where':_0x178c25[_0x340a('0x3b')]})[_0x340a('0x22')](function(_0x328fe9){_0x180efd[_0x340a('0x1c')]=_0x328fe9;if(_0x25b57b[_0x340a('0x33')]['includeAll']){_0x178c25[_0x340a('0x4e')]=[{'all':!![]}];}return db['JscriptyAnswerReport'][_0x340a('0x41')](_0x178c25);})['then'](function(_0x180855){_0x180efd[_0x340a('0x42')]=_0x180855;return _0x180efd;});}})[_0x340a('0x22')](respondWithFilteredResult(_0x317e8f,_0x178c25))[_0x340a('0x43')](handleError(_0x317e8f,null));};function char(_0x429a7a){return _0x340a('0x5b')===typeof _0x429a7a?String[_0x340a('0x5c')][_0x340a('0x1f')](null,arguments):_0x429a7a;}function needsEncapsulation(_0x49c4cb){return!!_0x49c4cb&&(_0x49c4cb[_0x340a('0x5d')]()[_0x340a('0x5e')](char(0xd))>=0x0||_0x49c4cb['toString']()[_0x340a('0x5e')](char(0xa))>=0x0||_0x49c4cb[_0x340a('0x5d')]()['indexOf'](char(0x2c))>=0x0||_0x49c4cb[_0x340a('0x5d')]()['indexOf'](char(0x22))>=0x0);}function encapsulate(_0x1a878b){var _0x613a1c=char(0x22),_0x23cceb='\x5c'+char(0x22),_0x588b13=_0x1a878b[_0x340a('0x5d')]()['replace'](new RegExp(_0x613a1c,'g'),_0x23cceb);return _0x613a1c+_0x588b13+_0x613a1c;}exports[_0x340a('0x5f')]=function(_0x470c4f,_0x23bcf9,_0x48b715){var _0x40ea49,_0x468bd8;var _0x4d7587={'where':{'ProjectId':_0x470c4f[_0x340a('0x44')]['id']}};if(_0x470c4f[_0x340a('0x33')]['startTime']){_0x4d7587['where'][_0x340a('0x60')]=JSON['parse'](_0x470c4f[_0x340a('0x33')]['startTime']);}return db[_0x340a('0x56')][_0x340a('0x41')](_0x4d7587)[_0x340a('0x22')](handleEntityNotFound(_0x23bcf9,null))['then'](function(_0x4964e8){if(_0x4964e8){_0x40ea49=_0x4964e8;return db[_0x340a('0x61')]['findAll']({'where':{'SessionId':{'$in':_['map'](_0x40ea49,'id')},'ProjectId':_0x470c4f[_0x340a('0x44')]['id']},'order':_0x340a('0x62')});}})[_0x340a('0x22')](handleEntityNotFound(_0x23bcf9,null))[_0x340a('0x22')](function(_0x3f7cc5){if(_0x3f7cc5){_0x468bd8=_0x3f7cc5;var _0x1d4a92={};for(var _0x790c37=0x0,_0x1d7195=_0x468bd8[_0x340a('0x38')];_0x790c37<_0x1d7195;_0x790c37++){if(!_0x1d4a92[_0x340a('0x63')](_0x468bd8[_0x790c37]['questionId'])){_0x1d4a92[_0x468bd8[_0x790c37][_0x340a('0x64')]]=needsEncapsulation(_0x468bd8[_0x790c37][_0x340a('0x65')])?encapsulate(_0x468bd8[_0x790c37][_0x340a('0x65')]):_0x468bd8[_0x790c37][_0x340a('0x65')];}}var _0x45c50b=[],_0x2ec0ee={};for(var _0xfc82e9=0x0,_0x4821af=_0x40ea49[_0x340a('0x38')];_0xfc82e9<_0x4821af;_0xfc82e9++){_0x2ec0ee={'ProjectId':_0x470c4f[_0x340a('0x44')]['id'],'SessionId':_0x40ea49[_0xfc82e9]['id'],'StartTime':moment(_0x40ea49[_0xfc82e9][_0x340a('0x60')])[_0x340a('0x66')]('YYYY-MM-DD\x20HH:mm:ss')};for(var _0x3ce423=0x0,_0x289511=_0x468bd8[_0x340a('0x38')];_0x3ce423<_0x289511;_0x3ce423++){if(_0x468bd8[_0x3ce423][_0x340a('0x67')]==_0x40ea49[_0xfc82e9]['id']&&_0x1d4a92[_0x340a('0x63')](_0x468bd8[_0x3ce423][_0x340a('0x64')])){_0x2ec0ee[_0x1d4a92[_0x468bd8[_0x3ce423][_0x340a('0x64')]]]=_0x468bd8[_0x3ce423][_0x340a('0x68')];}}for(var _0x421403 in _0x1d4a92){if(!_0x2ec0ee[_0x340a('0x63')](_0x1d4a92[_0x421403])){_0x2ec0ee[_0x1d4a92[_0x421403]]=null;}}_0x45c50b['push'](_0x2ec0ee);}return _0x45c50b;}})[_0x340a('0x22')](function(_0x9ddff5){if(!_[_0x340a('0x69')](_0x9ddff5)){var _0x47cd36=toCsv(_0x9ddff5);var _0x20e2b3=Date[_0x340a('0x6a')]();fs[_0x340a('0x6b')](util[_0x340a('0x66')](_0x340a('0x6c'),_0x470c4f[_0x340a('0x44')]['id'],_0x20e2b3),_0x47cd36);_0x23bcf9['setHeader'](_0x340a('0x6d'),'attachment;\x20filename='+util[_0x340a('0x66')](_0x340a('0x6e'),_0x470c4f[_0x340a('0x44')]['id'],_0x20e2b3));_0x23bcf9[_0x340a('0x6f')](_0x340a('0x70'),_0x340a('0x71'));return _0x23bcf9[_0x340a('0x72')](util['format'](_0x340a('0x6c'),_0x470c4f[_0x340a('0x44')]['id'],_0x20e2b3));}else{return _0x23bcf9['sendStatus'](0xcc);}})['catch'](handleError(_0x23bcf9,null));};