Built motion from commit 10af8726.|2.6.34
[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 _0x47e6=['split','slice','forEach','shift','indexOf','conditions','buildExpression','operator','$between','value','$gt','$lte','add','days','YYYY-MM-DD','castTo','CAST(','field','\x20AS\x20','$ne','$notIn','text','\x20OR\x20','$in','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','pop','DATE','format','minutes','seconds','moment','parseSearch','sqlOperator','[$or]','and','replace'];(function(_0x1ca93c,_0x3271ab){var _0x185169=function(_0x507763){while(--_0x507763){_0x1ca93c['push'](_0x1ca93c['shift']());}};_0x185169(++_0x3271ab);}(_0x47e6,0x182));var _0x647e=function(_0x635271,_0x6ccc26){_0x635271=_0x635271-0x0;var _0x5e3773=_0x47e6[_0x635271];return _0x5e3773;};'use strict';var _=require('lodash');var moment=require(_0x647e('0x0'));exports[_0x647e('0x1')]=function(_0x138ed2){var _0x4e93dd={'conditions':[]};_0x4e93dd[_0x647e('0x2')]=_['startsWith'](_0x138ed2,_0x647e('0x3'))?'or':_0x647e('0x4');var _0x59f2fd=_0x138ed2[_0x647e('0x5')]('[$and]','')[_0x647e('0x5')](_0x647e('0x3'),'')[_0x647e('0x6')]('||');for(var _0x47de70=0x0;_0x47de70<_0x59f2fd['length'];_0x47de70++){var _0x327f39=_0x59f2fd[_0x47de70][_0x647e('0x6')](':=');var _0x1e8101=_0x327f39[0x0];var _0x185d32=_0x327f39[_0x647e('0x7')](0x1);_0x185d32[_0x647e('0x8')](function(_0x412dd7){var _0x4b7fe6=_0x412dd7[_0x647e('0x6')]('[')[_0x647e('0x9')]();var _0x2d5d1f=_0x412dd7['match'](/\[(.*?)\]/g);_0x2d5d1f[_0x647e('0x8')](function(_0xae699f){var _0x19e848=_0xae699f[_0x647e('0x6')]('[')['filter'](function(_0x337f46){return _0x337f46[_0x647e('0xa')](']')>-0x1;})['map'](function(_0x3d8c5e){return _0x3d8c5e[_0x647e('0x6')](']')[0x0];})[0x0];_0x4e93dd[_0x647e('0xb')]['push']({'field':_0x1e8101,'operator':_0x4b7fe6,'value':_0x19e848});});});}return _0x4e93dd;};exports[_0x647e('0xc')]=function(_0x37c463,_0x51b344,_0x39daf9){var _0x2d2964={};if(_0x51b344==='DATE'){if(_0x39daf9[_0x647e('0xd')]==='$eq'){_0x39daf9[_0x647e('0xd')]=_0x647e('0xe');_0x39daf9[_0x647e('0xf')]+=','+_0x39daf9[_0x647e('0xf')];}else if(_['includes']([_0x647e('0x10'),_0x647e('0x11')],_0x39daf9[_0x647e('0xd')])){_0x39daf9[_0x647e('0xf')]=moment(_0x39daf9[_0x647e('0xf')])[_0x647e('0x12')](0x1,_0x647e('0x13'))['format'](_0x647e('0x14'));}}if(_0x39daf9[_0x647e('0x15')]){_0x51b344=_0x39daf9[_0x647e('0x15')];_0x2d2964['text']=_0x647e('0x16')+_0x37c463+'.'+_0x39daf9[_0x647e('0x17')]+_0x647e('0x18')+_0x39daf9[_0x647e('0x15')]+')\x20'+parseOperator(_0x39daf9[_0x647e('0xd')]);}else{_0x2d2964['text']=_0x37c463+'.'+_0x39daf9['field']+'\x20'+parseOperator(_0x39daf9[_0x647e('0xd')]);}if(_['includes']([_0x647e('0x19'),_0x647e('0x1a')],_0x39daf9['operator']))_0x2d2964[_0x647e('0x1b')]='('+_0x2d2964[_0x647e('0x1b')]+_0x647e('0x1c')+_0x37c463+'.'+_0x39daf9['field']+'\x20IS\x20NULL)';_0x2d2964[_0x647e('0xf')]=parseValue(_0x51b344,_0x39daf9[_0x647e('0xd')],_0x39daf9[_0x647e('0xf')]);return _0x2d2964;};function parseOperator(_0x2722fc){var _0x5240d7;switch(_0x2722fc){case _0x647e('0x1d'):_0x5240d7='IN\x20?';break;case _0x647e('0x1a'):_0x5240d7=_0x647e('0x1e');break;case'$eq':_0x5240d7=_0x647e('0x1f');break;case _0x647e('0x19'):_0x5240d7=_0x647e('0x20');break;case _0x647e('0x21'):case _0x647e('0x22'):case _0x647e('0x23'):_0x5240d7=_0x647e('0x24');break;case'$lt':_0x5240d7=_0x647e('0x25');break;case _0x647e('0x10'):_0x5240d7=_0x647e('0x26');break;case _0x647e('0x11'):_0x5240d7=_0x647e('0x27');break;case _0x647e('0x28'):_0x5240d7=_0x647e('0x29');break;case _0x647e('0xe'):_0x5240d7=_0x647e('0x2a');break;}return _0x5240d7;}function parseValue(_0xad0cc5,_0x279f77,_0x5bd62e){var _0x2bbbf1={'start':undefined,'end':undefined};switch(_0x279f77){case _0x647e('0x1d'):case _0x647e('0x1a'):_0x2bbbf1[_0x647e('0x2b')]=_0x5bd62e['split'](',');break;case _0x647e('0x21'):_0x2bbbf1['start']='%'+_0x5bd62e+'%';break;case _0x647e('0x22'):_0x2bbbf1['start']=_0x5bd62e+'%';break;case'$endsWith':_0x2bbbf1['start']='%'+_0x5bd62e;break;case'$between':var _0x3898e0=_0x5bd62e[_0x647e('0x6')](',');var _0x5bd62e=_0x3898e0[_0x647e('0x9')]();var _0x4d7c4e=_0x3898e0[_0x647e('0x2c')]();if(_0xad0cc5===_0x647e('0x2d')){_0x5bd62e=moment(_0x5bd62e)['utcOffset'](0x0,!![])[_0x647e('0x2e')]();_0x4d7c4e=moment(_0x4d7c4e)['utcOffset'](0x0,!![])[_0x647e('0x12')](0x17,'hours')['add'](0x3b,_0x647e('0x2f'))['add'](0x3b,_0x647e('0x30'))[_0x647e('0x2e')]();}_0x2bbbf1={'start':_0x5bd62e,'end':_0x4d7c4e};break;default:_0x2bbbf1[_0x647e('0x2b')]=_0x5bd62e;break;}return _0x2bbbf1;}