5732b8b5344f884a900b5c929fd565556a60de35
[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 _0xa229=['conditions','push','buildExpression','$eq','value','includes','$gt','operator','add','days','YYYY-MM-DD','castTo','text','CAST(','field','$ne','$notIn','\x20IS\x20NULL)','IN\x20?','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','$between','pop','DATE','utcOffset','format','hours','minutes','seconds','lodash','moment','sqlOperator','[$or]','and','replace','[$and]','split','length','slice','shift','match','filter','indexOf','map'];(function(_0x5bb648,_0x4a6cdb){var _0x40d1eb=function(_0x447db){while(--_0x447db){_0x5bb648['push'](_0x5bb648['shift']());}};_0x40d1eb(++_0x4a6cdb);}(_0xa229,0x179));var _0x9a22=function(_0x321bb2,_0x202794){_0x321bb2=_0x321bb2-0x0;var _0x9c12ed=_0xa229[_0x321bb2];return _0x9c12ed;};'use strict';var _=require(_0x9a22('0x0'));var moment=require(_0x9a22('0x1'));exports['parseSearch']=function(_0x5abb38){var _0x258bba={'conditions':[]};_0x258bba[_0x9a22('0x2')]=_['startsWith'](_0x5abb38,_0x9a22('0x3'))?'or':_0x9a22('0x4');var _0x113c91=_0x5abb38[_0x9a22('0x5')](_0x9a22('0x6'),'')[_0x9a22('0x5')](_0x9a22('0x3'),'')[_0x9a22('0x7')]('||');for(var _0xefd803=0x0;_0xefd803<_0x113c91[_0x9a22('0x8')];_0xefd803++){var _0x32c17d=_0x113c91[_0xefd803][_0x9a22('0x7')](':=');var _0x44969d=_0x32c17d[0x0];var _0x2d0901=_0x32c17d[_0x9a22('0x9')](0x1);_0x2d0901['forEach'](function(_0x3d868c){var _0x592475=_0x3d868c[_0x9a22('0x7')]('[')[_0x9a22('0xa')]();var _0x2f2c23=_0x3d868c[_0x9a22('0xb')](/\[(.*?)\]/g);_0x2f2c23['forEach'](function(_0x2722ef){var _0x3044f1=_0x2722ef[_0x9a22('0x7')]('[')[_0x9a22('0xc')](function(_0x263990){return _0x263990[_0x9a22('0xd')](']')>-0x1;})[_0x9a22('0xe')](function(_0x3be942){return _0x3be942[_0x9a22('0x7')](']')[0x0];})[0x0];_0x258bba[_0x9a22('0xf')][_0x9a22('0x10')]({'field':_0x44969d,'operator':_0x592475,'value':_0x3044f1});});});}return _0x258bba;};exports[_0x9a22('0x11')]=function(_0x1297d3,_0x5c084d,_0x34d3e5){var _0x38e541={};if(_0x5c084d==='DATE'){if(_0x34d3e5['operator']===_0x9a22('0x12')){_0x34d3e5['operator']='$between';_0x34d3e5[_0x9a22('0x13')]+=','+_0x34d3e5[_0x9a22('0x13')];}else if(_[_0x9a22('0x14')]([_0x9a22('0x15'),'$lte'],_0x34d3e5[_0x9a22('0x16')])){_0x34d3e5['value']=moment(_0x34d3e5[_0x9a22('0x13')])[_0x9a22('0x17')](0x1,_0x9a22('0x18'))['format'](_0x9a22('0x19'));}}if(_0x34d3e5[_0x9a22('0x1a')]){_0x5c084d=_0x34d3e5[_0x9a22('0x1a')];_0x38e541[_0x9a22('0x1b')]=_0x9a22('0x1c')+_0x1297d3+'.'+_0x34d3e5[_0x9a22('0x1d')]+'\x20AS\x20'+_0x34d3e5[_0x9a22('0x1a')]+')\x20'+parseOperator(_0x34d3e5[_0x9a22('0x16')]);}else{_0x38e541[_0x9a22('0x1b')]=_0x1297d3+'.'+_0x34d3e5['field']+'\x20'+parseOperator(_0x34d3e5['operator']);}if(_[_0x9a22('0x14')]([_0x9a22('0x1e'),_0x9a22('0x1f')],_0x34d3e5['operator']))_0x38e541[_0x9a22('0x1b')]='('+_0x38e541[_0x9a22('0x1b')]+'\x20OR\x20'+_0x1297d3+'.'+_0x34d3e5[_0x9a22('0x1d')]+_0x9a22('0x20');_0x38e541[_0x9a22('0x13')]=parseValue(_0x5c084d,_0x34d3e5[_0x9a22('0x16')],_0x34d3e5['value']);return _0x38e541;};function parseOperator(_0x3a09f1){var _0x489159;switch(_0x3a09f1){case'$in':_0x489159=_0x9a22('0x21');break;case'$notIn':_0x489159=_0x9a22('0x22');break;case _0x9a22('0x12'):_0x489159=_0x9a22('0x23');break;case _0x9a22('0x1e'):_0x489159=_0x9a22('0x24');break;case _0x9a22('0x25'):case _0x9a22('0x26'):case _0x9a22('0x27'):_0x489159=_0x9a22('0x28');break;case'$lt':_0x489159=_0x9a22('0x29');break;case _0x9a22('0x15'):_0x489159=_0x9a22('0x2a');break;case'$lte':_0x489159=_0x9a22('0x2b');break;case _0x9a22('0x2c'):_0x489159=_0x9a22('0x2d');break;case'$between':_0x489159=_0x9a22('0x2e');break;}return _0x489159;}function parseValue(_0x1a4b31,_0x300326,_0x4b815d){var _0x32c5ad={'start':undefined,'end':undefined};switch(_0x300326){case'$in':case'$notIn':_0x32c5ad[_0x9a22('0x2f')]=_0x4b815d[_0x9a22('0x7')](',');break;case _0x9a22('0x25'):_0x32c5ad[_0x9a22('0x2f')]='%'+_0x4b815d+'%';break;case'$startsWith':_0x32c5ad[_0x9a22('0x2f')]=_0x4b815d+'%';break;case'$endsWith':_0x32c5ad['start']='%'+_0x4b815d;break;case _0x9a22('0x30'):var _0x635598=_0x4b815d[_0x9a22('0x7')](',');var _0x4b815d=_0x635598[_0x9a22('0xa')]();var _0x3e98e1=_0x635598[_0x9a22('0x31')]();if(_0x1a4b31===_0x9a22('0x32')){_0x4b815d=moment(_0x4b815d)[_0x9a22('0x33')](0x0,!![])[_0x9a22('0x34')]();_0x3e98e1=moment(_0x3e98e1)[_0x9a22('0x33')](0x0,!![])['add'](0x17,_0x9a22('0x35'))[_0x9a22('0x17')](0x3b,_0x9a22('0x36'))[_0x9a22('0x17')](0x3b,_0x9a22('0x37'))[_0x9a22('0x34')]();}_0x32c5ad={'start':_0x4b815d,'end':_0x3e98e1};break;default:_0x32c5ad[_0x9a22('0x2f')]=_0x4b815d;break;}return _0x32c5ad;}