Built motion from commit (unavailable).|2.5.8
[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 _0x0462=['format','utcOffset','seconds','lodash','moment','sqlOperator','startsWith','[$or]','and','replace','[$and]','slice','shift','match','forEach','filter','map','split','conditions','push','DATE','operator','$eq','$between','value','includes','$gt','$lte','add','days','YYYY-MM-DD','castTo','text','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','$in','start','pop'];(function(_0x556e06,_0x52a157){var _0x1f54b3=function(_0x33c19d){while(--_0x33c19d){_0x556e06['push'](_0x556e06['shift']());}};_0x1f54b3(++_0x52a157);}(_0x0462,0xa5));var _0x2046=function(_0x595f88,_0x142a8c){_0x595f88=_0x595f88-0x0;var _0x43be2e=_0x0462[_0x595f88];return _0x43be2e;};'use strict';var _=require(_0x2046('0x0'));var moment=require(_0x2046('0x1'));exports['parseSearch']=function(_0x131a11){var _0x35f0f7={'conditions':[]};_0x35f0f7[_0x2046('0x2')]=_[_0x2046('0x3')](_0x131a11,_0x2046('0x4'))?'or':_0x2046('0x5');var _0x1e5ee5=_0x131a11[_0x2046('0x6')](_0x2046('0x7'),'')[_0x2046('0x6')]('[$or]','')['split']('||');for(var _0x546b39=0x0;_0x546b39<_0x1e5ee5['length'];_0x546b39++){var _0x4688aa=_0x1e5ee5[_0x546b39]['split'](':=');var _0x526d61=_0x4688aa[0x0];var _0x413c8e=_0x4688aa[_0x2046('0x8')](0x1);_0x413c8e['forEach'](function(_0x3d7415){var _0x709662=_0x3d7415['split']('[')[_0x2046('0x9')]();var _0x4a1efb=_0x3d7415[_0x2046('0xa')](/\[(.*?)\]/g);_0x4a1efb[_0x2046('0xb')](function(_0x2054de){var _0x3b76e7=_0x2054de['split']('[')[_0x2046('0xc')](function(_0x165c86){return _0x165c86['indexOf'](']')>-0x1;})[_0x2046('0xd')](function(_0x1150fb){return _0x1150fb[_0x2046('0xe')](']')[0x0];})[0x0];_0x35f0f7[_0x2046('0xf')][_0x2046('0x10')]({'field':_0x526d61,'operator':_0x709662,'value':_0x3b76e7});});});}return _0x35f0f7;};exports['buildExpression']=function(_0x4030ee,_0x196bba,_0x2618a9){var _0x4ec461={};if(_0x196bba===_0x2046('0x11')){if(_0x2618a9[_0x2046('0x12')]===_0x2046('0x13')){_0x2618a9['operator']=_0x2046('0x14');_0x2618a9[_0x2046('0x15')]+=','+_0x2618a9['value'];}else if(_[_0x2046('0x16')]([_0x2046('0x17'),_0x2046('0x18')],_0x2618a9[_0x2046('0x12')])){_0x2618a9[_0x2046('0x15')]=moment(_0x2618a9[_0x2046('0x15')])[_0x2046('0x19')](0x1,_0x2046('0x1a'))['format'](_0x2046('0x1b'));}}if(_0x2618a9['castTo']){_0x196bba=_0x2618a9[_0x2046('0x1c')];_0x4ec461[_0x2046('0x1d')]='CAST('+_0x4030ee+'.'+_0x2618a9[_0x2046('0x1e')]+'\x20AS\x20'+_0x2618a9[_0x2046('0x1c')]+')\x20'+parseOperator(_0x2618a9[_0x2046('0x12')]);}else{_0x4ec461[_0x2046('0x1d')]=_0x4030ee+'.'+_0x2618a9['field']+'\x20'+parseOperator(_0x2618a9[_0x2046('0x12')]);}if(_[_0x2046('0x16')]([_0x2046('0x1f'),_0x2046('0x20')],_0x2618a9['operator']))_0x4ec461[_0x2046('0x1d')]='('+_0x4ec461[_0x2046('0x1d')]+_0x2046('0x21')+_0x4030ee+'.'+_0x2618a9[_0x2046('0x1e')]+_0x2046('0x22');_0x4ec461['value']=parseValue(_0x196bba,_0x2618a9[_0x2046('0x12')],_0x2618a9[_0x2046('0x15')]);return _0x4ec461;};function parseOperator(_0x5edc7f){var _0x23b809;switch(_0x5edc7f){case'$in':_0x23b809='IN\x20?';break;case'$notIn':_0x23b809=_0x2046('0x23');break;case'$eq':_0x23b809=_0x2046('0x24');break;case _0x2046('0x1f'):_0x23b809=_0x2046('0x25');break;case _0x2046('0x26'):case _0x2046('0x27'):case _0x2046('0x28'):_0x23b809=_0x2046('0x29');break;case'$lt':_0x23b809=_0x2046('0x2a');break;case'$gt':_0x23b809=_0x2046('0x2b');break;case _0x2046('0x18'):_0x23b809=_0x2046('0x2c');break;case _0x2046('0x2d'):_0x23b809=_0x2046('0x2e');break;case _0x2046('0x14'):_0x23b809=_0x2046('0x2f');break;}return _0x23b809;}function parseValue(_0x32f4c9,_0x51c669,_0x5b8c46){var _0x2dd0b5={'start':undefined,'end':undefined};switch(_0x51c669){case _0x2046('0x30'):case'$notIn':_0x2dd0b5[_0x2046('0x31')]=_0x5b8c46[_0x2046('0xe')](',');break;case _0x2046('0x26'):_0x2dd0b5[_0x2046('0x31')]='%'+_0x5b8c46+'%';break;case _0x2046('0x27'):_0x2dd0b5[_0x2046('0x31')]=_0x5b8c46+'%';break;case _0x2046('0x28'):_0x2dd0b5[_0x2046('0x31')]='%'+_0x5b8c46;break;case _0x2046('0x14'):var _0x5e8e91=_0x5b8c46[_0x2046('0xe')](',');var _0x5b8c46=_0x5e8e91[_0x2046('0x9')]();var _0x482a00=_0x5e8e91[_0x2046('0x32')]();if(_0x32f4c9===_0x2046('0x11')){_0x5b8c46=moment(_0x5b8c46)['utcOffset'](0x0,!![])[_0x2046('0x33')]();_0x482a00=moment(_0x482a00)[_0x2046('0x34')](0x0,!![])[_0x2046('0x19')](0x17,'hours')['add'](0x3b,'minutes')[_0x2046('0x19')](0x3b,_0x2046('0x35'))[_0x2046('0x33')]();}_0x2dd0b5={'start':_0x5b8c46,'end':_0x482a00};break;default:_0x2dd0b5[_0x2046('0x31')]=_0x5b8c46;break;}return _0x2dd0b5;}