b25201c1916640b451fb3bc52319ac9d2ec360e3
[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 _0x5da8=['BETWEEN\x20?\x20AND\x20?','start','$between','pop','utcOffset','add','hours','minutes','seconds','lodash','moment','parseSearch','startsWith','[$or]','replace','[$and]','split','length','forEach','shift','match','indexOf','push','buildExpression','DATE','$eq','operator','value','$lte','days','format','YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','$ne','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','$notIn','NOT\x20IN\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?'];(function(_0x2c91e9,_0x2fb965){var _0x13f0ff=function(_0xb39edf){while(--_0xb39edf){_0x2c91e9['push'](_0x2c91e9['shift']());}};_0x13f0ff(++_0x2fb965);}(_0x5da8,0xe1));var _0x85da=function(_0x16bddd,_0x34c589){_0x16bddd=_0x16bddd-0x0;var _0x33fc0c=_0x5da8[_0x16bddd];return _0x33fc0c;};'use strict';var _=require(_0x85da('0x0'));var moment=require(_0x85da('0x1'));exports[_0x85da('0x2')]=function(_0x43cb4c){var _0x5a566d={'conditions':[]};_0x5a566d['sqlOperator']=_[_0x85da('0x3')](_0x43cb4c,_0x85da('0x4'))?'or':'and';var _0x15ea1c=_0x43cb4c[_0x85da('0x5')](_0x85da('0x6'),'')[_0x85da('0x5')]('[$or]','')[_0x85da('0x7')]('||');for(var _0x58ef22=0x0;_0x58ef22<_0x15ea1c[_0x85da('0x8')];_0x58ef22++){var _0x2d9f4d=_0x15ea1c[_0x58ef22][_0x85da('0x7')](':=');var _0x2b990b=_0x2d9f4d[0x0];var _0x5029cd=_0x2d9f4d['slice'](0x1);_0x5029cd[_0x85da('0x9')](function(_0x27d378){var _0x1087cc=_0x27d378[_0x85da('0x7')]('[')[_0x85da('0xa')]();var _0x2e77c1=_0x27d378[_0x85da('0xb')](/\[(.*?)\]/g);_0x2e77c1[_0x85da('0x9')](function(_0x57f6ca){var _0x1df68c=_0x57f6ca[_0x85da('0x7')]('[')['filter'](function(_0x234205){return _0x234205[_0x85da('0xc')](']')>-0x1;})['map'](function(_0x3cbc42){return _0x3cbc42[_0x85da('0x7')](']')[0x0];})[0x0];_0x5a566d['conditions'][_0x85da('0xd')]({'field':_0x2b990b,'operator':_0x1087cc,'value':_0x1df68c});});});}return _0x5a566d;};exports[_0x85da('0xe')]=function(_0x4423f0,_0x1981c2,_0xe04937){var _0x4e3b6a={};if(_0x1981c2===_0x85da('0xf')){if(_0xe04937['operator']===_0x85da('0x10')){_0xe04937[_0x85da('0x11')]='$between';_0xe04937[_0x85da('0x12')]+=','+_0xe04937[_0x85da('0x12')];}else if(_['includes'](['$gt',_0x85da('0x13')],_0xe04937[_0x85da('0x11')])){_0xe04937[_0x85da('0x12')]=moment(_0xe04937[_0x85da('0x12')])['add'](0x1,_0x85da('0x14'))[_0x85da('0x15')](_0x85da('0x16'));}}if(_0xe04937['castTo']){_0x1981c2=_0xe04937[_0x85da('0x17')];_0x4e3b6a[_0x85da('0x18')]=_0x85da('0x19')+_0x4423f0+'.'+_0xe04937[_0x85da('0x1a')]+_0x85da('0x1b')+_0xe04937['castTo']+')\x20'+parseOperator(_0xe04937[_0x85da('0x11')]);}else{_0x4e3b6a[_0x85da('0x18')]=_0x4423f0+'.'+_0xe04937[_0x85da('0x1a')]+'\x20'+parseOperator(_0xe04937[_0x85da('0x11')]);}if(_['includes']([_0x85da('0x1c'),'$notIn'],_0xe04937[_0x85da('0x11')]))_0x4e3b6a[_0x85da('0x18')]='('+_0x4e3b6a[_0x85da('0x18')]+_0x85da('0x1d')+_0x4423f0+'.'+_0xe04937[_0x85da('0x1a')]+_0x85da('0x1e');_0x4e3b6a[_0x85da('0x12')]=parseValue(_0x1981c2,_0xe04937['operator'],_0xe04937[_0x85da('0x12')]);return _0x4e3b6a;};function parseOperator(_0x41ba5d){var _0x283579;switch(_0x41ba5d){case _0x85da('0x1f'):_0x283579=_0x85da('0x20');break;case _0x85da('0x21'):_0x283579=_0x85da('0x22');break;case _0x85da('0x10'):_0x283579='=\x20?';break;case _0x85da('0x1c'):_0x283579=_0x85da('0x23');break;case _0x85da('0x24'):case _0x85da('0x25'):case _0x85da('0x26'):_0x283579=_0x85da('0x27');break;case'$lt':_0x283579=_0x85da('0x28');break;case'$gt':_0x283579=_0x85da('0x29');break;case _0x85da('0x13'):_0x283579=_0x85da('0x2a');break;case _0x85da('0x2b'):_0x283579=_0x85da('0x2c');break;case'$between':_0x283579=_0x85da('0x2d');break;}return _0x283579;}function parseValue(_0x45ff06,_0xa10c72,_0x558a5e){var _0xfe2509={'start':undefined,'end':undefined};switch(_0xa10c72){case _0x85da('0x1f'):case'$notIn':_0xfe2509[_0x85da('0x2e')]=_0x558a5e[_0x85da('0x7')](',');break;case _0x85da('0x24'):_0xfe2509[_0x85da('0x2e')]='%'+_0x558a5e+'%';break;case _0x85da('0x25'):_0xfe2509['start']=_0x558a5e+'%';break;case _0x85da('0x26'):_0xfe2509[_0x85da('0x2e')]='%'+_0x558a5e;break;case _0x85da('0x2f'):var _0x571bb6=_0x558a5e[_0x85da('0x7')](',');var _0x558a5e=_0x571bb6[_0x85da('0xa')]();var _0x2d4d0a=_0x571bb6[_0x85da('0x30')]();if(_0x45ff06==='DATE'){_0x558a5e=moment(_0x558a5e)[_0x85da('0x31')](0x0,!![])['format']();_0x2d4d0a=moment(_0x2d4d0a)['utcOffset'](0x0,!![])[_0x85da('0x32')](0x17,_0x85da('0x33'))[_0x85da('0x32')](0x3b,_0x85da('0x34'))[_0x85da('0x32')](0x3b,_0x85da('0x35'))['format']();}_0xfe2509={'start':_0x558a5e,'end':_0x2d4d0a};break;default:_0xfe2509['start']=_0x558a5e;break;}return _0xfe2509;}