cfb7e87143828f7a9d939e48b7551e53f65dba70
[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 _0xef0b=['hours','minutes','lodash','moment','parseSearch','sqlOperator','startsWith','[$or]','and','replace','[$and]','length','split','slice','forEach','shift','filter','map','conditions','push','DATE','$eq','operator','$between','value','includes','days','format','YYYY-MM-DD','castTo','text','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','=\x20?','$endsWith','LIKE\x20?','>\x20?','$lte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','$substring','pop','utcOffset','add'];(function(_0x496738,_0x3f1a9f){var _0xee1381=function(_0x4dc50c){while(--_0x4dc50c){_0x496738['push'](_0x496738['shift']());}};_0xee1381(++_0x3f1a9f);}(_0xef0b,0xd2));var _0xbef0=function(_0x551c4b,_0x53c6a9){_0x551c4b=_0x551c4b-0x0;var _0x167cd5=_0xef0b[_0x551c4b];return _0x167cd5;};'use strict';var _=require(_0xbef0('0x0'));var moment=require(_0xbef0('0x1'));exports[_0xbef0('0x2')]=function(_0x57dea){var _0x1585f9={'conditions':[]};_0x1585f9[_0xbef0('0x3')]=_[_0xbef0('0x4')](_0x57dea,_0xbef0('0x5'))?'or':_0xbef0('0x6');var _0xb64e76=_0x57dea[_0xbef0('0x7')](_0xbef0('0x8'),'')[_0xbef0('0x7')](_0xbef0('0x5'),'')['split']('||');for(var _0x12f34c=0x0;_0x12f34c<_0xb64e76[_0xbef0('0x9')];_0x12f34c++){var _0x555ca0=_0xb64e76[_0x12f34c][_0xbef0('0xa')](':=');var _0x57e783=_0x555ca0[0x0];var _0x473a6e=_0x555ca0[_0xbef0('0xb')](0x1);_0x473a6e[_0xbef0('0xc')](function(_0x1a7e0e){var _0x4e10f5=_0x1a7e0e[_0xbef0('0xa')]('[')[_0xbef0('0xd')]();var _0x2c697d=_0x1a7e0e['match'](/\[(.*?)\]/g);_0x2c697d[_0xbef0('0xc')](function(_0x2e73d6){var _0x1d0d15=_0x2e73d6[_0xbef0('0xa')]('[')[_0xbef0('0xe')](function(_0x3884fe){return _0x3884fe['indexOf'](']')>-0x1;})[_0xbef0('0xf')](function(_0x44b2c1){return _0x44b2c1[_0xbef0('0xa')](']')[0x0];})[0x0];_0x1585f9[_0xbef0('0x10')][_0xbef0('0x11')]({'field':_0x57e783,'operator':_0x4e10f5,'value':_0x1d0d15});});});}return _0x1585f9;};exports['buildExpression']=function(_0x2fb5e8,_0x51e1d9,_0x1b61b2){var _0x1eb6ba={};if(_0x51e1d9===_0xbef0('0x12')){if(_0x1b61b2['operator']===_0xbef0('0x13')){_0x1b61b2[_0xbef0('0x14')]=_0xbef0('0x15');_0x1b61b2['value']+=','+_0x1b61b2[_0xbef0('0x16')];}else if(_[_0xbef0('0x17')](['$gt','$lte'],_0x1b61b2[_0xbef0('0x14')])){_0x1b61b2['value']=moment(_0x1b61b2[_0xbef0('0x16')])['add'](0x1,_0xbef0('0x18'))[_0xbef0('0x19')](_0xbef0('0x1a'));}}if(_0x1b61b2[_0xbef0('0x1b')]){_0x51e1d9=_0x1b61b2['castTo'];_0x1eb6ba[_0xbef0('0x1c')]='CAST('+_0x2fb5e8+'.'+_0x1b61b2[_0xbef0('0x1d')]+_0xbef0('0x1e')+_0x1b61b2[_0xbef0('0x1b')]+')\x20'+parseOperator(_0x1b61b2[_0xbef0('0x14')]);}else{_0x1eb6ba[_0xbef0('0x1c')]=_0x2fb5e8+'.'+_0x1b61b2[_0xbef0('0x1d')]+'\x20'+parseOperator(_0x1b61b2['operator']);}if(_[_0xbef0('0x17')]([_0xbef0('0x1f'),_0xbef0('0x20')],_0x1b61b2[_0xbef0('0x14')]))_0x1eb6ba[_0xbef0('0x1c')]='('+_0x1eb6ba[_0xbef0('0x1c')]+_0xbef0('0x21')+_0x2fb5e8+'.'+_0x1b61b2[_0xbef0('0x1d')]+_0xbef0('0x22');_0x1eb6ba['value']=parseValue(_0x51e1d9,_0x1b61b2['operator'],_0x1b61b2[_0xbef0('0x16')]);return _0x1eb6ba;};function parseOperator(_0x4ee4f5){var _0x396f30;switch(_0x4ee4f5){case _0xbef0('0x23'):_0x396f30=_0xbef0('0x24');break;case'$notIn':_0x396f30=_0xbef0('0x25');break;case _0xbef0('0x13'):_0x396f30=_0xbef0('0x26');break;case _0xbef0('0x1f'):_0x396f30='<>\x20?';break;case'$substring':case'$startsWith':case _0xbef0('0x27'):_0x396f30=_0xbef0('0x28');break;case'$lt':_0x396f30='<\x20?';break;case'$gt':_0x396f30=_0xbef0('0x29');break;case _0xbef0('0x2a'):_0x396f30='<=\x20?';break;case'$gte':_0x396f30=_0xbef0('0x2b');break;case _0xbef0('0x15'):_0x396f30=_0xbef0('0x2c');break;}return _0x396f30;}function parseValue(_0x591893,_0x40c4ba,_0x116de7){var _0x3a8fc6={'start':undefined,'end':undefined};switch(_0x40c4ba){case _0xbef0('0x23'):case _0xbef0('0x20'):_0x3a8fc6[_0xbef0('0x2d')]=_0x116de7[_0xbef0('0xa')](',');break;case _0xbef0('0x2e'):_0x3a8fc6[_0xbef0('0x2d')]='%'+_0x116de7+'%';break;case'$startsWith':_0x3a8fc6[_0xbef0('0x2d')]=_0x116de7+'%';break;case _0xbef0('0x27'):_0x3a8fc6[_0xbef0('0x2d')]='%'+_0x116de7;break;case _0xbef0('0x15'):var _0x1d8f79=_0x116de7['split'](',');var _0x116de7=_0x1d8f79[_0xbef0('0xd')]();var _0x5c5b27=_0x1d8f79[_0xbef0('0x2f')]();if(_0x591893===_0xbef0('0x12')){_0x116de7=moment(_0x116de7)['utcOffset'](0x0,!![])[_0xbef0('0x19')]();_0x5c5b27=moment(_0x5c5b27)[_0xbef0('0x30')](0x0,!![])[_0xbef0('0x31')](0x17,_0xbef0('0x32'))[_0xbef0('0x31')](0x3b,_0xbef0('0x33'))[_0xbef0('0x31')](0x3b,'seconds')[_0xbef0('0x19')]();}_0x3a8fc6={'start':_0x116de7,'end':_0x5c5b27};break;default:_0x3a8fc6[_0xbef0('0x2d')]=_0x116de7;break;}return _0x3a8fc6;}