3b1cf2e8d85cc67d9594f97278869c3db54956ca
[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 _0x3560=['startsWith','replace','length','split','slice','forEach','match','filter','map','conditions','DATE','$between','value','$gt','$lte','operator','days','format','text','field','\x20AS\x20','includes','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','NOT\x20IN\x20?','$eq','<>\x20?','$startsWith','LIKE\x20?','$lt','<\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','$in','start','$endsWith','shift','pop','utcOffset','add','hours','minutes','lodash','parseSearch'];(function(_0x4f4d19,_0x574245){var _0x27a258=function(_0x38da3e){while(--_0x38da3e){_0x4f4d19['push'](_0x4f4d19['shift']());}};_0x27a258(++_0x574245);}(_0x3560,0x17e));var _0x0356=function(_0x35d4e9,_0x298c61){_0x35d4e9=_0x35d4e9-0x0;var _0x5c2770=_0x3560[_0x35d4e9];return _0x5c2770;};'use strict';var _=require(_0x0356('0x0'));var moment=require('moment');exports[_0x0356('0x1')]=function(_0x253230){var _0x25e888={'conditions':[]};_0x25e888['sqlOperator']=_[_0x0356('0x2')](_0x253230,'[$or]')?'or':'and';var _0x3b2f90=_0x253230[_0x0356('0x3')]('[$and]','')[_0x0356('0x3')]('[$or]','')['split']('||');for(var _0x1c39c6=0x0;_0x1c39c6<_0x3b2f90[_0x0356('0x4')];_0x1c39c6++){var _0x382a0e=_0x3b2f90[_0x1c39c6][_0x0356('0x5')](':=');var _0x14b8fc=_0x382a0e[0x0];var _0x28196c=_0x382a0e[_0x0356('0x6')](0x1);_0x28196c[_0x0356('0x7')](function(_0x10ba33){var _0xf18fa6=_0x10ba33[_0x0356('0x5')]('[')['shift']();var _0x155edf=_0x10ba33[_0x0356('0x8')](/\[(.*?)\]/g);_0x155edf[_0x0356('0x7')](function(_0x4b897b){var _0x4ea325=_0x4b897b['split']('[')[_0x0356('0x9')](function(_0x30af0b){return _0x30af0b['indexOf'](']')>-0x1;})[_0x0356('0xa')](function(_0x479a0b){return _0x479a0b[_0x0356('0x5')](']')[0x0];})[0x0];_0x25e888[_0x0356('0xb')]['push']({'field':_0x14b8fc,'operator':_0xf18fa6,'value':_0x4ea325});});});}return _0x25e888;};exports['buildExpression']=function(_0x2bfd88,_0x386ff5,_0x594c8a){var _0x40285c={};if(_0x386ff5===_0x0356('0xc')){if(_0x594c8a['operator']==='$eq'){_0x594c8a['operator']=_0x0356('0xd');_0x594c8a[_0x0356('0xe')]+=','+_0x594c8a[_0x0356('0xe')];}else if(_['includes']([_0x0356('0xf'),_0x0356('0x10')],_0x594c8a[_0x0356('0x11')])){_0x594c8a[_0x0356('0xe')]=moment(_0x594c8a[_0x0356('0xe')])['add'](0x1,_0x0356('0x12'))[_0x0356('0x13')]('YYYY-MM-DD');}}if(_0x594c8a['castTo']){_0x386ff5=_0x594c8a['castTo'];_0x40285c[_0x0356('0x14')]='CAST('+_0x2bfd88+'.'+_0x594c8a[_0x0356('0x15')]+_0x0356('0x16')+_0x594c8a['castTo']+')\x20'+parseOperator(_0x594c8a[_0x0356('0x11')]);}else{_0x40285c['text']=_0x2bfd88+'.'+_0x594c8a[_0x0356('0x15')]+'\x20'+parseOperator(_0x594c8a[_0x0356('0x11')]);}if(_[_0x0356('0x17')]([_0x0356('0x18'),_0x0356('0x19')],_0x594c8a['operator']))_0x40285c[_0x0356('0x14')]='('+_0x40285c[_0x0356('0x14')]+_0x0356('0x1a')+_0x2bfd88+'.'+_0x594c8a[_0x0356('0x15')]+_0x0356('0x1b');_0x40285c[_0x0356('0xe')]=parseValue(_0x386ff5,_0x594c8a['operator'],_0x594c8a[_0x0356('0xe')]);return _0x40285c;};function parseOperator(_0x541e57){var _0x2dfe49;switch(_0x541e57){case'$in':_0x2dfe49='IN\x20?';break;case'$notIn':_0x2dfe49=_0x0356('0x1c');break;case _0x0356('0x1d'):_0x2dfe49='=\x20?';break;case'$ne':_0x2dfe49=_0x0356('0x1e');break;case'$substring':case _0x0356('0x1f'):case'$endsWith':_0x2dfe49=_0x0356('0x20');break;case _0x0356('0x21'):_0x2dfe49=_0x0356('0x22');break;case _0x0356('0xf'):_0x2dfe49='>\x20?';break;case _0x0356('0x10'):_0x2dfe49=_0x0356('0x23');break;case _0x0356('0x24'):_0x2dfe49=_0x0356('0x25');break;case _0x0356('0xd'):_0x2dfe49=_0x0356('0x26');break;}return _0x2dfe49;}function parseValue(_0x12d8e4,_0x1335f7,_0xc6f72a){var _0x3b0d3c={'start':undefined,'end':undefined};switch(_0x1335f7){case _0x0356('0x27'):case _0x0356('0x19'):_0x3b0d3c['start']=_0xc6f72a[_0x0356('0x5')](',');break;case'$substring':_0x3b0d3c[_0x0356('0x28')]='%'+_0xc6f72a+'%';break;case _0x0356('0x1f'):_0x3b0d3c[_0x0356('0x28')]=_0xc6f72a+'%';break;case _0x0356('0x29'):_0x3b0d3c[_0x0356('0x28')]='%'+_0xc6f72a;break;case _0x0356('0xd'):var _0x5670d4=_0xc6f72a[_0x0356('0x5')](',');var _0xc6f72a=_0x5670d4[_0x0356('0x2a')]();var _0x1ac472=_0x5670d4[_0x0356('0x2b')]();if(_0x12d8e4===_0x0356('0xc')){_0xc6f72a=moment(_0xc6f72a)['utcOffset'](0x0,!![])[_0x0356('0x13')]();_0x1ac472=moment(_0x1ac472)[_0x0356('0x2c')](0x0,!![])[_0x0356('0x2d')](0x17,_0x0356('0x2e'))[_0x0356('0x2d')](0x3b,_0x0356('0x2f'))[_0x0356('0x2d')](0x3b,'seconds')[_0x0356('0x13')]();}_0x3b0d3c={'start':_0xc6f72a,'end':_0x1ac472};break;default:_0x3b0d3c['start']=_0xc6f72a;break;}return _0x3b0d3c;}