Built motion from commit 9d0783e6.|2.6.13
[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 _0x7fea=['../../config/license/util','sendStatus','status','end','json','offset','undefined','limit','count','set','Content-Range','apply','save','update','then','get','Projects','UserProfileResource','error','stack','name','send','index','rawAttributes','type','key','model','map','query','keys','filters','attributes','intersection','fields','hasOwnProperty','nolimit','order','sort','where','merge','VIRTUAL','options','includeAll','include','JscriptyProject','findAll','rows','catch','params','length','find','create','body','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','user','UserProfileSection','userProfileId','autoAssociation','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','createdAt','omit','updatedAt','destroy','getSessions','findOne','JscriptySessionReport','pick','ProjectId','filter','JscriptyAnswerReport','number','fromCharCode','indexOf','toString','replace','startTime','starttime','parse','questionId','question','format','YYYY-MM-DD\x20HH:mm:ss','SessionId','answer','push','isEmpty','now','writeFileSync','attachment;\x20filename=','Jscripty_Project_%d_Summary_%s.csv','setHeader','Content-type','text/csv','download','rimraf','request-promise','moment','bluebird','mustache','util','path','to-csv','ejs','fs-extra','lodash','squel','crypto','jsforce','desk.js','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../config/license/hardware','../../config/logger','../../config/utils'];(function(_0x5cf5be,_0x31a10c){var _0x41c969=function(_0x1ee830){while(--_0x1ee830){_0x5cf5be['push'](_0x5cf5be['shift']());}};_0x41c969(++_0x31a10c);}(_0x7fea,0x149));var _0xa7fe=function(_0x245a00,_0xb4c70b){_0x245a00=_0x245a00-0x0;var _0x26617f=_0x7fea[_0x245a00];return _0x26617f;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0xa7fe('0x0'));var zipdir=require('zip-dir');var jsonpatch=require('fast-json-patch');var rp=require(_0xa7fe('0x1'));var moment=require(_0xa7fe('0x2'));var BPromise=require(_0xa7fe('0x3'));var Mustache=require(_0xa7fe('0x4'));var util=require(_0xa7fe('0x5'));var path=require(_0xa7fe('0x6'));var sox=require('sox');var csv=require(_0xa7fe('0x7'));var ejs=require(_0xa7fe('0x8'));var fs=require('fs');var fs_extra=require(_0xa7fe('0x9'));var _=require(_0xa7fe('0xa'));var squel=require(_0xa7fe('0xb'));var crypto=require(_0xa7fe('0xc'));var jsforce=require(_0xa7fe('0xd'));var deskjs=require(_0xa7fe('0xe'));var toCsv=require('to-csv');var querystring=require('querystring');var Papa=require(_0xa7fe('0xf'));var Redis=require(_0xa7fe('0x10'));var authService=require(_0xa7fe('0x11'));var qs=require(_0xa7fe('0x12'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require(_0xa7fe('0x13'));var logger=require(_0xa7fe('0x14'))('api');var utils=require(_0xa7fe('0x15'));var config=require('../../config/environment');var licenseUtil=require(_0xa7fe('0x16'));var db=require('../../mysqldb')['db'];function respondWithStatusCode(_0x50a806,_0x3005d3){_0x3005d3=_0x3005d3||0xcc;return function(_0x26dde5){if(_0x26dde5){return _0x50a806[_0xa7fe('0x17')](_0x3005d3);}return _0x50a806[_0xa7fe('0x18')](_0x3005d3)[_0xa7fe('0x19')]();};}function respondWithResult(_0x5a4975,_0x49e7cb){_0x49e7cb=_0x49e7cb||0xc8;return function(_0x215d4c){if(_0x215d4c){return _0x5a4975[_0xa7fe('0x18')](_0x49e7cb)[_0xa7fe('0x1a')](_0x215d4c);}};}function respondWithFilteredResult(_0x43ae73,_0x34490e){return function(_0x5df0e3){if(_0x5df0e3){var _0x137dc9=typeof _0x34490e[_0xa7fe('0x1b')]===_0xa7fe('0x1c')&&typeof _0x34490e[_0xa7fe('0x1d')]===_0xa7fe('0x1c');var _0x4ac6eb=_0x5df0e3[_0xa7fe('0x1e')];var _0x1e4966=_0x137dc9?0x0:_0x34490e[_0xa7fe('0x1b')];var _0x2ef53c=_0x137dc9?_0x5df0e3[_0xa7fe('0x1e')]:_0x34490e[_0xa7fe('0x1b')]+_0x34490e[_0xa7fe('0x1d')];var _0x5e769d;if(_0x2ef53c>=_0x4ac6eb){_0x2ef53c=_0x4ac6eb;_0x5e769d=0xc8;}else{_0x5e769d=0xce;}_0x43ae73['status'](_0x5e769d);return _0x43ae73[_0xa7fe('0x1f')](_0xa7fe('0x20'),_0x1e4966+'-'+_0x2ef53c+'/'+_0x4ac6eb)[_0xa7fe('0x1a')](_0x5df0e3);}return null;};}function patchUpdates(_0x529990){return function(_0x1d33d2){try{jsonpatch[_0xa7fe('0x21')](_0x1d33d2,_0x529990,!![]);}catch(_0x189ada){return BPromise['reject'](_0x189ada);}return _0x1d33d2[_0xa7fe('0x22')]();};}function saveUpdates(_0x19b408,_0x1619c1){return function(_0x13e31e){if(_0x13e31e){return _0x13e31e[_0xa7fe('0x23')](_0x19b408)[_0xa7fe('0x24')](function(_0x2bc7fd){return _0x2bc7fd;});}return null;};}function removeEntity(_0x1043bf,_0x4ac7e0){return function(_0x3415b8){if(_0x3415b8){return _0x3415b8['destroy']()['then'](function(){var _0x37c8fa=_0x3415b8[_0xa7fe('0x25')]({'plain':!![]});var _0x24ec1b=_0xa7fe('0x26');return db[_0xa7fe('0x27')]['destroy']({'where':{'type':_0x24ec1b,'resourceId':_0x37c8fa['id']}})[_0xa7fe('0x24')](function(){return _0x3415b8;});})[_0xa7fe('0x24')](function(){_0x1043bf[_0xa7fe('0x18')](0xcc)[_0xa7fe('0x19')]();});}};}function handleEntityNotFound(_0x26e5a4,_0x146a74){return function(_0x11aff3){if(!_0x11aff3){_0x26e5a4[_0xa7fe('0x17')](0x194);}return _0x11aff3;};}function handleError(_0x9d5272,_0x3c3f91){_0x3c3f91=_0x3c3f91||0x1f4;return function(_0x44ba8a){logger[_0xa7fe('0x28')](_0x44ba8a[_0xa7fe('0x29')]);if(_0x44ba8a[_0xa7fe('0x2a')]){delete _0x44ba8a[_0xa7fe('0x2a')];}_0x9d5272[_0xa7fe('0x18')](_0x3c3f91)[_0xa7fe('0x2b')](_0x44ba8a);};}exports[_0xa7fe('0x2c')]=function(_0x1c9e5a,_0x429df4){var _0x5bd01d={},_0x3f900a={},_0x3198f9={'count':0x0,'rows':[]};var _0x5bde8b=_['map'](db['JscriptyProject'][_0xa7fe('0x2d')],function(_0x293405){return{'name':_0x293405['fieldName'],'type':_0x293405[_0xa7fe('0x2e')][_0xa7fe('0x2f')]};});_0x3f900a[_0xa7fe('0x30')]=_[_0xa7fe('0x31')](_0x5bde8b,_0xa7fe('0x2a'));_0x3f900a[_0xa7fe('0x32')]=_[_0xa7fe('0x33')](_0x1c9e5a[_0xa7fe('0x32')]);_0x3f900a[_0xa7fe('0x34')]=_['intersection'](_0x3f900a[_0xa7fe('0x30')],_0x3f900a['query']);_0x5bd01d[_0xa7fe('0x35')]=_[_0xa7fe('0x36')](_0x3f900a[_0xa7fe('0x30')],qs['fields'](_0x1c9e5a[_0xa7fe('0x32')][_0xa7fe('0x37')]));_0x5bd01d[_0xa7fe('0x35')]=_0x5bd01d[_0xa7fe('0x35')]['length']?_0x5bd01d[_0xa7fe('0x35')]:_0x3f900a[_0xa7fe('0x30')];if(!_0x1c9e5a['query'][_0xa7fe('0x38')](_0xa7fe('0x39'))){_0x5bd01d[_0xa7fe('0x1d')]=qs[_0xa7fe('0x1d')](_0x1c9e5a[_0xa7fe('0x32')][_0xa7fe('0x1d')]);_0x5bd01d[_0xa7fe('0x1b')]=qs[_0xa7fe('0x1b')](_0x1c9e5a[_0xa7fe('0x32')][_0xa7fe('0x1b')]);}_0x5bd01d[_0xa7fe('0x3a')]=qs[_0xa7fe('0x3b')](_0x1c9e5a[_0xa7fe('0x32')][_0xa7fe('0x3b')]);_0x5bd01d[_0xa7fe('0x3c')]=qs[_0xa7fe('0x34')](_['pick'](_0x1c9e5a['query'],_0x3f900a[_0xa7fe('0x34')]),_0x5bde8b);if(_0x1c9e5a[_0xa7fe('0x32')]['filter']){_0x5bd01d[_0xa7fe('0x3c')]=_[_0xa7fe('0x3d')](_0x5bd01d['where'],{'$or':_[_0xa7fe('0x31')](_0x5bde8b,function(_0x228590){if(_0x228590[_0xa7fe('0x2e')]!==_0xa7fe('0x3e')){var _0x463947={};_0x463947[_0x228590[_0xa7fe('0x2a')]]={'$like':'%'+_0x1c9e5a[_0xa7fe('0x32')]['filter']+'%'};return _0x463947;}})});}_0x5bd01d=_[_0xa7fe('0x3d')]({},_0x5bd01d,_0x1c9e5a[_0xa7fe('0x3f')]);var _0x2c6197={'where':_0x5bd01d[_0xa7fe('0x3c')]};return db['JscriptyProject'][_0xa7fe('0x1e')](_0x2c6197)[_0xa7fe('0x24')](function(_0x66671){_0x3198f9[_0xa7fe('0x1e')]=_0x66671;if(_0x1c9e5a[_0xa7fe('0x32')][_0xa7fe('0x40')]){_0x5bd01d[_0xa7fe('0x41')]=[{'all':!![]}];}return db[_0xa7fe('0x42')][_0xa7fe('0x43')](_0x5bd01d);})[_0xa7fe('0x24')](function(_0x241b13){_0x3198f9[_0xa7fe('0x44')]=_0x241b13;return _0x3198f9;})[_0xa7fe('0x24')](respondWithFilteredResult(_0x429df4,_0x5bd01d))[_0xa7fe('0x45')](handleError(_0x429df4,null));};exports['show']=function(_0x5c3a64,_0x5ab950){var _0x48d6f6={'raw':![],'where':{'id':_0x5c3a64[_0xa7fe('0x46')]['id']}},_0x24d943={};_0x24d943[_0xa7fe('0x30')]=_[_0xa7fe('0x33')](db[_0xa7fe('0x42')][_0xa7fe('0x2d')]);_0x24d943[_0xa7fe('0x32')]=_[_0xa7fe('0x33')](_0x5c3a64['query']);_0x24d943[_0xa7fe('0x34')]=_[_0xa7fe('0x36')](_0x24d943[_0xa7fe('0x30')],_0x24d943['query']);_0x48d6f6[_0xa7fe('0x35')]=_[_0xa7fe('0x36')](_0x24d943['model'],qs[_0xa7fe('0x37')](_0x5c3a64[_0xa7fe('0x32')][_0xa7fe('0x37')]));_0x48d6f6[_0xa7fe('0x35')]=_0x48d6f6['attributes'][_0xa7fe('0x47')]?_0x48d6f6[_0xa7fe('0x35')]:_0x24d943['model'];if(_0x5c3a64[_0xa7fe('0x32')]['includeAll']){_0x48d6f6[_0xa7fe('0x41')]=[{'all':!![]}];}_0x48d6f6=_[_0xa7fe('0x3d')]({},_0x48d6f6,_0x5c3a64[_0xa7fe('0x3f')]);return db['JscriptyProject'][_0xa7fe('0x48')](_0x48d6f6)[_0xa7fe('0x24')](handleEntityNotFound(_0x5ab950,null))['then'](respondWithResult(_0x5ab950,null))[_0xa7fe('0x45')](handleError(_0x5ab950,null));};exports['create']=function(_0x1d9ad4,_0x58cbec){return db[_0xa7fe('0x42')][_0xa7fe('0x49')](_0x1d9ad4[_0xa7fe('0x4a')],{})[_0xa7fe('0x24')](function(_0x41124a){var _0x5ecc9a=_0x1d9ad4['user'][_0xa7fe('0x25')]({'plain':!![]});if(!_0x5ecc9a)throw new Error(_0xa7fe('0x4b'));if(_0x5ecc9a[_0xa7fe('0x4c')]===_0xa7fe('0x4d')){var _0xf316c8=_0x41124a['get']({'plain':!![]});var _0x4e2918=_0xa7fe('0x26');return db[_0xa7fe('0x4e')]['find']({'where':{'name':_0x4e2918,'userProfileId':_0x5ecc9a[_0xa7fe('0x4f')]},'raw':!![]})['then'](function(_0x37d9c3){if(_0x37d9c3&&_0x37d9c3[_0xa7fe('0x50')]===0x0){return db[_0xa7fe('0x27')]['create']({'name':_0xf316c8['name'],'resourceId':_0xf316c8['id'],'type':_0x37d9c3[_0xa7fe('0x2a')],'sectionId':_0x37d9c3['id']},{})['then'](function(){return _0x41124a;});}else{return _0x41124a;}})['catch'](function(_0x1ebeb5){logger[_0xa7fe('0x28')](_0xa7fe('0x51'),_0x1ebeb5);throw _0x1ebeb5;});}return _0x41124a;})[_0xa7fe('0x24')](respondWithResult(_0x58cbec,0xc9))[_0xa7fe('0x45')](handleError(_0x58cbec,null));};exports['clone']=function(_0x241090,_0xae7bea){var _0x418e7f={'where':{'id':_0x241090['params']['id']}},_0x10a287={};_0x10a287['model']=_['keys'](db[_0xa7fe('0x42')]['rawAttributes']);_0x418e7f[_0xa7fe('0x35')]=_[_0xa7fe('0x36')](_0x10a287[_0xa7fe('0x30')],qs[_0xa7fe('0x37')](_0x241090[_0xa7fe('0x32')][_0xa7fe('0x37')]));_0x418e7f['attributes']=_0x418e7f['attributes'][_0xa7fe('0x47')]?_0x418e7f[_0xa7fe('0x35')]:_0x10a287[_0xa7fe('0x30')];if(_0x241090['query'][_0xa7fe('0x40')]){_0x418e7f[_0xa7fe('0x41')]=[{'all':!![]}];}_0x418e7f=_[_0xa7fe('0x3d')]({},_0x418e7f,_0x241090['options']);return db[_0xa7fe('0x42')][_0xa7fe('0x48')](_0x418e7f)[_0xa7fe('0x24')](handleEntityNotFound(_0xae7bea,null))[_0xa7fe('0x24')](function(_0x40f888){if(_0x40f888){var _0x3ed6e9=_0x40f888[_0xa7fe('0x25')]({'plain':!![]});_0x3ed6e9=qs['omit'](_0x3ed6e9,['id',_0xa7fe('0x52'),'updatedAt']);_0x241090[_0xa7fe('0x4a')]=_[_0xa7fe('0x53')](_0x241090[_0xa7fe('0x4a')],['id',_0xa7fe('0x52'),_0xa7fe('0x54')]);return db[_0xa7fe('0x42')][_0xa7fe('0x49')](_[_0xa7fe('0x3d')](_0x3ed6e9,_0x241090[_0xa7fe('0x4a')]),{'include':_0x241090[_0xa7fe('0x32')][_0xa7fe('0x40')]?[{'all':!![]}]:undefined})[_0xa7fe('0x24')](function(_0x410674){var _0x5262de=_0x241090[_0xa7fe('0x4d')][_0xa7fe('0x25')]({'plain':!![]});if(!_0x5262de)throw new Error(_0xa7fe('0x4b'));if(_0x5262de[_0xa7fe('0x4c')]===_0xa7fe('0x4d')){var _0x39a947=_0x410674[_0xa7fe('0x25')]({'plain':!![]});var _0x4d624c=_0xa7fe('0x26');return db['UserProfileSection'][_0xa7fe('0x48')]({'where':{'name':_0x4d624c,'userProfileId':_0x5262de[_0xa7fe('0x4f')]},'raw':!![]})[_0xa7fe('0x24')](function(_0x1d7eca){if(_0x1d7eca&&_0x1d7eca[_0xa7fe('0x50')]===0x0){return db['UserProfileResource'][_0xa7fe('0x49')]({'name':_0x39a947[_0xa7fe('0x2a')],'resourceId':_0x39a947['id'],'type':_0x1d7eca['name'],'sectionId':_0x1d7eca['id']},{})[_0xa7fe('0x24')](function(){return _0x410674;});}else{return _0x410674;}})[_0xa7fe('0x45')](function(_0x4a88d2){logger[_0xa7fe('0x28')](_0xa7fe('0x51'),_0x4a88d2);throw _0x4a88d2;});}return _0x410674;});}})[_0xa7fe('0x24')](respondWithResult(_0xae7bea,0xc9))[_0xa7fe('0x45')](handleError(_0xae7bea,null));};exports[_0xa7fe('0x23')]=function(_0x5050b2,_0x2c5241){if(_0x5050b2[_0xa7fe('0x4a')]['id']){delete _0x5050b2[_0xa7fe('0x4a')]['id'];}return db[_0xa7fe('0x42')][_0xa7fe('0x48')]({'where':{'id':_0x5050b2[_0xa7fe('0x46')]['id']}})[_0xa7fe('0x24')](handleEntityNotFound(_0x2c5241,null))[_0xa7fe('0x24')](saveUpdates(_0x5050b2[_0xa7fe('0x4a')],null))['then'](respondWithResult(_0x2c5241,null))[_0xa7fe('0x45')](handleError(_0x2c5241,null));};exports[_0xa7fe('0x55')]=function(_0x5356d8,_0x2ae0fa){return db['JscriptyProject'][_0xa7fe('0x48')]({'where':{'id':_0x5356d8[_0xa7fe('0x46')]['id']}})[_0xa7fe('0x24')](handleEntityNotFound(_0x2ae0fa,null))[_0xa7fe('0x24')](removeEntity(_0x2ae0fa,null))['catch'](handleError(_0x2ae0fa,null));};exports[_0xa7fe('0x56')]=function(_0x1d6398,_0x237d8c,_0x1d4e4a){var _0x4b767a={'raw':!![],'where':{}};var _0x8e04bf={};var _0x175489={'count':0x0,'rows':[]};return db[_0xa7fe('0x42')][_0xa7fe('0x57')]({'where':{'id':_0x1d6398[_0xa7fe('0x46')]['id']}})[_0xa7fe('0x24')](handleEntityNotFound(_0x237d8c,null))[_0xa7fe('0x24')](function(_0x2c15fc){if(_0x2c15fc){_0x8e04bf[_0xa7fe('0x30')]=_[_0xa7fe('0x33')](db[_0xa7fe('0x58')][_0xa7fe('0x2d')]);_0x8e04bf[_0xa7fe('0x32')]=_[_0xa7fe('0x33')](_0x1d6398['query']);_0x8e04bf[_0xa7fe('0x34')]=_[_0xa7fe('0x36')](_0x8e04bf[_0xa7fe('0x30')],_0x8e04bf['query']);_0x4b767a[_0xa7fe('0x35')]=_['intersection'](_0x8e04bf[_0xa7fe('0x30')],qs['fields'](_0x1d6398[_0xa7fe('0x32')]['fields']));_0x4b767a['attributes']=_0x4b767a[_0xa7fe('0x35')][_0xa7fe('0x47')]?_0x4b767a['attributes']:_0x8e04bf[_0xa7fe('0x30')];if(!_0x1d6398['query']['hasOwnProperty']('nolimit')){_0x4b767a[_0xa7fe('0x1d')]=qs['limit'](_0x1d6398[_0xa7fe('0x32')][_0xa7fe('0x1d')]);_0x4b767a[_0xa7fe('0x1b')]=qs[_0xa7fe('0x1b')](_0x1d6398['query'][_0xa7fe('0x1b')]);}_0x4b767a[_0xa7fe('0x3a')]=qs['sort'](_0x1d6398[_0xa7fe('0x32')][_0xa7fe('0x3b')]);_0x4b767a['where']=qs[_0xa7fe('0x34')](_[_0xa7fe('0x59')](_0x1d6398['query'],_0x8e04bf[_0xa7fe('0x34')]));_0x4b767a[_0xa7fe('0x3c')][_0xa7fe('0x5a')]=_0x2c15fc['id'];if(_0x1d6398[_0xa7fe('0x32')][_0xa7fe('0x5b')]){_0x4b767a[_0xa7fe('0x3c')]=_[_0xa7fe('0x3d')](_0x4b767a['where'],{'$or':_['map'](_0x4b767a[_0xa7fe('0x35')],function(_0x3f8b5a){var _0x484114={};_0x484114[_0x3f8b5a]={'$like':'%'+_0x1d6398[_0xa7fe('0x32')][_0xa7fe('0x5b')]+'%'};return _0x484114;})});}_0x4b767a=_[_0xa7fe('0x3d')]({},_0x4b767a,_0x1d6398[_0xa7fe('0x3f')]);return db['JscriptySessionReport'][_0xa7fe('0x1e')]({'where':_0x4b767a[_0xa7fe('0x3c')]})['then'](function(_0x63d1cf){_0x175489[_0xa7fe('0x1e')]=_0x63d1cf;if(_0x1d6398[_0xa7fe('0x32')][_0xa7fe('0x40')]){_0x4b767a[_0xa7fe('0x41')]=[{'all':!![]}];}return db[_0xa7fe('0x58')][_0xa7fe('0x43')](_0x4b767a);})['then'](function(_0x408768){_0x175489[_0xa7fe('0x44')]=_0x408768;return _0x175489;});}})[_0xa7fe('0x24')](respondWithFilteredResult(_0x237d8c,_0x4b767a))[_0xa7fe('0x45')](handleError(_0x237d8c,null));};exports['getAnswers']=function(_0x21b9f7,_0x367f55,_0x1f48df){var _0x14916b={'raw':!![],'where':{}};var _0x295e0a={};var _0x427cfb={'count':0x0,'rows':[]};return db['JscriptyProject']['findOne']({'where':{'id':_0x21b9f7[_0xa7fe('0x46')]['id']}})[_0xa7fe('0x24')](handleEntityNotFound(_0x367f55,null))[_0xa7fe('0x24')](function(_0x81c253){if(_0x81c253){_0x295e0a[_0xa7fe('0x30')]=_[_0xa7fe('0x33')](db[_0xa7fe('0x5c')][_0xa7fe('0x2d')]);_0x295e0a[_0xa7fe('0x32')]=_['keys'](_0x21b9f7[_0xa7fe('0x32')]);_0x295e0a['filters']=_[_0xa7fe('0x36')](_0x295e0a[_0xa7fe('0x30')],_0x295e0a[_0xa7fe('0x32')]);_0x14916b[_0xa7fe('0x35')]=_[_0xa7fe('0x36')](_0x295e0a[_0xa7fe('0x30')],qs['fields'](_0x21b9f7[_0xa7fe('0x32')]['fields']));_0x14916b[_0xa7fe('0x35')]=_0x14916b['attributes']['length']?_0x14916b[_0xa7fe('0x35')]:_0x295e0a[_0xa7fe('0x30')];if(!_0x21b9f7['query'][_0xa7fe('0x38')](_0xa7fe('0x39'))){_0x14916b['limit']=qs[_0xa7fe('0x1d')](_0x21b9f7[_0xa7fe('0x32')][_0xa7fe('0x1d')]);_0x14916b[_0xa7fe('0x1b')]=qs['offset'](_0x21b9f7['query'][_0xa7fe('0x1b')]);}_0x14916b['order']=qs[_0xa7fe('0x3b')](_0x21b9f7[_0xa7fe('0x32')][_0xa7fe('0x3b')]);_0x14916b[_0xa7fe('0x3c')]=qs[_0xa7fe('0x34')](_[_0xa7fe('0x59')](_0x21b9f7[_0xa7fe('0x32')],_0x295e0a[_0xa7fe('0x34')]));_0x14916b[_0xa7fe('0x3c')][_0xa7fe('0x5a')]=_0x81c253['id'];if(_0x21b9f7[_0xa7fe('0x32')][_0xa7fe('0x5b')]){_0x14916b[_0xa7fe('0x3c')]=_[_0xa7fe('0x3d')](_0x14916b[_0xa7fe('0x3c')],{'$or':_[_0xa7fe('0x31')](_0x14916b[_0xa7fe('0x35')],function(_0x1027e5){var _0x90f882={};_0x90f882[_0x1027e5]={'$like':'%'+_0x21b9f7[_0xa7fe('0x32')][_0xa7fe('0x5b')]+'%'};return _0x90f882;})});}_0x14916b=_[_0xa7fe('0x3d')]({},_0x14916b,_0x21b9f7[_0xa7fe('0x3f')]);return db[_0xa7fe('0x5c')]['count']({'where':_0x14916b[_0xa7fe('0x3c')]})[_0xa7fe('0x24')](function(_0x27beb1){_0x427cfb[_0xa7fe('0x1e')]=_0x27beb1;if(_0x21b9f7[_0xa7fe('0x32')][_0xa7fe('0x40')]){_0x14916b[_0xa7fe('0x41')]=[{'all':!![]}];}return db['JscriptyAnswerReport'][_0xa7fe('0x43')](_0x14916b);})[_0xa7fe('0x24')](function(_0x51b335){_0x427cfb['rows']=_0x51b335;return _0x427cfb;});}})['then'](respondWithFilteredResult(_0x367f55,_0x14916b))['catch'](handleError(_0x367f55,null));};function char(_0x4ad192){return _0xa7fe('0x5d')===typeof _0x4ad192?String[_0xa7fe('0x5e')]['apply'](null,arguments):_0x4ad192;}function needsEncapsulation(_0x2e909a){return!!_0x2e909a&&(_0x2e909a['toString']()[_0xa7fe('0x5f')](char(0xd))>=0x0||_0x2e909a['toString']()[_0xa7fe('0x5f')](char(0xa))>=0x0||_0x2e909a[_0xa7fe('0x60')]()[_0xa7fe('0x5f')](char(0x2c))>=0x0||_0x2e909a['toString']()[_0xa7fe('0x5f')](char(0x22))>=0x0);}function encapsulate(_0xf4eb62){var _0x5d6cf3=char(0x22),_0x121dbf='\x5c'+char(0x22),_0x4e7eb1=_0xf4eb62['toString']()[_0xa7fe('0x61')](new RegExp(_0x5d6cf3,'g'),_0x121dbf);return _0x5d6cf3+_0x4e7eb1+_0x5d6cf3;}exports['getSummary']=function(_0x2dc904,_0x209918,_0x58736e){var _0x9053e4,_0x5a96fc;var _0x4f1ccc={'where':{'ProjectId':_0x2dc904['params']['id']}};if(_0x2dc904[_0xa7fe('0x32')][_0xa7fe('0x62')]){_0x4f1ccc[_0xa7fe('0x3c')][_0xa7fe('0x63')]=JSON[_0xa7fe('0x64')](_0x2dc904[_0xa7fe('0x32')][_0xa7fe('0x62')]);}return db[_0xa7fe('0x58')][_0xa7fe('0x43')](_0x4f1ccc)[_0xa7fe('0x24')](handleEntityNotFound(_0x209918,null))[_0xa7fe('0x24')](function(_0x11b76a){if(_0x11b76a){_0x9053e4=_0x11b76a;return db['JscriptyQuestionReport'][_0xa7fe('0x43')]({'where':{'SessionId':{'$in':_[_0xa7fe('0x31')](_0x9053e4,'id')},'ProjectId':_0x2dc904[_0xa7fe('0x46')]['id']},'order':'-createdAt'});}})[_0xa7fe('0x24')](handleEntityNotFound(_0x209918,null))[_0xa7fe('0x24')](function(_0x3697cd){if(_0x3697cd){_0x5a96fc=_0x3697cd;var _0x39061c={};for(var _0x2ba52d=0x0,_0x7624e2=_0x5a96fc['length'];_0x2ba52d<_0x7624e2;_0x2ba52d++){if(!_0x39061c['hasOwnProperty'](_0x5a96fc[_0x2ba52d][_0xa7fe('0x65')])){_0x39061c[_0x5a96fc[_0x2ba52d]['questionId']]=needsEncapsulation(_0x5a96fc[_0x2ba52d]['question'])?encapsulate(_0x5a96fc[_0x2ba52d][_0xa7fe('0x66')]):_0x5a96fc[_0x2ba52d]['question'];}}var _0x3c77ec=[],_0x5f26e8={};for(var _0x20d61f=0x0,_0x69934e=_0x9053e4[_0xa7fe('0x47')];_0x20d61f<_0x69934e;_0x20d61f++){_0x5f26e8={'ProjectId':_0x2dc904[_0xa7fe('0x46')]['id'],'SessionId':_0x9053e4[_0x20d61f]['id'],'StartTime':moment(_0x9053e4[_0x20d61f][_0xa7fe('0x63')])[_0xa7fe('0x67')](_0xa7fe('0x68'))};for(var _0x47601b=0x0,_0x1cfd13=_0x5a96fc[_0xa7fe('0x47')];_0x47601b<_0x1cfd13;_0x47601b++){if(_0x5a96fc[_0x47601b][_0xa7fe('0x69')]==_0x9053e4[_0x20d61f]['id']&&_0x39061c['hasOwnProperty'](_0x5a96fc[_0x47601b][_0xa7fe('0x65')])){_0x5f26e8[_0x39061c[_0x5a96fc[_0x47601b]['questionId']]]=_0x5a96fc[_0x47601b][_0xa7fe('0x6a')];}}for(var _0x522f8d in _0x39061c){if(!_0x5f26e8[_0xa7fe('0x38')](_0x39061c[_0x522f8d])){_0x5f26e8[_0x39061c[_0x522f8d]]=null;}}_0x3c77ec[_0xa7fe('0x6b')](_0x5f26e8);}return _0x3c77ec;}})['then'](function(_0x45d3db){if(!_[_0xa7fe('0x6c')](_0x45d3db)){var _0x3bda80=toCsv(_0x45d3db);var _0x211462=Date[_0xa7fe('0x6d')]();fs[_0xa7fe('0x6e')](util[_0xa7fe('0x67')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0x2dc904[_0xa7fe('0x46')]['id'],_0x211462),_0x3bda80);_0x209918['setHeader']('Content-disposition',_0xa7fe('0x6f')+util[_0xa7fe('0x67')](_0xa7fe('0x70'),_0x2dc904[_0xa7fe('0x46')]['id'],_0x211462));_0x209918[_0xa7fe('0x71')](_0xa7fe('0x72'),_0xa7fe('0x73'));return _0x209918[_0xa7fe('0x74')](util[_0xa7fe('0x67')]('/tmp/Jscripty_Project_%d_Summary_%s.csv',_0x2dc904[_0xa7fe('0x46')]['id'],_0x211462));}else{return _0x209918[_0xa7fe('0x17')](0xcc);}})[_0xa7fe('0x45')](handleError(_0x209918,null));};