b39358b2531d5c1ae5738d7a9c07d74d25b1ad64
[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 _0x8e84=['start','$startsWith','pop','utcOffset','format','minutes','seconds','moment','parseSearch','startsWith','[$or]','and','replace','[$and]','split','length','forEach','match','indexOf','map','conditions','push','buildExpression','DATE','$eq','operator','value','$lte','add','days','YYYY-MM-DD','text','CAST(','field','castTo','includes','$notIn','\x20IS\x20NULL)','IN\x20?','NOT\x20IN\x20?','$ne','<>\x20?','$substring','$endsWith','$lt','<\x20?','$gt','>\x20?','<=\x20?','$gte','>=\x20?','$between','BETWEEN\x20?\x20AND\x20?'];(function(_0x1cc8fe,_0x105328){var _0x230054=function(_0x1a1b56){while(--_0x1a1b56){_0x1cc8fe['push'](_0x1cc8fe['shift']());}};_0x230054(++_0x105328);}(_0x8e84,0x17a));var _0x48e8=function(_0x2bce20,_0x391615){_0x2bce20=_0x2bce20-0x0;var _0x28409e=_0x8e84[_0x2bce20];return _0x28409e;};'use strict';var _=require('lodash');var moment=require(_0x48e8('0x0'));exports[_0x48e8('0x1')]=function(_0x27c9f6){var _0x52ca57={'conditions':[]};_0x52ca57['sqlOperator']=_[_0x48e8('0x2')](_0x27c9f6,_0x48e8('0x3'))?'or':_0x48e8('0x4');var _0x373d64=_0x27c9f6[_0x48e8('0x5')](_0x48e8('0x6'),'')[_0x48e8('0x5')](_0x48e8('0x3'),'')[_0x48e8('0x7')]('||');for(var _0x21c1b3=0x0;_0x21c1b3<_0x373d64[_0x48e8('0x8')];_0x21c1b3++){var _0xcfacf7=_0x373d64[_0x21c1b3]['split'](':=');var _0x5cf9c1=_0xcfacf7[0x0];var _0xae7fe2=_0xcfacf7['slice'](0x1);_0xae7fe2[_0x48e8('0x9')](function(_0x3d2bb0){var _0x27a7ce=_0x3d2bb0[_0x48e8('0x7')]('[')['shift']();var _0x54480e=_0x3d2bb0[_0x48e8('0xa')](/\[(.*?)\]/g);_0x54480e[_0x48e8('0x9')](function(_0x470665){var _0x5a6aaa=_0x470665[_0x48e8('0x7')]('[')['filter'](function(_0x4fe250){return _0x4fe250[_0x48e8('0xb')](']')>-0x1;})[_0x48e8('0xc')](function(_0x49f4df){return _0x49f4df[_0x48e8('0x7')](']')[0x0];})[0x0];_0x52ca57[_0x48e8('0xd')][_0x48e8('0xe')]({'field':_0x5cf9c1,'operator':_0x27a7ce,'value':_0x5a6aaa});});});}return _0x52ca57;};exports[_0x48e8('0xf')]=function(_0x5a90c8,_0x192370,_0x44d0ff){var _0x444538={};if(_0x192370===_0x48e8('0x10')){if(_0x44d0ff['operator']===_0x48e8('0x11')){_0x44d0ff[_0x48e8('0x12')]='$between';_0x44d0ff['value']+=','+_0x44d0ff[_0x48e8('0x13')];}else if(_['includes'](['$gt',_0x48e8('0x14')],_0x44d0ff[_0x48e8('0x12')])){_0x44d0ff[_0x48e8('0x13')]=moment(_0x44d0ff[_0x48e8('0x13')])[_0x48e8('0x15')](0x1,_0x48e8('0x16'))['format'](_0x48e8('0x17'));}}if(_0x44d0ff['castTo']){_0x192370=_0x44d0ff['castTo'];_0x444538[_0x48e8('0x18')]=_0x48e8('0x19')+_0x5a90c8+'.'+_0x44d0ff[_0x48e8('0x1a')]+'\x20AS\x20'+_0x44d0ff[_0x48e8('0x1b')]+')\x20'+parseOperator(_0x44d0ff['operator']);}else{_0x444538[_0x48e8('0x18')]=_0x5a90c8+'.'+_0x44d0ff[_0x48e8('0x1a')]+'\x20'+parseOperator(_0x44d0ff[_0x48e8('0x12')]);}if(_[_0x48e8('0x1c')](['$ne',_0x48e8('0x1d')],_0x44d0ff['operator']))_0x444538['text']='('+_0x444538[_0x48e8('0x18')]+'\x20OR\x20'+_0x5a90c8+'.'+_0x44d0ff[_0x48e8('0x1a')]+_0x48e8('0x1e');_0x444538[_0x48e8('0x13')]=parseValue(_0x192370,_0x44d0ff['operator'],_0x44d0ff['value']);return _0x444538;};function parseOperator(_0x53684c){var _0x2f922e;switch(_0x53684c){case'$in':_0x2f922e=_0x48e8('0x1f');break;case'$notIn':_0x2f922e=_0x48e8('0x20');break;case _0x48e8('0x11'):_0x2f922e='=\x20?';break;case _0x48e8('0x21'):_0x2f922e=_0x48e8('0x22');break;case _0x48e8('0x23'):case'$startsWith':case _0x48e8('0x24'):_0x2f922e='LIKE\x20?';break;case _0x48e8('0x25'):_0x2f922e=_0x48e8('0x26');break;case _0x48e8('0x27'):_0x2f922e=_0x48e8('0x28');break;case _0x48e8('0x14'):_0x2f922e=_0x48e8('0x29');break;case _0x48e8('0x2a'):_0x2f922e=_0x48e8('0x2b');break;case _0x48e8('0x2c'):_0x2f922e=_0x48e8('0x2d');break;}return _0x2f922e;}function parseValue(_0x417ed5,_0x2de7d3,_0x6c088f){var _0x5b22e9={'start':undefined,'end':undefined};switch(_0x2de7d3){case'$in':case _0x48e8('0x1d'):_0x5b22e9[_0x48e8('0x2e')]=_0x6c088f[_0x48e8('0x7')](',');break;case _0x48e8('0x23'):_0x5b22e9[_0x48e8('0x2e')]='%'+_0x6c088f+'%';break;case _0x48e8('0x2f'):_0x5b22e9[_0x48e8('0x2e')]=_0x6c088f+'%';break;case _0x48e8('0x24'):_0x5b22e9[_0x48e8('0x2e')]='%'+_0x6c088f;break;case'$between':var _0x397d42=_0x6c088f[_0x48e8('0x7')](',');var _0x6c088f=_0x397d42['shift']();var _0x1c5dfe=_0x397d42[_0x48e8('0x30')]();if(_0x417ed5===_0x48e8('0x10')){_0x6c088f=moment(_0x6c088f)[_0x48e8('0x31')](0x0,!![])[_0x48e8('0x32')]();_0x1c5dfe=moment(_0x1c5dfe)['utcOffset'](0x0,!![])[_0x48e8('0x15')](0x17,'hours')[_0x48e8('0x15')](0x3b,_0x48e8('0x33'))[_0x48e8('0x15')](0x3b,_0x48e8('0x34'))[_0x48e8('0x32')]();}_0x5b22e9={'start':_0x6c088f,'end':_0x1c5dfe};break;default:_0x5b22e9[_0x48e8('0x2e')]=_0x6c088f;break;}return _0x5b22e9;}