bfd48815810f2ee2edb1a841aa421cdfc4cec7aa
[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 _0x25c2=['fs-extra','lodash','squel','crypto','desk.js','papaparse','ioredis','../../components/auth/service','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','api','../../config/environment','../../config/license/util','status','end','json','offset','undefined','limit','count','set','Content-Range','apply','reject','save','update','destroy','then','get','sendStatus','error','name','map','JscriptyProject','rawAttributes','fieldName','type','key','model','query','filters','attributes','intersection','fields','length','nolimit','sort','where','pick','filter','merge','VIRTUAL','options','includeAll','include','rows','catch','find','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','Projects','userProfileId','autoAssociation','UserProfileResource','clone','params','keys','body','createdAt','updatedAt','create','UserProfileSection','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','findOne','JscriptySessionReport','hasOwnProperty','ProjectId','findAll','getAnswers','JscriptyAnswerReport','order','fromCharCode','toString','indexOf','replace','getSummary','startTime','JscriptyQuestionReport','-createdAt','questionId','question','format','YYYY-MM-DD\x20HH:mm:ss','SessionId','answer','push','now','writeFileSync','setHeader','Content-disposition','Jscripty_Project_%d_Summary_%s.csv','Content-type','text/csv','/tmp/Jscripty_Project_%d_Summary_%s.csv','eml-format','zip-dir','fast-json-patch','moment','bluebird','util','path','to-csv','ejs'];(function(_0x35949a,_0xece70){var _0x9e2198=function(_0x5f5839){while(--_0x5f5839){_0x35949a['push'](_0x35949a['shift']());}};_0x9e2198(++_0xece70);}(_0x25c2,0xdd));var _0x225c=function(_0x2a56ad,_0x2b94bf){_0x2a56ad=_0x2a56ad-0x0;var _0x425175=_0x25c2[_0x2a56ad];return _0x425175;};'use strict';var emlformat=require(_0x225c('0x0'));var rimraf=require('rimraf');var zipdir=require(_0x225c('0x1'));var jsonpatch=require(_0x225c('0x2'));var rp=require('request-promise');var moment=require(_0x225c('0x3'));var BPromise=require(_0x225c('0x4'));var Mustache=require('mustache');var util=require(_0x225c('0x5'));var path=require(_0x225c('0x6'));var sox=require('sox');var csv=require(_0x225c('0x7'));var ejs=require(_0x225c('0x8'));var fs=require('fs');var fs_extra=require(_0x225c('0x9'));var _=require(_0x225c('0xa'));var squel=require(_0x225c('0xb'));var crypto=require(_0x225c('0xc'));var jsforce=require('jsforce');var deskjs=require(_0x225c('0xd'));var toCsv=require('to-csv');var querystring=require('querystring');var Papa=require(_0x225c('0xe'));var Redis=require(_0x225c('0xf'));var authService=require(_0x225c('0x10'));var qs=require('../../components/parsers/qs');var as=require(_0x225c('0x11'));var hardwareService=require(_0x225c('0x12'));var logger=require(_0x225c('0x13'))(_0x225c('0x14'));var utils=require('../../config/utils');var config=require(_0x225c('0x15'));var licenseUtil=require(_0x225c('0x16'));var db=require('../../mysqldb')['db'];function respondWithStatusCode(_0x1384bd,_0x45368a){_0x45368a=_0x45368a||0xcc;return function(_0x18ab23){if(_0x18ab23){return _0x1384bd['sendStatus'](_0x45368a);}return _0x1384bd[_0x225c('0x17')](_0x45368a)[_0x225c('0x18')]();};}function respondWithResult(_0x33f961,_0x39d22d){_0x39d22d=_0x39d22d||0xc8;return function(_0x1f9782){if(_0x1f9782){return _0x33f961[_0x225c('0x17')](_0x39d22d)[_0x225c('0x19')](_0x1f9782);}};}function respondWithFilteredResult(_0x1b28d3,_0x51235b){return function(_0x5a2c4b){if(_0x5a2c4b){var _0x801c1b=typeof _0x51235b[_0x225c('0x1a')]===_0x225c('0x1b')&&typeof _0x51235b[_0x225c('0x1c')]==='undefined';var _0x3e1c8a=_0x5a2c4b[_0x225c('0x1d')];var _0x3d52ba=_0x801c1b?0x0:_0x51235b[_0x225c('0x1a')];var _0x5a9da9=_0x801c1b?_0x5a2c4b['count']:_0x51235b['offset']+_0x51235b[_0x225c('0x1c')];var _0x208a1a;if(_0x5a9da9>=_0x3e1c8a){_0x5a9da9=_0x3e1c8a;_0x208a1a=0xc8;}else{_0x208a1a=0xce;}_0x1b28d3[_0x225c('0x17')](_0x208a1a);return _0x1b28d3[_0x225c('0x1e')](_0x225c('0x1f'),_0x3d52ba+'-'+_0x5a9da9+'/'+_0x3e1c8a)[_0x225c('0x19')](_0x5a2c4b);}return null;};}function patchUpdates(_0x484cd6){return function(_0x32e525){try{jsonpatch[_0x225c('0x20')](_0x32e525,_0x484cd6,!![]);}catch(_0x33c38f){return BPromise[_0x225c('0x21')](_0x33c38f);}return _0x32e525[_0x225c('0x22')]();};}function saveUpdates(_0x56bb67,_0x2696ca){return function(_0x369e41){if(_0x369e41){return _0x369e41[_0x225c('0x23')](_0x56bb67)['then'](function(_0x4e0e11){return _0x4e0e11;});}return null;};}function removeEntity(_0x167a7c,_0x4abf2c){return function(_0x355523){if(_0x355523){return _0x355523[_0x225c('0x24')]()[_0x225c('0x25')](function(){var _0x107de1=_0x355523[_0x225c('0x26')]({'plain':!![]});var _0x132f82='Projects';return db['UserProfileResource'][_0x225c('0x24')]({'where':{'type':_0x132f82,'resourceId':_0x107de1['id']}})[_0x225c('0x25')](function(){return _0x355523;});})['then'](function(){_0x167a7c[_0x225c('0x17')](0xcc)['end']();});}};}function handleEntityNotFound(_0x35acd5,_0x572380){return function(_0x5aa346){if(!_0x5aa346){_0x35acd5[_0x225c('0x27')](0x194);}return _0x5aa346;};}function handleError(_0x50ace7,_0x569685){_0x569685=_0x569685||0x1f4;return function(_0x51f413){logger[_0x225c('0x28')](_0x51f413['stack']);if(_0x51f413[_0x225c('0x29')]){delete _0x51f413[_0x225c('0x29')];}_0x50ace7[_0x225c('0x17')](_0x569685)['send'](_0x51f413);};}exports['index']=function(_0x4f17e7,_0x347f8f){var _0x75cc09={},_0x2169e1={},_0x13306e={'count':0x0,'rows':[]};var _0x5ee044=_[_0x225c('0x2a')](db[_0x225c('0x2b')][_0x225c('0x2c')],function(_0x295dde){return{'name':_0x295dde[_0x225c('0x2d')],'type':_0x295dde[_0x225c('0x2e')][_0x225c('0x2f')]};});_0x2169e1[_0x225c('0x30')]=_[_0x225c('0x2a')](_0x5ee044,_0x225c('0x29'));_0x2169e1['query']=_['keys'](_0x4f17e7[_0x225c('0x31')]);_0x2169e1[_0x225c('0x32')]=_['intersection'](_0x2169e1[_0x225c('0x30')],_0x2169e1['query']);_0x75cc09[_0x225c('0x33')]=_[_0x225c('0x34')](_0x2169e1['model'],qs['fields'](_0x4f17e7[_0x225c('0x31')][_0x225c('0x35')]));_0x75cc09[_0x225c('0x33')]=_0x75cc09[_0x225c('0x33')][_0x225c('0x36')]?_0x75cc09[_0x225c('0x33')]:_0x2169e1[_0x225c('0x30')];if(!_0x4f17e7[_0x225c('0x31')]['hasOwnProperty'](_0x225c('0x37'))){_0x75cc09[_0x225c('0x1c')]=qs['limit'](_0x4f17e7[_0x225c('0x31')][_0x225c('0x1c')]);_0x75cc09[_0x225c('0x1a')]=qs[_0x225c('0x1a')](_0x4f17e7[_0x225c('0x31')][_0x225c('0x1a')]);}_0x75cc09['order']=qs[_0x225c('0x38')](_0x4f17e7[_0x225c('0x31')]['sort']);_0x75cc09[_0x225c('0x39')]=qs[_0x225c('0x32')](_[_0x225c('0x3a')](_0x4f17e7['query'],_0x2169e1[_0x225c('0x32')]),_0x5ee044);if(_0x4f17e7[_0x225c('0x31')][_0x225c('0x3b')]){_0x75cc09[_0x225c('0x39')]=_[_0x225c('0x3c')](_0x75cc09[_0x225c('0x39')],{'$or':_[_0x225c('0x2a')](_0x5ee044,function(_0x48fbe9){if(_0x48fbe9[_0x225c('0x2e')]!==_0x225c('0x3d')){var _0x127de6={};_0x127de6[_0x48fbe9[_0x225c('0x29')]]={'$like':'%'+_0x4f17e7[_0x225c('0x31')][_0x225c('0x3b')]+'%'};return _0x127de6;}})});}_0x75cc09=_['merge']({},_0x75cc09,_0x4f17e7[_0x225c('0x3e')]);var _0xaef377={'where':_0x75cc09[_0x225c('0x39')]};return db[_0x225c('0x2b')][_0x225c('0x1d')](_0xaef377)['then'](function(_0x2048bc){_0x13306e[_0x225c('0x1d')]=_0x2048bc;if(_0x4f17e7[_0x225c('0x31')][_0x225c('0x3f')]){_0x75cc09[_0x225c('0x40')]=[{'all':!![]}];}return db[_0x225c('0x2b')]['findAll'](_0x75cc09);})[_0x225c('0x25')](function(_0x35f3b1){_0x13306e[_0x225c('0x41')]=_0x35f3b1;return _0x13306e;})[_0x225c('0x25')](respondWithFilteredResult(_0x347f8f,_0x75cc09))[_0x225c('0x42')](handleError(_0x347f8f,null));};exports['show']=function(_0x5b326c,_0x1847a6){var _0x19d3da={'raw':![],'where':{'id':_0x5b326c['params']['id']}},_0x335cd2={};_0x335cd2['model']=_['keys'](db['JscriptyProject'][_0x225c('0x2c')]);_0x335cd2[_0x225c('0x31')]=_['keys'](_0x5b326c[_0x225c('0x31')]);_0x335cd2[_0x225c('0x32')]=_[_0x225c('0x34')](_0x335cd2['model'],_0x335cd2['query']);_0x19d3da[_0x225c('0x33')]=_[_0x225c('0x34')](_0x335cd2[_0x225c('0x30')],qs[_0x225c('0x35')](_0x5b326c['query']['fields']));_0x19d3da['attributes']=_0x19d3da[_0x225c('0x33')][_0x225c('0x36')]?_0x19d3da[_0x225c('0x33')]:_0x335cd2['model'];if(_0x5b326c[_0x225c('0x31')][_0x225c('0x3f')]){_0x19d3da[_0x225c('0x40')]=[{'all':!![]}];}_0x19d3da=_[_0x225c('0x3c')]({},_0x19d3da,_0x5b326c[_0x225c('0x3e')]);return db[_0x225c('0x2b')][_0x225c('0x43')](_0x19d3da)[_0x225c('0x25')](handleEntityNotFound(_0x1847a6,null))[_0x225c('0x25')](respondWithResult(_0x1847a6,null))['catch'](handleError(_0x1847a6,null));};exports['create']=function(_0x443350,_0x1be7d6){return db[_0x225c('0x2b')]['create'](_0x443350['body'],{})[_0x225c('0x25')](function(_0x370b73){var _0x42d48d=_0x443350[_0x225c('0x44')]['get']({'plain':!![]});if(!_0x42d48d)throw new Error(_0x225c('0x45'));if(_0x42d48d[_0x225c('0x46')]===_0x225c('0x44')){var _0x38921f=_0x370b73['get']({'plain':!![]});var _0x35ddee=_0x225c('0x47');return db['UserProfileSection']['find']({'where':{'name':_0x35ddee,'userProfileId':_0x42d48d[_0x225c('0x48')]},'raw':!![]})[_0x225c('0x25')](function(_0x4ef0b8){if(_0x4ef0b8&&_0x4ef0b8[_0x225c('0x49')]===0x0){return db[_0x225c('0x4a')]['create']({'name':_0x38921f['name'],'resourceId':_0x38921f['id'],'type':_0x4ef0b8[_0x225c('0x29')],'sectionId':_0x4ef0b8['id']},{})[_0x225c('0x25')](function(){return _0x370b73;});}else{return _0x370b73;}})[_0x225c('0x42')](function(_0x1bb064){logger[_0x225c('0x28')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x1bb064);throw _0x1bb064;});}return _0x370b73;})[_0x225c('0x25')](respondWithResult(_0x1be7d6,0xc9))['catch'](handleError(_0x1be7d6,null));};exports[_0x225c('0x4b')]=function(_0x43497b,_0x587ec5){var _0x1d473b={'where':{'id':_0x43497b[_0x225c('0x4c')]['id']}},_0x3d0b7e={};_0x3d0b7e['model']=_[_0x225c('0x4d')](db[_0x225c('0x2b')][_0x225c('0x2c')]);_0x1d473b[_0x225c('0x33')]=_[_0x225c('0x34')](_0x3d0b7e[_0x225c('0x30')],qs[_0x225c('0x35')](_0x43497b['query'][_0x225c('0x35')]));_0x1d473b[_0x225c('0x33')]=_0x1d473b[_0x225c('0x33')][_0x225c('0x36')]?_0x1d473b['attributes']:_0x3d0b7e['model'];if(_0x43497b[_0x225c('0x31')][_0x225c('0x3f')]){_0x1d473b[_0x225c('0x40')]=[{'all':!![]}];}_0x1d473b=_[_0x225c('0x3c')]({},_0x1d473b,_0x43497b[_0x225c('0x3e')]);return db[_0x225c('0x2b')][_0x225c('0x43')](_0x1d473b)['then'](handleEntityNotFound(_0x587ec5,null))[_0x225c('0x25')](function(_0x2a5fb8){if(_0x2a5fb8){var _0x5a7d60=_0x2a5fb8[_0x225c('0x26')]({'plain':!![]});_0x5a7d60=qs['omit'](_0x5a7d60,['id','createdAt','updatedAt']);_0x43497b[_0x225c('0x4e')]=_['omit'](_0x43497b['body'],['id',_0x225c('0x4f'),_0x225c('0x50')]);return db['JscriptyProject'][_0x225c('0x51')](_[_0x225c('0x3c')](_0x5a7d60,_0x43497b[_0x225c('0x4e')]),{'include':_0x43497b['query'][_0x225c('0x3f')]?[{'all':!![]}]:undefined})[_0x225c('0x25')](function(_0x4e93e1){var _0x777aa0=_0x43497b[_0x225c('0x44')][_0x225c('0x26')]({'plain':!![]});if(!_0x777aa0)throw new Error(_0x225c('0x45'));if(_0x777aa0['role']===_0x225c('0x44')){var _0x3d62b1=_0x4e93e1[_0x225c('0x26')]({'plain':!![]});var _0x53a31b='Projects';return db[_0x225c('0x52')][_0x225c('0x43')]({'where':{'name':_0x53a31b,'userProfileId':_0x777aa0[_0x225c('0x48')]},'raw':!![]})[_0x225c('0x25')](function(_0x2ee88c){if(_0x2ee88c&&_0x2ee88c['autoAssociation']===0x0){return db[_0x225c('0x4a')][_0x225c('0x51')]({'name':_0x3d62b1[_0x225c('0x29')],'resourceId':_0x3d62b1['id'],'type':_0x2ee88c[_0x225c('0x29')],'sectionId':_0x2ee88c['id']},{})[_0x225c('0x25')](function(){return _0x4e93e1;});}else{return _0x4e93e1;}})['catch'](function(_0x55541c){logger[_0x225c('0x28')](_0x225c('0x53'),_0x55541c);throw _0x55541c;});}return _0x4e93e1;});}})[_0x225c('0x25')](respondWithResult(_0x587ec5,0xc9))['catch'](handleError(_0x587ec5,null));};exports['update']=function(_0x5585e1,_0x13147b){if(_0x5585e1[_0x225c('0x4e')]['id']){delete _0x5585e1[_0x225c('0x4e')]['id'];}return db[_0x225c('0x2b')][_0x225c('0x43')]({'where':{'id':_0x5585e1[_0x225c('0x4c')]['id']}})[_0x225c('0x25')](handleEntityNotFound(_0x13147b,null))['then'](saveUpdates(_0x5585e1[_0x225c('0x4e')],null))[_0x225c('0x25')](respondWithResult(_0x13147b,null))[_0x225c('0x42')](handleError(_0x13147b,null));};exports[_0x225c('0x24')]=function(_0x376dc8,_0x58c8ab){return db['JscriptyProject']['find']({'where':{'id':_0x376dc8[_0x225c('0x4c')]['id']}})[_0x225c('0x25')](handleEntityNotFound(_0x58c8ab,null))[_0x225c('0x25')](removeEntity(_0x58c8ab,null))[_0x225c('0x42')](handleError(_0x58c8ab,null));};exports['getSessions']=function(_0x16abff,_0x1583e4,_0xb0ba24){var _0x2510b3={'raw':!![],'where':{}};var _0x795c86={};var _0x6c9775={'count':0x0,'rows':[]};return db[_0x225c('0x2b')][_0x225c('0x54')]({'where':{'id':_0x16abff['params']['id']}})[_0x225c('0x25')](handleEntityNotFound(_0x1583e4,null))[_0x225c('0x25')](function(_0x124ecc){if(_0x124ecc){_0x795c86[_0x225c('0x30')]=_['keys'](db[_0x225c('0x55')][_0x225c('0x2c')]);_0x795c86[_0x225c('0x31')]=_[_0x225c('0x4d')](_0x16abff[_0x225c('0x31')]);_0x795c86[_0x225c('0x32')]=_[_0x225c('0x34')](_0x795c86[_0x225c('0x30')],_0x795c86[_0x225c('0x31')]);_0x2510b3['attributes']=_['intersection'](_0x795c86['model'],qs[_0x225c('0x35')](_0x16abff[_0x225c('0x31')]['fields']));_0x2510b3[_0x225c('0x33')]=_0x2510b3[_0x225c('0x33')]['length']?_0x2510b3['attributes']:_0x795c86[_0x225c('0x30')];if(!_0x16abff[_0x225c('0x31')][_0x225c('0x56')](_0x225c('0x37'))){_0x2510b3[_0x225c('0x1c')]=qs[_0x225c('0x1c')](_0x16abff[_0x225c('0x31')][_0x225c('0x1c')]);_0x2510b3[_0x225c('0x1a')]=qs[_0x225c('0x1a')](_0x16abff[_0x225c('0x31')][_0x225c('0x1a')]);}_0x2510b3['order']=qs[_0x225c('0x38')](_0x16abff[_0x225c('0x31')][_0x225c('0x38')]);_0x2510b3['where']=qs[_0x225c('0x32')](_[_0x225c('0x3a')](_0x16abff[_0x225c('0x31')],_0x795c86[_0x225c('0x32')]));_0x2510b3['where'][_0x225c('0x57')]=_0x124ecc['id'];if(_0x16abff[_0x225c('0x31')][_0x225c('0x3b')]){_0x2510b3['where']=_[_0x225c('0x3c')](_0x2510b3[_0x225c('0x39')],{'$or':_[_0x225c('0x2a')](_0x2510b3[_0x225c('0x33')],function(_0x43658f){var _0x21b103={};_0x21b103[_0x43658f]={'$like':'%'+_0x16abff[_0x225c('0x31')][_0x225c('0x3b')]+'%'};return _0x21b103;})});}_0x2510b3=_[_0x225c('0x3c')]({},_0x2510b3,_0x16abff['options']);return db[_0x225c('0x55')][_0x225c('0x1d')]({'where':_0x2510b3[_0x225c('0x39')]})[_0x225c('0x25')](function(_0xa01ece){_0x6c9775[_0x225c('0x1d')]=_0xa01ece;if(_0x16abff['query'][_0x225c('0x3f')]){_0x2510b3[_0x225c('0x40')]=[{'all':!![]}];}return db['JscriptySessionReport'][_0x225c('0x58')](_0x2510b3);})[_0x225c('0x25')](function(_0x403c94){_0x6c9775[_0x225c('0x41')]=_0x403c94;return _0x6c9775;});}})[_0x225c('0x25')](respondWithFilteredResult(_0x1583e4,_0x2510b3))[_0x225c('0x42')](handleError(_0x1583e4,null));};exports[_0x225c('0x59')]=function(_0x1b1a85,_0x28ae3a,_0x5df5bf){var _0x191867={'raw':!![],'where':{}};var _0x4f172f={};var _0x5cdd44={'count':0x0,'rows':[]};return db[_0x225c('0x2b')]['findOne']({'where':{'id':_0x1b1a85[_0x225c('0x4c')]['id']}})[_0x225c('0x25')](handleEntityNotFound(_0x28ae3a,null))['then'](function(_0x2dfdd5){if(_0x2dfdd5){_0x4f172f[_0x225c('0x30')]=_[_0x225c('0x4d')](db[_0x225c('0x5a')][_0x225c('0x2c')]);_0x4f172f[_0x225c('0x31')]=_['keys'](_0x1b1a85['query']);_0x4f172f[_0x225c('0x32')]=_[_0x225c('0x34')](_0x4f172f[_0x225c('0x30')],_0x4f172f[_0x225c('0x31')]);_0x191867['attributes']=_[_0x225c('0x34')](_0x4f172f['model'],qs[_0x225c('0x35')](_0x1b1a85['query'][_0x225c('0x35')]));_0x191867[_0x225c('0x33')]=_0x191867[_0x225c('0x33')]['length']?_0x191867[_0x225c('0x33')]:_0x4f172f[_0x225c('0x30')];if(!_0x1b1a85['query'][_0x225c('0x56')]('nolimit')){_0x191867[_0x225c('0x1c')]=qs[_0x225c('0x1c')](_0x1b1a85[_0x225c('0x31')]['limit']);_0x191867[_0x225c('0x1a')]=qs[_0x225c('0x1a')](_0x1b1a85[_0x225c('0x31')][_0x225c('0x1a')]);}_0x191867[_0x225c('0x5b')]=qs[_0x225c('0x38')](_0x1b1a85[_0x225c('0x31')][_0x225c('0x38')]);_0x191867[_0x225c('0x39')]=qs['filters'](_[_0x225c('0x3a')](_0x1b1a85[_0x225c('0x31')],_0x4f172f[_0x225c('0x32')]));_0x191867[_0x225c('0x39')][_0x225c('0x57')]=_0x2dfdd5['id'];if(_0x1b1a85[_0x225c('0x31')][_0x225c('0x3b')]){_0x191867['where']=_[_0x225c('0x3c')](_0x191867['where'],{'$or':_[_0x225c('0x2a')](_0x191867[_0x225c('0x33')],function(_0x5643a9){var _0x360bc9={};_0x360bc9[_0x5643a9]={'$like':'%'+_0x1b1a85[_0x225c('0x31')][_0x225c('0x3b')]+'%'};return _0x360bc9;})});}_0x191867=_[_0x225c('0x3c')]({},_0x191867,_0x1b1a85[_0x225c('0x3e')]);return db[_0x225c('0x5a')][_0x225c('0x1d')]({'where':_0x191867[_0x225c('0x39')]})[_0x225c('0x25')](function(_0x487b3b){_0x5cdd44['count']=_0x487b3b;if(_0x1b1a85['query'][_0x225c('0x3f')]){_0x191867[_0x225c('0x40')]=[{'all':!![]}];}return db['JscriptyAnswerReport']['findAll'](_0x191867);})[_0x225c('0x25')](function(_0x222852){_0x5cdd44['rows']=_0x222852;return _0x5cdd44;});}})[_0x225c('0x25')](respondWithFilteredResult(_0x28ae3a,_0x191867))[_0x225c('0x42')](handleError(_0x28ae3a,null));};function char(_0x37befa){return'number'===typeof _0x37befa?String[_0x225c('0x5c')]['apply'](null,arguments):_0x37befa;}function needsEncapsulation(_0x1ae02f){return!!_0x1ae02f&&(_0x1ae02f[_0x225c('0x5d')]()[_0x225c('0x5e')](char(0xd))>=0x0||_0x1ae02f[_0x225c('0x5d')]()[_0x225c('0x5e')](char(0xa))>=0x0||_0x1ae02f['toString']()[_0x225c('0x5e')](char(0x2c))>=0x0||_0x1ae02f['toString']()['indexOf'](char(0x22))>=0x0);}function encapsulate(_0x4fbe9b){var _0x348d11=char(0x22),_0x564f77='\x5c'+char(0x22),_0x279569=_0x4fbe9b['toString']()[_0x225c('0x5f')](new RegExp(_0x348d11,'g'),_0x564f77);return _0x348d11+_0x279569+_0x348d11;}exports[_0x225c('0x60')]=function(_0x171590,_0x1fbfc3,_0x303991){var _0x4321b3,_0x1bd9cd;var _0x5f4ead={'where':{'ProjectId':_0x171590[_0x225c('0x4c')]['id']}};if(_0x171590[_0x225c('0x31')][_0x225c('0x61')]){_0x5f4ead['where']['starttime']=JSON['parse'](_0x171590['query']['startTime']);}return db[_0x225c('0x55')]['findAll'](_0x5f4ead)[_0x225c('0x25')](handleEntityNotFound(_0x1fbfc3,null))['then'](function(_0x3099a0){if(_0x3099a0){_0x4321b3=_0x3099a0;return db[_0x225c('0x62')][_0x225c('0x58')]({'where':{'SessionId':{'$in':_[_0x225c('0x2a')](_0x4321b3,'id')},'ProjectId':_0x171590[_0x225c('0x4c')]['id']},'order':_0x225c('0x63')});}})['then'](handleEntityNotFound(_0x1fbfc3,null))['then'](function(_0x28e978){if(_0x28e978){_0x1bd9cd=_0x28e978;var _0x31e024={};for(var _0x25139e=0x0,_0x5114a3=_0x1bd9cd[_0x225c('0x36')];_0x25139e<_0x5114a3;_0x25139e++){if(!_0x31e024[_0x225c('0x56')](_0x1bd9cd[_0x25139e][_0x225c('0x64')])){_0x31e024[_0x1bd9cd[_0x25139e][_0x225c('0x64')]]=needsEncapsulation(_0x1bd9cd[_0x25139e][_0x225c('0x65')])?encapsulate(_0x1bd9cd[_0x25139e][_0x225c('0x65')]):_0x1bd9cd[_0x25139e][_0x225c('0x65')];}}var _0x5d94fb=[],_0x33322a={};for(var _0x7e1212=0x0,_0x13a34b=_0x4321b3[_0x225c('0x36')];_0x7e1212<_0x13a34b;_0x7e1212++){_0x33322a={'ProjectId':_0x171590[_0x225c('0x4c')]['id'],'SessionId':_0x4321b3[_0x7e1212]['id'],'StartTime':moment(_0x4321b3[_0x7e1212]['starttime'])[_0x225c('0x66')](_0x225c('0x67'))};for(var _0x1ed6c2=0x0,_0x3e1140=_0x1bd9cd[_0x225c('0x36')];_0x1ed6c2<_0x3e1140;_0x1ed6c2++){if(_0x1bd9cd[_0x1ed6c2][_0x225c('0x68')]==_0x4321b3[_0x7e1212]['id']&&_0x31e024['hasOwnProperty'](_0x1bd9cd[_0x1ed6c2]['questionId'])){_0x33322a[_0x31e024[_0x1bd9cd[_0x1ed6c2]['questionId']]]=_0x1bd9cd[_0x1ed6c2][_0x225c('0x69')];}}for(var _0x1c10d7 in _0x31e024){if(!_0x33322a[_0x225c('0x56')](_0x31e024[_0x1c10d7])){_0x33322a[_0x31e024[_0x1c10d7]]=null;}}_0x5d94fb[_0x225c('0x6a')](_0x33322a);}return _0x5d94fb;}})['then'](function(_0x99ec09){if(!_['isEmpty'](_0x99ec09)){var _0x514be4=toCsv(_0x99ec09);var _0x45469b=Date[_0x225c('0x6b')]();fs[_0x225c('0x6c')](util[_0x225c('0x66')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0x171590[_0x225c('0x4c')]['id'],_0x45469b),_0x514be4);_0x1fbfc3[_0x225c('0x6d')](_0x225c('0x6e'),'attachment;\x20filename='+util[_0x225c('0x66')](_0x225c('0x6f'),_0x171590['params']['id'],_0x45469b));_0x1fbfc3[_0x225c('0x6d')](_0x225c('0x70'),_0x225c('0x71'));return _0x1fbfc3['download'](util[_0x225c('0x66')](_0x225c('0x72'),_0x171590[_0x225c('0x4c')]['id'],_0x45469b));}else{return _0x1fbfc3[_0x225c('0x27')](0xcc);}})[_0x225c('0x42')](handleError(_0x1fbfc3,null));};