Built motion from commit fe909640.|2.6.8
[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 _0x20d8=['answer','isEmpty','writeFileSync','/tmp/Jscripty_Project_%d_Summary_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','Jscripty_Project_%d_Summary_%s.csv','text/csv','download','eml-format','rimraf','zip-dir','moment','bluebird','mustache','util','path','to-csv','ejs','fs-extra','squel','crypto','jsforce','papaparse','../../components/parsers/qs','../../config/license/hardware','../../config/logger','api','../../config/environment','../../config/license/util','sendStatus','status','end','json','undefined','limit','count','offset','set','Content-Range','apply','reject','save','update','then','destroy','get','Projects','UserProfileResource','error','stack','name','send','index','map','JscriptyProject','model','keys','query','intersection','attributes','fields','length','nolimit','order','sort','where','filters','filter','merge','VIRTUAL','options','include','findAll','rows','show','params','rawAttributes','includeAll','find','catch','create','user','role','userProfileId','autoAssociation','clone','omit','updatedAt','body','createdAt','Unable\x20to\x20retrieve\x20the\x20current\x20user','UserProfileSection','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','findOne','JscriptySessionReport','hasOwnProperty','pick','ProjectId','getAnswers','JscriptyAnswerReport','fromCharCode','toString','indexOf','replace','getSummary','starttime','startTime','-createdAt','questionId','question','format','YYYY-MM-DD\x20HH:mm:ss'];(function(_0x59162a,_0x10e547){var _0x35e50d=function(_0x578425){while(--_0x578425){_0x59162a['push'](_0x59162a['shift']());}};_0x35e50d(++_0x10e547);}(_0x20d8,0xee));var _0x820d=function(_0x4f5316,_0x143fd5){_0x4f5316=_0x4f5316-0x0;var _0x215bad=_0x20d8[_0x4f5316];return _0x215bad;};'use strict';var emlformat=require(_0x820d('0x0'));var rimraf=require(_0x820d('0x1'));var zipdir=require(_0x820d('0x2'));var jsonpatch=require('fast-json-patch');var rp=require('request-promise');var moment=require(_0x820d('0x3'));var BPromise=require(_0x820d('0x4'));var Mustache=require(_0x820d('0x5'));var util=require(_0x820d('0x6'));var path=require(_0x820d('0x7'));var sox=require('sox');var csv=require(_0x820d('0x8'));var ejs=require(_0x820d('0x9'));var fs=require('fs');var fs_extra=require(_0x820d('0xa'));var _=require('lodash');var squel=require(_0x820d('0xb'));var crypto=require(_0x820d('0xc'));var jsforce=require(_0x820d('0xd'));var deskjs=require('desk.js');var toCsv=require(_0x820d('0x8'));var querystring=require('querystring');var Papa=require(_0x820d('0xe'));var Redis=require('ioredis');var authService=require('../../components/auth/service');var qs=require(_0x820d('0xf'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require(_0x820d('0x10'));var logger=require(_0x820d('0x11'))(_0x820d('0x12'));var utils=require('../../config/utils');var config=require(_0x820d('0x13'));var licenseUtil=require(_0x820d('0x14'));var db=require('../../mysqldb')['db'];function respondWithStatusCode(_0x19db98,_0x4cbdc4){_0x4cbdc4=_0x4cbdc4||0xcc;return function(_0x36cf6e){if(_0x36cf6e){return _0x19db98[_0x820d('0x15')](_0x4cbdc4);}return _0x19db98[_0x820d('0x16')](_0x4cbdc4)[_0x820d('0x17')]();};}function respondWithResult(_0x11322f,_0x401c14){_0x401c14=_0x401c14||0xc8;return function(_0x56b600){if(_0x56b600){return _0x11322f['status'](_0x401c14)[_0x820d('0x18')](_0x56b600);}};}function respondWithFilteredResult(_0x59763d,_0x3e72de){return function(_0x1e9b31){if(_0x1e9b31){var _0x455bfb=typeof _0x3e72de['offset']===_0x820d('0x19')&&typeof _0x3e72de[_0x820d('0x1a')]===_0x820d('0x19');var _0x1c0455=_0x1e9b31[_0x820d('0x1b')];var _0x43d424=_0x455bfb?0x0:_0x3e72de[_0x820d('0x1c')];var _0x1928ae=_0x455bfb?_0x1e9b31[_0x820d('0x1b')]:_0x3e72de[_0x820d('0x1c')]+_0x3e72de[_0x820d('0x1a')];var _0x29d8b5;if(_0x1928ae>=_0x1c0455){_0x1928ae=_0x1c0455;_0x29d8b5=0xc8;}else{_0x29d8b5=0xce;}_0x59763d[_0x820d('0x16')](_0x29d8b5);return _0x59763d[_0x820d('0x1d')](_0x820d('0x1e'),_0x43d424+'-'+_0x1928ae+'/'+_0x1c0455)[_0x820d('0x18')](_0x1e9b31);}return null;};}function patchUpdates(_0x30ec53){return function(_0x241aa2){try{jsonpatch[_0x820d('0x1f')](_0x241aa2,_0x30ec53,!![]);}catch(_0x53dec9){return BPromise[_0x820d('0x20')](_0x53dec9);}return _0x241aa2[_0x820d('0x21')]();};}function saveUpdates(_0x4787ba,_0x32563e){return function(_0x2de355){if(_0x2de355){return _0x2de355[_0x820d('0x22')](_0x4787ba)[_0x820d('0x23')](function(_0x237856){return _0x237856;});}return null;};}function removeEntity(_0x1bb54d,_0x22af5e){return function(_0x2beae7){if(_0x2beae7){return _0x2beae7[_0x820d('0x24')]()[_0x820d('0x23')](function(){var _0x575b07=_0x2beae7[_0x820d('0x25')]({'plain':!![]});var _0x54c975=_0x820d('0x26');return db[_0x820d('0x27')][_0x820d('0x24')]({'where':{'type':_0x54c975,'resourceId':_0x575b07['id']}})[_0x820d('0x23')](function(){return _0x2beae7;});})[_0x820d('0x23')](function(){_0x1bb54d[_0x820d('0x16')](0xcc)[_0x820d('0x17')]();});}};}function handleEntityNotFound(_0x582010,_0x1b078a){return function(_0x284dae){if(!_0x284dae){_0x582010[_0x820d('0x15')](0x194);}return _0x284dae;};}function handleError(_0x537823,_0x42c235){_0x42c235=_0x42c235||0x1f4;return function(_0x5a0697){logger[_0x820d('0x28')](_0x5a0697[_0x820d('0x29')]);if(_0x5a0697[_0x820d('0x2a')]){delete _0x5a0697['name'];}_0x537823['status'](_0x42c235)[_0x820d('0x2b')](_0x5a0697);};}exports[_0x820d('0x2c')]=function(_0x4fab38,_0x5167d0){var _0x30ff53={},_0x215872={},_0x4cc5da={'count':0x0,'rows':[]};var _0x170fee=_[_0x820d('0x2d')](db[_0x820d('0x2e')]['rawAttributes'],function(_0x1e4b7f){return{'name':_0x1e4b7f['fieldName'],'type':_0x1e4b7f['type']['key']};});_0x215872[_0x820d('0x2f')]=_[_0x820d('0x2d')](_0x170fee,_0x820d('0x2a'));_0x215872['query']=_[_0x820d('0x30')](_0x4fab38[_0x820d('0x31')]);_0x215872['filters']=_[_0x820d('0x32')](_0x215872['model'],_0x215872[_0x820d('0x31')]);_0x30ff53[_0x820d('0x33')]=_[_0x820d('0x32')](_0x215872['model'],qs[_0x820d('0x34')](_0x4fab38['query'][_0x820d('0x34')]));_0x30ff53[_0x820d('0x33')]=_0x30ff53[_0x820d('0x33')][_0x820d('0x35')]?_0x30ff53[_0x820d('0x33')]:_0x215872['model'];if(!_0x4fab38[_0x820d('0x31')]['hasOwnProperty'](_0x820d('0x36'))){_0x30ff53[_0x820d('0x1a')]=qs['limit'](_0x4fab38[_0x820d('0x31')]['limit']);_0x30ff53[_0x820d('0x1c')]=qs['offset'](_0x4fab38['query'][_0x820d('0x1c')]);}_0x30ff53[_0x820d('0x37')]=qs[_0x820d('0x38')](_0x4fab38[_0x820d('0x31')]['sort']);_0x30ff53[_0x820d('0x39')]=qs[_0x820d('0x3a')](_['pick'](_0x4fab38['query'],_0x215872[_0x820d('0x3a')]),_0x170fee);if(_0x4fab38[_0x820d('0x31')][_0x820d('0x3b')]){_0x30ff53[_0x820d('0x39')]=_[_0x820d('0x3c')](_0x30ff53[_0x820d('0x39')],{'$or':_[_0x820d('0x2d')](_0x170fee,function(_0x51aa6c){if(_0x51aa6c['type']!==_0x820d('0x3d')){var _0xa3adab={};_0xa3adab[_0x51aa6c[_0x820d('0x2a')]]={'$like':'%'+_0x4fab38[_0x820d('0x31')]['filter']+'%'};return _0xa3adab;}})});}_0x30ff53=_[_0x820d('0x3c')]({},_0x30ff53,_0x4fab38[_0x820d('0x3e')]);var _0x2b2cba={'where':_0x30ff53[_0x820d('0x39')]};return db[_0x820d('0x2e')][_0x820d('0x1b')](_0x2b2cba)['then'](function(_0xc01378){_0x4cc5da['count']=_0xc01378;if(_0x4fab38[_0x820d('0x31')]['includeAll']){_0x30ff53[_0x820d('0x3f')]=[{'all':!![]}];}return db[_0x820d('0x2e')][_0x820d('0x40')](_0x30ff53);})['then'](function(_0x14fc29){_0x4cc5da[_0x820d('0x41')]=_0x14fc29;return _0x4cc5da;})['then'](respondWithFilteredResult(_0x5167d0,_0x30ff53))['catch'](handleError(_0x5167d0,null));};exports[_0x820d('0x42')]=function(_0x4f8756,_0x22974e){var _0x28ba53={'raw':![],'where':{'id':_0x4f8756[_0x820d('0x43')]['id']}},_0x55d820={};_0x55d820[_0x820d('0x2f')]=_[_0x820d('0x30')](db[_0x820d('0x2e')][_0x820d('0x44')]);_0x55d820[_0x820d('0x31')]=_['keys'](_0x4f8756[_0x820d('0x31')]);_0x55d820[_0x820d('0x3a')]=_[_0x820d('0x32')](_0x55d820['model'],_0x55d820[_0x820d('0x31')]);_0x28ba53[_0x820d('0x33')]=_[_0x820d('0x32')](_0x55d820['model'],qs[_0x820d('0x34')](_0x4f8756[_0x820d('0x31')][_0x820d('0x34')]));_0x28ba53[_0x820d('0x33')]=_0x28ba53[_0x820d('0x33')]['length']?_0x28ba53[_0x820d('0x33')]:_0x55d820[_0x820d('0x2f')];if(_0x4f8756[_0x820d('0x31')][_0x820d('0x45')]){_0x28ba53[_0x820d('0x3f')]=[{'all':!![]}];}_0x28ba53=_[_0x820d('0x3c')]({},_0x28ba53,_0x4f8756['options']);return db[_0x820d('0x2e')][_0x820d('0x46')](_0x28ba53)[_0x820d('0x23')](handleEntityNotFound(_0x22974e,null))[_0x820d('0x23')](respondWithResult(_0x22974e,null))[_0x820d('0x47')](handleError(_0x22974e,null));};exports[_0x820d('0x48')]=function(_0x5005a8,_0x27b340){return db[_0x820d('0x2e')][_0x820d('0x48')](_0x5005a8['body'],{})['then'](function(_0x114ab6){var _0x2dab36=_0x5005a8[_0x820d('0x49')][_0x820d('0x25')]({'plain':!![]});if(!_0x2dab36)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x2dab36[_0x820d('0x4a')]===_0x820d('0x49')){var _0x30f224=_0x114ab6[_0x820d('0x25')]({'plain':!![]});var _0x2f6e02=_0x820d('0x26');return db['UserProfileSection'][_0x820d('0x46')]({'where':{'name':_0x2f6e02,'userProfileId':_0x2dab36[_0x820d('0x4b')]},'raw':!![]})[_0x820d('0x23')](function(_0x4b7b7b){if(_0x4b7b7b&&_0x4b7b7b[_0x820d('0x4c')]===0x0){return db[_0x820d('0x27')]['create']({'name':_0x30f224['name'],'resourceId':_0x30f224['id'],'type':_0x4b7b7b['name'],'sectionId':_0x4b7b7b['id']},{})[_0x820d('0x23')](function(){return _0x114ab6;});}else{return _0x114ab6;}})[_0x820d('0x47')](function(_0x62f8e7){logger[_0x820d('0x28')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x62f8e7);throw _0x62f8e7;});}return _0x114ab6;})['then'](respondWithResult(_0x27b340,0xc9))[_0x820d('0x47')](handleError(_0x27b340,null));};exports[_0x820d('0x4d')]=function(_0x868f2,_0x146b9d){var _0x371514={'where':{'id':_0x868f2[_0x820d('0x43')]['id']}},_0x5f1d41={};_0x5f1d41[_0x820d('0x2f')]=_[_0x820d('0x30')](db['JscriptyProject'][_0x820d('0x44')]);_0x371514['attributes']=_[_0x820d('0x32')](_0x5f1d41[_0x820d('0x2f')],qs[_0x820d('0x34')](_0x868f2[_0x820d('0x31')][_0x820d('0x34')]));_0x371514[_0x820d('0x33')]=_0x371514[_0x820d('0x33')][_0x820d('0x35')]?_0x371514['attributes']:_0x5f1d41[_0x820d('0x2f')];if(_0x868f2['query'][_0x820d('0x45')]){_0x371514[_0x820d('0x3f')]=[{'all':!![]}];}_0x371514=_['merge']({},_0x371514,_0x868f2[_0x820d('0x3e')]);return db[_0x820d('0x2e')][_0x820d('0x46')](_0x371514)['then'](handleEntityNotFound(_0x146b9d,null))['then'](function(_0x3c3ca9){if(_0x3c3ca9){var _0x3f37e8=_0x3c3ca9[_0x820d('0x25')]({'plain':!![]});_0x3f37e8=qs[_0x820d('0x4e')](_0x3f37e8,['id','createdAt',_0x820d('0x4f')]);_0x868f2[_0x820d('0x50')]=_[_0x820d('0x4e')](_0x868f2['body'],['id',_0x820d('0x51'),_0x820d('0x4f')]);return db[_0x820d('0x2e')][_0x820d('0x48')](_['merge'](_0x3f37e8,_0x868f2['body']),{'include':_0x868f2[_0x820d('0x31')][_0x820d('0x45')]?[{'all':!![]}]:undefined})[_0x820d('0x23')](function(_0x1b1612){var _0x331a6a=_0x868f2[_0x820d('0x49')][_0x820d('0x25')]({'plain':!![]});if(!_0x331a6a)throw new Error(_0x820d('0x52'));if(_0x331a6a[_0x820d('0x4a')]===_0x820d('0x49')){var _0x1a93c1=_0x1b1612[_0x820d('0x25')]({'plain':!![]});var _0x3de430=_0x820d('0x26');return db[_0x820d('0x53')][_0x820d('0x46')]({'where':{'name':_0x3de430,'userProfileId':_0x331a6a[_0x820d('0x4b')]},'raw':!![]})[_0x820d('0x23')](function(_0xeee33c){if(_0xeee33c&&_0xeee33c[_0x820d('0x4c')]===0x0){return db[_0x820d('0x27')][_0x820d('0x48')]({'name':_0x1a93c1['name'],'resourceId':_0x1a93c1['id'],'type':_0xeee33c[_0x820d('0x2a')],'sectionId':_0xeee33c['id']},{})[_0x820d('0x23')](function(){return _0x1b1612;});}else{return _0x1b1612;}})[_0x820d('0x47')](function(_0x15128a){logger[_0x820d('0x28')](_0x820d('0x54'),_0x15128a);throw _0x15128a;});}return _0x1b1612;});}})[_0x820d('0x23')](respondWithResult(_0x146b9d,0xc9))[_0x820d('0x47')](handleError(_0x146b9d,null));};exports[_0x820d('0x22')]=function(_0xbca977,_0x48be89){if(_0xbca977[_0x820d('0x50')]['id']){delete _0xbca977['body']['id'];}return db[_0x820d('0x2e')][_0x820d('0x46')]({'where':{'id':_0xbca977[_0x820d('0x43')]['id']}})[_0x820d('0x23')](handleEntityNotFound(_0x48be89,null))['then'](saveUpdates(_0xbca977[_0x820d('0x50')],null))[_0x820d('0x23')](respondWithResult(_0x48be89,null))['catch'](handleError(_0x48be89,null));};exports[_0x820d('0x24')]=function(_0x58bfd0,_0x462832){return db[_0x820d('0x2e')][_0x820d('0x46')]({'where':{'id':_0x58bfd0[_0x820d('0x43')]['id']}})[_0x820d('0x23')](handleEntityNotFound(_0x462832,null))[_0x820d('0x23')](removeEntity(_0x462832,null))['catch'](handleError(_0x462832,null));};exports['getSessions']=function(_0x22214f,_0x47e645,_0x2d54be){var _0x40ff80={'raw':!![],'where':{}};var _0x44f0a5={};var _0x512134={'count':0x0,'rows':[]};return db[_0x820d('0x2e')][_0x820d('0x55')]({'where':{'id':_0x22214f[_0x820d('0x43')]['id']}})[_0x820d('0x23')](handleEntityNotFound(_0x47e645,null))[_0x820d('0x23')](function(_0xabc02a){if(_0xabc02a){_0x44f0a5[_0x820d('0x2f')]=_[_0x820d('0x30')](db[_0x820d('0x56')]['rawAttributes']);_0x44f0a5[_0x820d('0x31')]=_[_0x820d('0x30')](_0x22214f['query']);_0x44f0a5['filters']=_[_0x820d('0x32')](_0x44f0a5[_0x820d('0x2f')],_0x44f0a5[_0x820d('0x31')]);_0x40ff80[_0x820d('0x33')]=_[_0x820d('0x32')](_0x44f0a5['model'],qs[_0x820d('0x34')](_0x22214f[_0x820d('0x31')][_0x820d('0x34')]));_0x40ff80['attributes']=_0x40ff80[_0x820d('0x33')][_0x820d('0x35')]?_0x40ff80[_0x820d('0x33')]:_0x44f0a5[_0x820d('0x2f')];if(!_0x22214f['query'][_0x820d('0x57')](_0x820d('0x36'))){_0x40ff80[_0x820d('0x1a')]=qs['limit'](_0x22214f[_0x820d('0x31')][_0x820d('0x1a')]);_0x40ff80[_0x820d('0x1c')]=qs[_0x820d('0x1c')](_0x22214f[_0x820d('0x31')][_0x820d('0x1c')]);}_0x40ff80['order']=qs[_0x820d('0x38')](_0x22214f[_0x820d('0x31')][_0x820d('0x38')]);_0x40ff80[_0x820d('0x39')]=qs[_0x820d('0x3a')](_[_0x820d('0x58')](_0x22214f['query'],_0x44f0a5['filters']));_0x40ff80['where'][_0x820d('0x59')]=_0xabc02a['id'];if(_0x22214f[_0x820d('0x31')]['filter']){_0x40ff80[_0x820d('0x39')]=_[_0x820d('0x3c')](_0x40ff80[_0x820d('0x39')],{'$or':_[_0x820d('0x2d')](_0x40ff80[_0x820d('0x33')],function(_0x5703fb){var _0x14f16f={};_0x14f16f[_0x5703fb]={'$like':'%'+_0x22214f[_0x820d('0x31')]['filter']+'%'};return _0x14f16f;})});}_0x40ff80=_[_0x820d('0x3c')]({},_0x40ff80,_0x22214f[_0x820d('0x3e')]);return db['JscriptySessionReport'][_0x820d('0x1b')]({'where':_0x40ff80[_0x820d('0x39')]})[_0x820d('0x23')](function(_0x3663be){_0x512134[_0x820d('0x1b')]=_0x3663be;if(_0x22214f['query']['includeAll']){_0x40ff80[_0x820d('0x3f')]=[{'all':!![]}];}return db[_0x820d('0x56')][_0x820d('0x40')](_0x40ff80);})[_0x820d('0x23')](function(_0x16aad5){_0x512134['rows']=_0x16aad5;return _0x512134;});}})[_0x820d('0x23')](respondWithFilteredResult(_0x47e645,_0x40ff80))[_0x820d('0x47')](handleError(_0x47e645,null));};exports[_0x820d('0x5a')]=function(_0x55b340,_0x101a1f,_0x2a76ee){var _0xe1f79e={'raw':!![],'where':{}};var _0x55779c={};var _0x3b5203={'count':0x0,'rows':[]};return db['JscriptyProject']['findOne']({'where':{'id':_0x55b340[_0x820d('0x43')]['id']}})[_0x820d('0x23')](handleEntityNotFound(_0x101a1f,null))[_0x820d('0x23')](function(_0x40bda7){if(_0x40bda7){_0x55779c[_0x820d('0x2f')]=_[_0x820d('0x30')](db['JscriptyAnswerReport'][_0x820d('0x44')]);_0x55779c['query']=_[_0x820d('0x30')](_0x55b340['query']);_0x55779c['filters']=_[_0x820d('0x32')](_0x55779c[_0x820d('0x2f')],_0x55779c[_0x820d('0x31')]);_0xe1f79e[_0x820d('0x33')]=_[_0x820d('0x32')](_0x55779c[_0x820d('0x2f')],qs[_0x820d('0x34')](_0x55b340[_0x820d('0x31')][_0x820d('0x34')]));_0xe1f79e[_0x820d('0x33')]=_0xe1f79e['attributes'][_0x820d('0x35')]?_0xe1f79e[_0x820d('0x33')]:_0x55779c[_0x820d('0x2f')];if(!_0x55b340[_0x820d('0x31')][_0x820d('0x57')](_0x820d('0x36'))){_0xe1f79e[_0x820d('0x1a')]=qs[_0x820d('0x1a')](_0x55b340[_0x820d('0x31')][_0x820d('0x1a')]);_0xe1f79e[_0x820d('0x1c')]=qs['offset'](_0x55b340[_0x820d('0x31')][_0x820d('0x1c')]);}_0xe1f79e[_0x820d('0x37')]=qs['sort'](_0x55b340['query'][_0x820d('0x38')]);_0xe1f79e[_0x820d('0x39')]=qs[_0x820d('0x3a')](_[_0x820d('0x58')](_0x55b340['query'],_0x55779c[_0x820d('0x3a')]));_0xe1f79e[_0x820d('0x39')]['ProjectId']=_0x40bda7['id'];if(_0x55b340[_0x820d('0x31')][_0x820d('0x3b')]){_0xe1f79e[_0x820d('0x39')]=_[_0x820d('0x3c')](_0xe1f79e[_0x820d('0x39')],{'$or':_[_0x820d('0x2d')](_0xe1f79e[_0x820d('0x33')],function(_0x40b4fa){var _0x1d727c={};_0x1d727c[_0x40b4fa]={'$like':'%'+_0x55b340[_0x820d('0x31')][_0x820d('0x3b')]+'%'};return _0x1d727c;})});}_0xe1f79e=_['merge']({},_0xe1f79e,_0x55b340[_0x820d('0x3e')]);return db[_0x820d('0x5b')]['count']({'where':_0xe1f79e['where']})[_0x820d('0x23')](function(_0x4ba933){_0x3b5203[_0x820d('0x1b')]=_0x4ba933;if(_0x55b340[_0x820d('0x31')][_0x820d('0x45')]){_0xe1f79e[_0x820d('0x3f')]=[{'all':!![]}];}return db[_0x820d('0x5b')][_0x820d('0x40')](_0xe1f79e);})[_0x820d('0x23')](function(_0x37d4e6){_0x3b5203['rows']=_0x37d4e6;return _0x3b5203;});}})[_0x820d('0x23')](respondWithFilteredResult(_0x101a1f,_0xe1f79e))[_0x820d('0x47')](handleError(_0x101a1f,null));};function char(_0x144394){return'number'===typeof _0x144394?String[_0x820d('0x5c')]['apply'](null,arguments):_0x144394;}function needsEncapsulation(_0x2b9a76){return!!_0x2b9a76&&(_0x2b9a76[_0x820d('0x5d')]()[_0x820d('0x5e')](char(0xd))>=0x0||_0x2b9a76[_0x820d('0x5d')]()[_0x820d('0x5e')](char(0xa))>=0x0||_0x2b9a76[_0x820d('0x5d')]()[_0x820d('0x5e')](char(0x2c))>=0x0||_0x2b9a76[_0x820d('0x5d')]()['indexOf'](char(0x22))>=0x0);}function encapsulate(_0x3affaa){var _0xf00653=char(0x22),_0x50dd11='\x5c'+char(0x22),_0x23f72f=_0x3affaa['toString']()[_0x820d('0x5f')](new RegExp(_0xf00653,'g'),_0x50dd11);return _0xf00653+_0x23f72f+_0xf00653;}exports[_0x820d('0x60')]=function(_0x5e4746,_0x3fafd4,_0x5e6e14){var _0x20e4d4,_0x2b94bc;var _0x23098c={'where':{'ProjectId':_0x5e4746[_0x820d('0x43')]['id']}};if(_0x5e4746[_0x820d('0x31')]['startTime']){_0x23098c[_0x820d('0x39')][_0x820d('0x61')]=JSON['parse'](_0x5e4746[_0x820d('0x31')][_0x820d('0x62')]);}return db[_0x820d('0x56')][_0x820d('0x40')](_0x23098c)[_0x820d('0x23')](handleEntityNotFound(_0x3fafd4,null))[_0x820d('0x23')](function(_0x539dc9){if(_0x539dc9){_0x20e4d4=_0x539dc9;return db['JscriptyQuestionReport'][_0x820d('0x40')]({'where':{'SessionId':{'$in':_['map'](_0x20e4d4,'id')},'ProjectId':_0x5e4746[_0x820d('0x43')]['id']},'order':_0x820d('0x63')});}})[_0x820d('0x23')](handleEntityNotFound(_0x3fafd4,null))[_0x820d('0x23')](function(_0x3d8acb){if(_0x3d8acb){_0x2b94bc=_0x3d8acb;var _0x4bb149={};for(var _0x1e9439=0x0,_0x39c39a=_0x2b94bc[_0x820d('0x35')];_0x1e9439<_0x39c39a;_0x1e9439++){if(!_0x4bb149['hasOwnProperty'](_0x2b94bc[_0x1e9439]['questionId'])){_0x4bb149[_0x2b94bc[_0x1e9439][_0x820d('0x64')]]=needsEncapsulation(_0x2b94bc[_0x1e9439][_0x820d('0x65')])?encapsulate(_0x2b94bc[_0x1e9439][_0x820d('0x65')]):_0x2b94bc[_0x1e9439][_0x820d('0x65')];}}var _0x3b38c3=[],_0xcfde3c={};for(var _0x210232=0x0,_0x5d9f05=_0x20e4d4['length'];_0x210232<_0x5d9f05;_0x210232++){_0xcfde3c={'ProjectId':_0x5e4746[_0x820d('0x43')]['id'],'SessionId':_0x20e4d4[_0x210232]['id'],'StartTime':moment(_0x20e4d4[_0x210232][_0x820d('0x61')])[_0x820d('0x66')](_0x820d('0x67'))};for(var _0x14b291=0x0,_0x3f7527=_0x2b94bc[_0x820d('0x35')];_0x14b291<_0x3f7527;_0x14b291++){if(_0x2b94bc[_0x14b291]['SessionId']==_0x20e4d4[_0x210232]['id']&&_0x4bb149[_0x820d('0x57')](_0x2b94bc[_0x14b291]['questionId'])){_0xcfde3c[_0x4bb149[_0x2b94bc[_0x14b291][_0x820d('0x64')]]]=_0x2b94bc[_0x14b291][_0x820d('0x68')];}}for(var _0x50f77f in _0x4bb149){if(!_0xcfde3c[_0x820d('0x57')](_0x4bb149[_0x50f77f])){_0xcfde3c[_0x4bb149[_0x50f77f]]=null;}}_0x3b38c3['push'](_0xcfde3c);}return _0x3b38c3;}})[_0x820d('0x23')](function(_0x21605b){if(!_[_0x820d('0x69')](_0x21605b)){var _0x1c5cef=toCsv(_0x21605b);var _0x577b8d=Date['now']();fs[_0x820d('0x6a')](util[_0x820d('0x66')](_0x820d('0x6b'),_0x5e4746[_0x820d('0x43')]['id'],_0x577b8d),_0x1c5cef);_0x3fafd4[_0x820d('0x6c')](_0x820d('0x6d'),_0x820d('0x6e')+util[_0x820d('0x66')](_0x820d('0x6f'),_0x5e4746[_0x820d('0x43')]['id'],_0x577b8d));_0x3fafd4[_0x820d('0x6c')]('Content-type',_0x820d('0x70'));return _0x3fafd4[_0x820d('0x71')](util[_0x820d('0x66')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0x5e4746[_0x820d('0x43')]['id'],_0x577b8d));}else{return _0x3fafd4['sendStatus'](0xcc);}})[_0x820d('0x47')](handleError(_0x3fafd4,null));};