Built motion from commit (unavailable).|2.5.4
[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 _0x1dab=['DATE','utcOffset','add','minutes','seconds','lodash','moment','parseSearch','sqlOperator','startsWith','and','replace','[$and]','[$or]','length','split','slice','shift','forEach','filter','map','push','buildExpression','operator','$between','value','$gt','$lte','days','format','castTo','text','CAST(','includes','\x20OR\x20','field','$in','IN\x20?','$notIn','NOT\x20IN\x20?','$eq','=\x20?','<>\x20?','$substring','$endsWith','$lt','<\x20?','>\x20?','$gte','start','$startsWith','pop'];(function(_0xa74d52,_0x430427){var _0x1e1247=function(_0x5128be){while(--_0x5128be){_0xa74d52['push'](_0xa74d52['shift']());}};_0x1e1247(++_0x430427);}(_0x1dab,0x13d));var _0xb1da=function(_0x5db018,_0x504f94){_0x5db018=_0x5db018-0x0;var _0xe48a05=_0x1dab[_0x5db018];return _0xe48a05;};'use strict';var _=require(_0xb1da('0x0'));var moment=require(_0xb1da('0x1'));exports[_0xb1da('0x2')]=function(_0x127a9a){var _0x32919f={'conditions':[]};_0x32919f[_0xb1da('0x3')]=_[_0xb1da('0x4')](_0x127a9a,'[$or]')?'or':_0xb1da('0x5');var _0x5afbac=_0x127a9a[_0xb1da('0x6')](_0xb1da('0x7'),'')[_0xb1da('0x6')](_0xb1da('0x8'),'')['split']('||');for(var _0x5078ce=0x0;_0x5078ce<_0x5afbac[_0xb1da('0x9')];_0x5078ce++){var _0x464b59=_0x5afbac[_0x5078ce][_0xb1da('0xa')](':=');var _0x155b2c=_0x464b59[0x0];var _0x287e31=_0x464b59[_0xb1da('0xb')](0x1);_0x287e31['forEach'](function(_0x55d22b){var _0x55c7f3=_0x55d22b[_0xb1da('0xa')]('[')[_0xb1da('0xc')]();var _0x220f63=_0x55d22b['match'](/\[(.*?)\]/g);_0x220f63[_0xb1da('0xd')](function(_0x2327c5){var _0x2b9f0a=_0x2327c5[_0xb1da('0xa')]('[')[_0xb1da('0xe')](function(_0xd1426c){return _0xd1426c['indexOf'](']')>-0x1;})[_0xb1da('0xf')](function(_0x9d26e){return _0x9d26e[_0xb1da('0xa')](']')[0x0];})[0x0];_0x32919f['conditions'][_0xb1da('0x10')]({'field':_0x155b2c,'operator':_0x55c7f3,'value':_0x2b9f0a});});});}return _0x32919f;};exports[_0xb1da('0x11')]=function(_0x24e168,_0x4bf115,_0xe0870a){var _0x1ca856={};if(_0x4bf115==='DATE'){if(_0xe0870a[_0xb1da('0x12')]==='$eq'){_0xe0870a['operator']=_0xb1da('0x13');_0xe0870a['value']+=','+_0xe0870a[_0xb1da('0x14')];}else if(_['includes']([_0xb1da('0x15'),_0xb1da('0x16')],_0xe0870a[_0xb1da('0x12')])){_0xe0870a[_0xb1da('0x14')]=moment(_0xe0870a['value'])['add'](0x1,_0xb1da('0x17'))[_0xb1da('0x18')]('YYYY-MM-DD');}}if(_0xe0870a[_0xb1da('0x19')]){_0x4bf115=_0xe0870a['castTo'];_0x1ca856[_0xb1da('0x1a')]=_0xb1da('0x1b')+_0x24e168+'.'+_0xe0870a['field']+'\x20AS\x20'+_0xe0870a[_0xb1da('0x19')]+')\x20'+parseOperator(_0xe0870a[_0xb1da('0x12')]);}else{_0x1ca856[_0xb1da('0x1a')]=_0x24e168+'.'+_0xe0870a['field']+'\x20'+parseOperator(_0xe0870a['operator']);}if(_[_0xb1da('0x1c')](['$ne','$notIn'],_0xe0870a[_0xb1da('0x12')]))_0x1ca856[_0xb1da('0x1a')]='('+_0x1ca856[_0xb1da('0x1a')]+_0xb1da('0x1d')+_0x24e168+'.'+_0xe0870a[_0xb1da('0x1e')]+'\x20IS\x20NULL)';_0x1ca856[_0xb1da('0x14')]=parseValue(_0x4bf115,_0xe0870a['operator'],_0xe0870a['value']);return _0x1ca856;};function parseOperator(_0x3ae3da){var _0x4a2391;switch(_0x3ae3da){case _0xb1da('0x1f'):_0x4a2391=_0xb1da('0x20');break;case _0xb1da('0x21'):_0x4a2391=_0xb1da('0x22');break;case _0xb1da('0x23'):_0x4a2391=_0xb1da('0x24');break;case'$ne':_0x4a2391=_0xb1da('0x25');break;case _0xb1da('0x26'):case'$startsWith':case _0xb1da('0x27'):_0x4a2391='LIKE\x20?';break;case _0xb1da('0x28'):_0x4a2391=_0xb1da('0x29');break;case _0xb1da('0x15'):_0x4a2391=_0xb1da('0x2a');break;case _0xb1da('0x16'):_0x4a2391='<=\x20?';break;case _0xb1da('0x2b'):_0x4a2391='>=\x20?';break;case _0xb1da('0x13'):_0x4a2391='BETWEEN\x20?\x20AND\x20?';break;}return _0x4a2391;}function parseValue(_0x555847,_0x5e8f14,_0x268600){var _0x3fb914={'start':undefined,'end':undefined};switch(_0x5e8f14){case _0xb1da('0x1f'):case _0xb1da('0x21'):_0x3fb914[_0xb1da('0x2c')]=_0x268600['split'](',');break;case _0xb1da('0x26'):_0x3fb914[_0xb1da('0x2c')]='%'+_0x268600+'%';break;case _0xb1da('0x2d'):_0x3fb914['start']=_0x268600+'%';break;case'$endsWith':_0x3fb914[_0xb1da('0x2c')]='%'+_0x268600;break;case'$between':var _0xeb6137=_0x268600[_0xb1da('0xa')](',');var _0x268600=_0xeb6137[_0xb1da('0xc')]();var _0x136f77=_0xeb6137[_0xb1da('0x2e')]();if(_0x555847===_0xb1da('0x2f')){_0x268600=moment(_0x268600)[_0xb1da('0x30')](0x0,!![])[_0xb1da('0x18')]();_0x136f77=moment(_0x136f77)['utcOffset'](0x0,!![])[_0xb1da('0x31')](0x17,'hours')[_0xb1da('0x31')](0x3b,_0xb1da('0x32'))['add'](0x3b,_0xb1da('0x33'))[_0xb1da('0x18')]();}_0x3fb914={'start':_0x268600,'end':_0x136f77};break;default:_0x3fb914[_0xb1da('0x2c')]=_0x268600;break;}return _0x3fb914;}