Built motion from commit e1760111.|2.6.18
[motion2.git] / server / components / parsers / advancedSearch.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 _0xf044=['$startsWith','pop','utcOffset','hours','seconds','lodash','moment','parseSearch','sqlOperator','startsWith','[$or]','and','replace','split','length','slice','forEach','shift','filter','indexOf','map','conditions','push','buildExpression','DATE','$eq','$between','value','includes','$gt','$lte','operator','add','days','format','castTo','text','CAST(','field','\x20AS\x20','$notIn','\x20IS\x20NULL)','$in','=\x20?','<>\x20?','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?','<=\x20?','>=\x20?','BETWEEN\x20?\x20AND\x20?','start'];(function(_0x15337b,_0x4fc0b0){var _0x493c20=function(_0x5941a6){while(--_0x5941a6){_0x15337b['push'](_0x15337b['shift']());}};_0x493c20(++_0x4fc0b0);}(_0xf044,0x149));var _0x4f04=function(_0x1de166,_0x2fb1b1){_0x1de166=_0x1de166-0x0;var _0x5ee5a5=_0xf044[_0x1de166];return _0x5ee5a5;};'use strict';var _=require(_0x4f04('0x0'));var moment=require(_0x4f04('0x1'));exports[_0x4f04('0x2')]=function(_0x2238e8){var _0x566f2d={'conditions':[]};_0x566f2d[_0x4f04('0x3')]=_[_0x4f04('0x4')](_0x2238e8,_0x4f04('0x5'))?'or':_0x4f04('0x6');var _0x11571d=_0x2238e8[_0x4f04('0x7')]('[$and]','')[_0x4f04('0x7')](_0x4f04('0x5'),'')[_0x4f04('0x8')]('||');for(var _0x508c8a=0x0;_0x508c8a<_0x11571d[_0x4f04('0x9')];_0x508c8a++){var _0x19c5dc=_0x11571d[_0x508c8a][_0x4f04('0x8')](':=');var _0x4ccf34=_0x19c5dc[0x0];var _0x22384d=_0x19c5dc[_0x4f04('0xa')](0x1);_0x22384d[_0x4f04('0xb')](function(_0x11de75){var _0x3eb3f2=_0x11de75[_0x4f04('0x8')]('[')[_0x4f04('0xc')]();var _0x4f7b48=_0x11de75['match'](/\[(.*?)\]/g);_0x4f7b48[_0x4f04('0xb')](function(_0x5b2666){var _0x1e48ca=_0x5b2666[_0x4f04('0x8')]('[')[_0x4f04('0xd')](function(_0x3d9dbe){return _0x3d9dbe[_0x4f04('0xe')](']')>-0x1;})[_0x4f04('0xf')](function(_0x1968cf){return _0x1968cf[_0x4f04('0x8')](']')[0x0];})[0x0];_0x566f2d[_0x4f04('0x10')][_0x4f04('0x11')]({'field':_0x4ccf34,'operator':_0x3eb3f2,'value':_0x1e48ca});});});}return _0x566f2d;};exports[_0x4f04('0x12')]=function(_0x12a50a,_0x31ea45,_0x563060){var _0x1cafe7={};if(_0x31ea45===_0x4f04('0x13')){if(_0x563060['operator']===_0x4f04('0x14')){_0x563060['operator']=_0x4f04('0x15');_0x563060[_0x4f04('0x16')]+=','+_0x563060[_0x4f04('0x16')];}else if(_[_0x4f04('0x17')]([_0x4f04('0x18'),_0x4f04('0x19')],_0x563060[_0x4f04('0x1a')])){_0x563060[_0x4f04('0x16')]=moment(_0x563060[_0x4f04('0x16')])[_0x4f04('0x1b')](0x1,_0x4f04('0x1c'))[_0x4f04('0x1d')]('YYYY-MM-DD');}}if(_0x563060['castTo']){_0x31ea45=_0x563060[_0x4f04('0x1e')];_0x1cafe7[_0x4f04('0x1f')]=_0x4f04('0x20')+_0x12a50a+'.'+_0x563060[_0x4f04('0x21')]+_0x4f04('0x22')+_0x563060[_0x4f04('0x1e')]+')\x20'+parseOperator(_0x563060[_0x4f04('0x1a')]);}else{_0x1cafe7[_0x4f04('0x1f')]=_0x12a50a+'.'+_0x563060[_0x4f04('0x21')]+'\x20'+parseOperator(_0x563060[_0x4f04('0x1a')]);}if(_[_0x4f04('0x17')](['$ne',_0x4f04('0x23')],_0x563060[_0x4f04('0x1a')]))_0x1cafe7[_0x4f04('0x1f')]='('+_0x1cafe7['text']+'\x20OR\x20'+_0x12a50a+'.'+_0x563060[_0x4f04('0x21')]+_0x4f04('0x24');_0x1cafe7[_0x4f04('0x16')]=parseValue(_0x31ea45,_0x563060[_0x4f04('0x1a')],_0x563060['value']);return _0x1cafe7;};function parseOperator(_0x2e9701){var _0x53625b;switch(_0x2e9701){case _0x4f04('0x25'):_0x53625b='IN\x20?';break;case _0x4f04('0x23'):_0x53625b='NOT\x20IN\x20?';break;case'$eq':_0x53625b=_0x4f04('0x26');break;case'$ne':_0x53625b=_0x4f04('0x27');break;case'$substring':case'$startsWith':case _0x4f04('0x28'):_0x53625b=_0x4f04('0x29');break;case _0x4f04('0x2a'):_0x53625b=_0x4f04('0x2b');break;case _0x4f04('0x18'):_0x53625b=_0x4f04('0x2c');break;case _0x4f04('0x19'):_0x53625b=_0x4f04('0x2d');break;case'$gte':_0x53625b=_0x4f04('0x2e');break;case'$between':_0x53625b=_0x4f04('0x2f');break;}return _0x53625b;}function parseValue(_0x968744,_0x14d0e3,_0x50bf24){var _0x3aa5cb={'start':undefined,'end':undefined};switch(_0x14d0e3){case _0x4f04('0x25'):case'$notIn':_0x3aa5cb[_0x4f04('0x30')]=_0x50bf24[_0x4f04('0x8')](',');break;case'$substring':_0x3aa5cb['start']='%'+_0x50bf24+'%';break;case _0x4f04('0x31'):_0x3aa5cb['start']=_0x50bf24+'%';break;case _0x4f04('0x28'):_0x3aa5cb[_0x4f04('0x30')]='%'+_0x50bf24;break;case _0x4f04('0x15'):var _0x35e75a=_0x50bf24[_0x4f04('0x8')](',');var _0x50bf24=_0x35e75a[_0x4f04('0xc')]();var _0x45aa0c=_0x35e75a[_0x4f04('0x32')]();if(_0x968744==='DATE'){_0x50bf24=moment(_0x50bf24)[_0x4f04('0x33')](0x0,!![])[_0x4f04('0x1d')]();_0x45aa0c=moment(_0x45aa0c)[_0x4f04('0x33')](0x0,!![])[_0x4f04('0x1b')](0x17,_0x4f04('0x34'))[_0x4f04('0x1b')](0x3b,'minutes')['add'](0x3b,_0x4f04('0x35'))['format']();}_0x3aa5cb={'start':_0x50bf24,'end':_0x45aa0c};break;default:_0x3aa5cb[_0x4f04('0x30')]=_0x50bf24;break;}return _0x3aa5cb;}