Built motion from commit a61a4a20.|2.5.46
[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 _0x5ba3=['querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/advancedSearch','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','sendStatus','end','json','undefined','limit','count','status','set','Content-Range','apply','reject','save','update','then','UserProfileResource','destroy','error','stack','name','send','index','JscriptyProject','rawAttributes','fieldName','model','map','keys','filters','intersection','attributes','fields','nolimit','offset','order','sort','query','where','pick','filter','merge','options','includeAll','include','findAll','rows','catch','show','params','find','create','body','get','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','autoAssociation','length','createdAt','omit','user','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','getSessions','JscriptySessionReport','hasOwnProperty','getAnswers','findOne','JscriptyAnswerReport','number','toString','indexOf','replace','getSummary','startTime','JscriptyQuestionReport','questionId','question','YYYY-MM-DD\x20HH:mm:ss','SessionId','answer','now','writeFileSync','format','/tmp/Jscripty_Project_%d_Summary_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','Jscripty_Project_%d_Summary_%s.csv','Content-type','text/csv','download','eml-format','zip-dir','fast-json-patch','moment','bluebird','mustache','path','sox','to-csv','lodash','squel','crypto','desk.js'];(function(_0x56e4e7,_0x1db098){var _0x383618=function(_0xb088c6){while(--_0xb088c6){_0x56e4e7['push'](_0x56e4e7['shift']());}};_0x383618(++_0x1db098);}(_0x5ba3,0x140));var _0x35ba=function(_0x5e4836,_0x17155e){_0x5e4836=_0x5e4836-0x0;var _0x7fb581=_0x5ba3[_0x5e4836];return _0x7fb581;};'use strict';var emlformat=require(_0x35ba('0x0'));var rimraf=require('rimraf');var zipdir=require(_0x35ba('0x1'));var jsonpatch=require(_0x35ba('0x2'));var rp=require('request-promise');var moment=require(_0x35ba('0x3'));var BPromise=require(_0x35ba('0x4'));var Mustache=require(_0x35ba('0x5'));var util=require('util');var path=require(_0x35ba('0x6'));var sox=require(_0x35ba('0x7'));var csv=require(_0x35ba('0x8'));var ejs=require('ejs');var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0x35ba('0x9'));var squel=require(_0x35ba('0xa'));var crypto=require(_0x35ba('0xb'));var jsforce=require('jsforce');var deskjs=require(_0x35ba('0xc'));var toCsv=require('to-csv');var querystring=require(_0x35ba('0xd'));var Papa=require(_0x35ba('0xe'));var Redis=require(_0x35ba('0xf'));var authService=require(_0x35ba('0x10'));var qs=require('../../components/parsers/qs');var as=require(_0x35ba('0x11'));var hardwareService=require('../../config/license/hardware');var logger=require('../../config/logger')('api');var utils=require(_0x35ba('0x12'));var config=require(_0x35ba('0x13'));var licenseUtil=require(_0x35ba('0x14'));var db=require(_0x35ba('0x15'))['db'];function respondWithStatusCode(_0x3755c0,_0x203e6e){_0x203e6e=_0x203e6e||0xcc;return function(_0x23c253){if(_0x23c253){return _0x3755c0[_0x35ba('0x16')](_0x203e6e);}return _0x3755c0['status'](_0x203e6e)[_0x35ba('0x17')]();};}function respondWithResult(_0x169a24,_0x3ad4cc){_0x3ad4cc=_0x3ad4cc||0xc8;return function(_0x249caf){if(_0x249caf){return _0x169a24['status'](_0x3ad4cc)[_0x35ba('0x18')](_0x249caf);}};}function respondWithFilteredResult(_0x58b608,_0x50bf46){return function(_0x2372f7){if(_0x2372f7){var _0x71a8b=typeof _0x50bf46['offset']===_0x35ba('0x19')&&typeof _0x50bf46[_0x35ba('0x1a')]===_0x35ba('0x19');var _0x32b9e4=_0x2372f7[_0x35ba('0x1b')];var _0x374f91=_0x71a8b?0x0:_0x50bf46['offset'];var _0x423666=_0x71a8b?_0x2372f7[_0x35ba('0x1b')]:_0x50bf46['offset']+_0x50bf46[_0x35ba('0x1a')];var _0x1d73a2;if(_0x423666>=_0x32b9e4){_0x423666=_0x32b9e4;_0x1d73a2=0xc8;}else{_0x1d73a2=0xce;}_0x58b608[_0x35ba('0x1c')](_0x1d73a2);return _0x58b608[_0x35ba('0x1d')](_0x35ba('0x1e'),_0x374f91+'-'+_0x423666+'/'+_0x32b9e4)[_0x35ba('0x18')](_0x2372f7);}return null;};}function patchUpdates(_0x3f5e92){return function(_0x430522){try{jsonpatch[_0x35ba('0x1f')](_0x430522,_0x3f5e92,!![]);}catch(_0x205889){return BPromise[_0x35ba('0x20')](_0x205889);}return _0x430522[_0x35ba('0x21')]();};}function saveUpdates(_0x4e4c09,_0x2d3b2b){return function(_0xba9dbc){if(_0xba9dbc){return _0xba9dbc[_0x35ba('0x22')](_0x4e4c09)[_0x35ba('0x23')](function(_0x29a25f){return _0x29a25f;});}return null;};}function removeEntity(_0x1a638a,_0xa9080b){return function(_0x439f43){if(_0x439f43){return _0x439f43['destroy']()[_0x35ba('0x23')](function(){var _0x53fd3d=_0x439f43['get']({'plain':!![]});var _0x1cffd9='Projects';return db[_0x35ba('0x24')][_0x35ba('0x25')]({'where':{'type':_0x1cffd9,'resourceId':_0x53fd3d['id']}})[_0x35ba('0x23')](function(){return _0x439f43;});})[_0x35ba('0x23')](function(){_0x1a638a[_0x35ba('0x1c')](0xcc)[_0x35ba('0x17')]();});}};}function handleEntityNotFound(_0x246198,_0x25fc3b){return function(_0x13b8fb){if(!_0x13b8fb){_0x246198[_0x35ba('0x16')](0x194);}return _0x13b8fb;};}function handleError(_0x40f2fc,_0x1d3d7f){_0x1d3d7f=_0x1d3d7f||0x1f4;return function(_0x38112f){logger[_0x35ba('0x26')](_0x38112f[_0x35ba('0x27')]);if(_0x38112f[_0x35ba('0x28')]){delete _0x38112f['name'];}_0x40f2fc[_0x35ba('0x1c')](_0x1d3d7f)[_0x35ba('0x29')](_0x38112f);};}exports[_0x35ba('0x2a')]=function(_0x2185dd,_0xe022f2){var _0x1eceef={},_0xe130c5={},_0x246981={'count':0x0,'rows':[]};var _0x1cb674=_['map'](db[_0x35ba('0x2b')][_0x35ba('0x2c')],function(_0x1c2b6e){return{'name':_0x1c2b6e[_0x35ba('0x2d')],'type':_0x1c2b6e['type']['key']};});_0xe130c5[_0x35ba('0x2e')]=_[_0x35ba('0x2f')](_0x1cb674,_0x35ba('0x28'));_0xe130c5['query']=_[_0x35ba('0x30')](_0x2185dd['query']);_0xe130c5[_0x35ba('0x31')]=_[_0x35ba('0x32')](_0xe130c5['model'],_0xe130c5['query']);_0x1eceef[_0x35ba('0x33')]=_[_0x35ba('0x32')](_0xe130c5[_0x35ba('0x2e')],qs[_0x35ba('0x34')](_0x2185dd['query'][_0x35ba('0x34')]));_0x1eceef[_0x35ba('0x33')]=_0x1eceef[_0x35ba('0x33')]['length']?_0x1eceef[_0x35ba('0x33')]:_0xe130c5[_0x35ba('0x2e')];if(!_0x2185dd['query']['hasOwnProperty'](_0x35ba('0x35'))){_0x1eceef[_0x35ba('0x1a')]=qs['limit'](_0x2185dd['query']['limit']);_0x1eceef[_0x35ba('0x36')]=qs['offset'](_0x2185dd['query'][_0x35ba('0x36')]);}_0x1eceef[_0x35ba('0x37')]=qs[_0x35ba('0x38')](_0x2185dd[_0x35ba('0x39')][_0x35ba('0x38')]);_0x1eceef[_0x35ba('0x3a')]=qs[_0x35ba('0x31')](_[_0x35ba('0x3b')](_0x2185dd[_0x35ba('0x39')],_0xe130c5[_0x35ba('0x31')]),_0x1cb674);if(_0x2185dd[_0x35ba('0x39')][_0x35ba('0x3c')]){_0x1eceef['where']=_[_0x35ba('0x3d')](_0x1eceef['where'],{'$or':_[_0x35ba('0x2f')](_0x1cb674,function(_0x3267a1){if(_0x3267a1['type']!=='VIRTUAL'){var _0x172e0a={};_0x172e0a[_0x3267a1['name']]={'$like':'%'+_0x2185dd['query']['filter']+'%'};return _0x172e0a;}})});}_0x1eceef=_[_0x35ba('0x3d')]({},_0x1eceef,_0x2185dd[_0x35ba('0x3e')]);var _0x1019c7={'where':_0x1eceef['where']};return db[_0x35ba('0x2b')]['count'](_0x1019c7)[_0x35ba('0x23')](function(_0x58481a){_0x246981[_0x35ba('0x1b')]=_0x58481a;if(_0x2185dd[_0x35ba('0x39')][_0x35ba('0x3f')]){_0x1eceef[_0x35ba('0x40')]=[{'all':!![]}];}return db['JscriptyProject'][_0x35ba('0x41')](_0x1eceef);})[_0x35ba('0x23')](function(_0x51c9e1){_0x246981[_0x35ba('0x42')]=_0x51c9e1;return _0x246981;})[_0x35ba('0x23')](respondWithFilteredResult(_0xe022f2,_0x1eceef))[_0x35ba('0x43')](handleError(_0xe022f2,null));};exports[_0x35ba('0x44')]=function(_0x170e5c,_0x16f559){var _0x433077={'raw':![],'where':{'id':_0x170e5c[_0x35ba('0x45')]['id']}},_0xe86741={};_0xe86741[_0x35ba('0x2e')]=_['keys'](db[_0x35ba('0x2b')][_0x35ba('0x2c')]);_0xe86741[_0x35ba('0x39')]=_[_0x35ba('0x30')](_0x170e5c[_0x35ba('0x39')]);_0xe86741[_0x35ba('0x31')]=_[_0x35ba('0x32')](_0xe86741[_0x35ba('0x2e')],_0xe86741[_0x35ba('0x39')]);_0x433077[_0x35ba('0x33')]=_[_0x35ba('0x32')](_0xe86741['model'],qs[_0x35ba('0x34')](_0x170e5c[_0x35ba('0x39')]['fields']));_0x433077[_0x35ba('0x33')]=_0x433077[_0x35ba('0x33')]['length']?_0x433077[_0x35ba('0x33')]:_0xe86741[_0x35ba('0x2e')];if(_0x170e5c[_0x35ba('0x39')][_0x35ba('0x3f')]){_0x433077[_0x35ba('0x40')]=[{'all':!![]}];}_0x433077=_[_0x35ba('0x3d')]({},_0x433077,_0x170e5c[_0x35ba('0x3e')]);return db[_0x35ba('0x2b')][_0x35ba('0x46')](_0x433077)['then'](handleEntityNotFound(_0x16f559,null))['then'](respondWithResult(_0x16f559,null))[_0x35ba('0x43')](handleError(_0x16f559,null));};exports[_0x35ba('0x47')]=function(_0xe2dd75,_0x55bc33){return db[_0x35ba('0x2b')]['create'](_0xe2dd75[_0x35ba('0x48')],{})[_0x35ba('0x23')](function(_0x4791b0){var _0x4075ac=_0xe2dd75['user'][_0x35ba('0x49')]({'plain':!![]});if(!_0x4075ac)throw new Error(_0x35ba('0x4a'));if(_0x4075ac[_0x35ba('0x4b')]==='user'){var _0x760f60=_0x4791b0[_0x35ba('0x49')]({'plain':!![]});var _0x2f7877='Projects';return db['UserProfileSection']['find']({'where':{'name':_0x2f7877,'userProfileId':_0x4075ac['userProfileId']},'raw':!![]})[_0x35ba('0x23')](function(_0x12f0c5){if(_0x12f0c5&&_0x12f0c5[_0x35ba('0x4c')]===0x0){return db[_0x35ba('0x24')][_0x35ba('0x47')]({'name':_0x760f60[_0x35ba('0x28')],'resourceId':_0x760f60['id'],'type':_0x12f0c5[_0x35ba('0x28')],'sectionId':_0x12f0c5['id']},{})[_0x35ba('0x23')](function(){return _0x4791b0;});}else{return _0x4791b0;}})[_0x35ba('0x43')](function(_0x18bb1f){logger[_0x35ba('0x26')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x18bb1f);throw _0x18bb1f;});}return _0x4791b0;})['then'](respondWithResult(_0x55bc33,0xc9))[_0x35ba('0x43')](handleError(_0x55bc33,null));};exports['clone']=function(_0xdb9d74,_0x4b8bf7){var _0x55f904={'where':{'id':_0xdb9d74['params']['id']}},_0x15744c={};_0x15744c[_0x35ba('0x2e')]=_[_0x35ba('0x30')](db['JscriptyProject'][_0x35ba('0x2c')]);_0x55f904[_0x35ba('0x33')]=_[_0x35ba('0x32')](_0x15744c[_0x35ba('0x2e')],qs['fields'](_0xdb9d74[_0x35ba('0x39')]['fields']));_0x55f904[_0x35ba('0x33')]=_0x55f904[_0x35ba('0x33')][_0x35ba('0x4d')]?_0x55f904[_0x35ba('0x33')]:_0x15744c[_0x35ba('0x2e')];if(_0xdb9d74['query'][_0x35ba('0x3f')]){_0x55f904[_0x35ba('0x40')]=[{'all':!![]}];}_0x55f904=_['merge']({},_0x55f904,_0xdb9d74[_0x35ba('0x3e')]);return db['JscriptyProject']['find'](_0x55f904)[_0x35ba('0x23')](handleEntityNotFound(_0x4b8bf7,null))['then'](function(_0x2766a9){if(_0x2766a9){var _0x441324=_0x2766a9[_0x35ba('0x49')]({'plain':!![]});_0x441324=qs['omit'](_0x441324,['id',_0x35ba('0x4e'),'updatedAt']);_0xdb9d74[_0x35ba('0x48')]=_[_0x35ba('0x4f')](_0xdb9d74[_0x35ba('0x48')],['id',_0x35ba('0x4e'),'updatedAt']);return db['JscriptyProject']['create'](_['merge'](_0x441324,_0xdb9d74[_0x35ba('0x48')]),{'include':_0xdb9d74['query'][_0x35ba('0x3f')]?[{'all':!![]}]:undefined})[_0x35ba('0x23')](function(_0x2979a8){var _0x16ee0f=_0xdb9d74[_0x35ba('0x50')][_0x35ba('0x49')]({'plain':!![]});if(!_0x16ee0f)throw new Error(_0x35ba('0x4a'));if(_0x16ee0f['role']===_0x35ba('0x50')){var _0x20d08c=_0x2979a8[_0x35ba('0x49')]({'plain':!![]});var _0x234f78='Projects';return db['UserProfileSection'][_0x35ba('0x46')]({'where':{'name':_0x234f78,'userProfileId':_0x16ee0f['userProfileId']},'raw':!![]})[_0x35ba('0x23')](function(_0x106510){if(_0x106510&&_0x106510['autoAssociation']===0x0){return db[_0x35ba('0x24')][_0x35ba('0x47')]({'name':_0x20d08c[_0x35ba('0x28')],'resourceId':_0x20d08c['id'],'type':_0x106510[_0x35ba('0x28')],'sectionId':_0x106510['id']},{})[_0x35ba('0x23')](function(){return _0x2979a8;});}else{return _0x2979a8;}})['catch'](function(_0x184b72){logger['error'](_0x35ba('0x51'),_0x184b72);throw _0x184b72;});}return _0x2979a8;});}})[_0x35ba('0x23')](respondWithResult(_0x4b8bf7,0xc9))['catch'](handleError(_0x4b8bf7,null));};exports['update']=function(_0x1a856a,_0x53d9c7){if(_0x1a856a[_0x35ba('0x48')]['id']){delete _0x1a856a[_0x35ba('0x48')]['id'];}return db[_0x35ba('0x2b')]['find']({'where':{'id':_0x1a856a['params']['id']}})[_0x35ba('0x23')](handleEntityNotFound(_0x53d9c7,null))[_0x35ba('0x23')](saveUpdates(_0x1a856a['body'],null))[_0x35ba('0x23')](respondWithResult(_0x53d9c7,null))[_0x35ba('0x43')](handleError(_0x53d9c7,null));};exports[_0x35ba('0x25')]=function(_0x2b001b,_0x1ad5e6){return db[_0x35ba('0x2b')][_0x35ba('0x46')]({'where':{'id':_0x2b001b[_0x35ba('0x45')]['id']}})[_0x35ba('0x23')](handleEntityNotFound(_0x1ad5e6,null))['then'](removeEntity(_0x1ad5e6,null))[_0x35ba('0x43')](handleError(_0x1ad5e6,null));};exports[_0x35ba('0x52')]=function(_0x62ac22,_0x5eb454,_0x4b8994){var _0x17e870={'raw':!![],'where':{}};var _0x327918={};var _0x4de3d6={'count':0x0,'rows':[]};return db[_0x35ba('0x2b')]['findOne']({'where':{'id':_0x62ac22[_0x35ba('0x45')]['id']}})[_0x35ba('0x23')](handleEntityNotFound(_0x5eb454,null))[_0x35ba('0x23')](function(_0x5d3b60){if(_0x5d3b60){_0x327918[_0x35ba('0x2e')]=_[_0x35ba('0x30')](db[_0x35ba('0x53')][_0x35ba('0x2c')]);_0x327918['query']=_[_0x35ba('0x30')](_0x62ac22['query']);_0x327918[_0x35ba('0x31')]=_[_0x35ba('0x32')](_0x327918['model'],_0x327918['query']);_0x17e870[_0x35ba('0x33')]=_['intersection'](_0x327918[_0x35ba('0x2e')],qs[_0x35ba('0x34')](_0x62ac22['query'][_0x35ba('0x34')]));_0x17e870['attributes']=_0x17e870[_0x35ba('0x33')][_0x35ba('0x4d')]?_0x17e870[_0x35ba('0x33')]:_0x327918[_0x35ba('0x2e')];if(!_0x62ac22[_0x35ba('0x39')][_0x35ba('0x54')](_0x35ba('0x35'))){_0x17e870[_0x35ba('0x1a')]=qs['limit'](_0x62ac22[_0x35ba('0x39')][_0x35ba('0x1a')]);_0x17e870[_0x35ba('0x36')]=qs[_0x35ba('0x36')](_0x62ac22[_0x35ba('0x39')]['offset']);}_0x17e870['order']=qs[_0x35ba('0x38')](_0x62ac22[_0x35ba('0x39')][_0x35ba('0x38')]);_0x17e870[_0x35ba('0x3a')]=qs[_0x35ba('0x31')](_['pick'](_0x62ac22['query'],_0x327918[_0x35ba('0x31')]));_0x17e870[_0x35ba('0x3a')]['ProjectId']=_0x5d3b60['id'];if(_0x62ac22['query'][_0x35ba('0x3c')]){_0x17e870[_0x35ba('0x3a')]=_[_0x35ba('0x3d')](_0x17e870[_0x35ba('0x3a')],{'$or':_[_0x35ba('0x2f')](_0x17e870[_0x35ba('0x33')],function(_0x4c28b1){var _0x3b66f1={};_0x3b66f1[_0x4c28b1]={'$like':'%'+_0x62ac22['query'][_0x35ba('0x3c')]+'%'};return _0x3b66f1;})});}_0x17e870=_[_0x35ba('0x3d')]({},_0x17e870,_0x62ac22[_0x35ba('0x3e')]);return db[_0x35ba('0x53')][_0x35ba('0x1b')]({'where':_0x17e870[_0x35ba('0x3a')]})[_0x35ba('0x23')](function(_0x590ea5){_0x4de3d6[_0x35ba('0x1b')]=_0x590ea5;if(_0x62ac22[_0x35ba('0x39')][_0x35ba('0x3f')]){_0x17e870[_0x35ba('0x40')]=[{'all':!![]}];}return db[_0x35ba('0x53')][_0x35ba('0x41')](_0x17e870);})[_0x35ba('0x23')](function(_0x14a26d){_0x4de3d6['rows']=_0x14a26d;return _0x4de3d6;});}})[_0x35ba('0x23')](respondWithFilteredResult(_0x5eb454,_0x17e870))[_0x35ba('0x43')](handleError(_0x5eb454,null));};exports[_0x35ba('0x55')]=function(_0x4aeded,_0x28a39c,_0x2fc472){var _0x2cb290={'raw':!![],'where':{}};var _0x4384d4={};var _0xe7ab={'count':0x0,'rows':[]};return db[_0x35ba('0x2b')][_0x35ba('0x56')]({'where':{'id':_0x4aeded[_0x35ba('0x45')]['id']}})[_0x35ba('0x23')](handleEntityNotFound(_0x28a39c,null))[_0x35ba('0x23')](function(_0x3f1347){if(_0x3f1347){_0x4384d4['model']=_[_0x35ba('0x30')](db['JscriptyAnswerReport'][_0x35ba('0x2c')]);_0x4384d4['query']=_[_0x35ba('0x30')](_0x4aeded['query']);_0x4384d4[_0x35ba('0x31')]=_[_0x35ba('0x32')](_0x4384d4['model'],_0x4384d4['query']);_0x2cb290[_0x35ba('0x33')]=_[_0x35ba('0x32')](_0x4384d4[_0x35ba('0x2e')],qs[_0x35ba('0x34')](_0x4aeded[_0x35ba('0x39')][_0x35ba('0x34')]));_0x2cb290[_0x35ba('0x33')]=_0x2cb290[_0x35ba('0x33')][_0x35ba('0x4d')]?_0x2cb290[_0x35ba('0x33')]:_0x4384d4['model'];if(!_0x4aeded['query'][_0x35ba('0x54')]('nolimit')){_0x2cb290['limit']=qs[_0x35ba('0x1a')](_0x4aeded['query'][_0x35ba('0x1a')]);_0x2cb290[_0x35ba('0x36')]=qs[_0x35ba('0x36')](_0x4aeded['query'][_0x35ba('0x36')]);}_0x2cb290['order']=qs[_0x35ba('0x38')](_0x4aeded[_0x35ba('0x39')][_0x35ba('0x38')]);_0x2cb290[_0x35ba('0x3a')]=qs['filters'](_[_0x35ba('0x3b')](_0x4aeded[_0x35ba('0x39')],_0x4384d4[_0x35ba('0x31')]));_0x2cb290[_0x35ba('0x3a')]['ProjectId']=_0x3f1347['id'];if(_0x4aeded[_0x35ba('0x39')][_0x35ba('0x3c')]){_0x2cb290['where']=_['merge'](_0x2cb290['where'],{'$or':_[_0x35ba('0x2f')](_0x2cb290['attributes'],function(_0x48cd25){var _0x59d990={};_0x59d990[_0x48cd25]={'$like':'%'+_0x4aeded[_0x35ba('0x39')][_0x35ba('0x3c')]+'%'};return _0x59d990;})});}_0x2cb290=_[_0x35ba('0x3d')]({},_0x2cb290,_0x4aeded[_0x35ba('0x3e')]);return db[_0x35ba('0x57')][_0x35ba('0x1b')]({'where':_0x2cb290[_0x35ba('0x3a')]})[_0x35ba('0x23')](function(_0x5a31f1){_0xe7ab[_0x35ba('0x1b')]=_0x5a31f1;if(_0x4aeded[_0x35ba('0x39')]['includeAll']){_0x2cb290[_0x35ba('0x40')]=[{'all':!![]}];}return db[_0x35ba('0x57')][_0x35ba('0x41')](_0x2cb290);})[_0x35ba('0x23')](function(_0x2697ee){_0xe7ab['rows']=_0x2697ee;return _0xe7ab;});}})[_0x35ba('0x23')](respondWithFilteredResult(_0x28a39c,_0x2cb290))['catch'](handleError(_0x28a39c,null));};function char(_0x1e20b3){return _0x35ba('0x58')===typeof _0x1e20b3?String['fromCharCode'][_0x35ba('0x1f')](null,arguments):_0x1e20b3;}function needsEncapsulation(_0x136607){return!!_0x136607&&(_0x136607[_0x35ba('0x59')]()[_0x35ba('0x5a')](char(0xd))>=0x0||_0x136607[_0x35ba('0x59')]()['indexOf'](char(0xa))>=0x0||_0x136607['toString']()[_0x35ba('0x5a')](char(0x2c))>=0x0||_0x136607['toString']()['indexOf'](char(0x22))>=0x0);}function encapsulate(_0x5dea90){var _0x5ce612=char(0x22),_0x5c170='\x5c'+char(0x22),_0x1c2466=_0x5dea90[_0x35ba('0x59')]()[_0x35ba('0x5b')](new RegExp(_0x5ce612,'g'),_0x5c170);return _0x5ce612+_0x1c2466+_0x5ce612;}exports[_0x35ba('0x5c')]=function(_0x184e7e,_0x3a6689,_0x230703){var _0x58f7ca,_0x24e670;var _0x150f9f={'where':{'ProjectId':_0x184e7e[_0x35ba('0x45')]['id']}};if(_0x184e7e[_0x35ba('0x39')]['startTime']){_0x150f9f['where']['starttime']=JSON['parse'](_0x184e7e[_0x35ba('0x39')][_0x35ba('0x5d')]);}return db[_0x35ba('0x53')][_0x35ba('0x41')](_0x150f9f)[_0x35ba('0x23')](handleEntityNotFound(_0x3a6689,null))[_0x35ba('0x23')](function(_0x5a7afb){if(_0x5a7afb){_0x58f7ca=_0x5a7afb;return db[_0x35ba('0x5e')][_0x35ba('0x41')]({'where':{'SessionId':{'$in':_[_0x35ba('0x2f')](_0x58f7ca,'id')},'ProjectId':_0x184e7e[_0x35ba('0x45')]['id']},'order':'-createdAt'});}})[_0x35ba('0x23')](handleEntityNotFound(_0x3a6689,null))[_0x35ba('0x23')](function(_0x2c3b9e){if(_0x2c3b9e){_0x24e670=_0x2c3b9e;var _0x246f2b={};for(var _0x3d7065=0x0,_0xe92774=_0x24e670[_0x35ba('0x4d')];_0x3d7065<_0xe92774;_0x3d7065++){if(!_0x246f2b[_0x35ba('0x54')](_0x24e670[_0x3d7065]['questionId'])){_0x246f2b[_0x24e670[_0x3d7065][_0x35ba('0x5f')]]=needsEncapsulation(_0x24e670[_0x3d7065][_0x35ba('0x60')])?encapsulate(_0x24e670[_0x3d7065][_0x35ba('0x60')]):_0x24e670[_0x3d7065][_0x35ba('0x60')];}}var _0x15a80d=[],_0x528eab={};for(var _0x1610fb=0x0,_0x11abca=_0x58f7ca[_0x35ba('0x4d')];_0x1610fb<_0x11abca;_0x1610fb++){_0x528eab={'ProjectId':_0x184e7e[_0x35ba('0x45')]['id'],'SessionId':_0x58f7ca[_0x1610fb]['id'],'StartTime':moment(_0x58f7ca[_0x1610fb]['starttime'])['format'](_0x35ba('0x61'))};for(var _0x1b955f=0x0,_0x356aee=_0x24e670[_0x35ba('0x4d')];_0x1b955f<_0x356aee;_0x1b955f++){if(_0x24e670[_0x1b955f][_0x35ba('0x62')]==_0x58f7ca[_0x1610fb]['id']&&_0x246f2b[_0x35ba('0x54')](_0x24e670[_0x1b955f]['questionId'])){_0x528eab[_0x246f2b[_0x24e670[_0x1b955f]['questionId']]]=_0x24e670[_0x1b955f][_0x35ba('0x63')];}}for(var _0x4e7bcf in _0x246f2b){if(!_0x528eab[_0x35ba('0x54')](_0x246f2b[_0x4e7bcf])){_0x528eab[_0x246f2b[_0x4e7bcf]]=null;}}_0x15a80d['push'](_0x528eab);}return _0x15a80d;}})['then'](function(_0x2113d5){if(!_['isEmpty'](_0x2113d5)){var _0x2f5171=toCsv(_0x2113d5);var _0x37210d=Date[_0x35ba('0x64')]();fs[_0x35ba('0x65')](util[_0x35ba('0x66')](_0x35ba('0x67'),_0x184e7e['params']['id'],_0x37210d),_0x2f5171);_0x3a6689[_0x35ba('0x68')](_0x35ba('0x69'),_0x35ba('0x6a')+util['format'](_0x35ba('0x6b'),_0x184e7e[_0x35ba('0x45')]['id'],_0x37210d));_0x3a6689[_0x35ba('0x68')](_0x35ba('0x6c'),_0x35ba('0x6d'));return _0x3a6689[_0x35ba('0x6e')](util[_0x35ba('0x66')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0x184e7e['params']['id'],_0x37210d));}else{return _0x3a6689[_0x35ba('0x16')](0xcc);}})[_0x35ba('0x43')](handleError(_0x3a6689,null));};