Built motion from commit (unavailable).|2.5.11
[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 _0x023a=['utcOffset','hours','minutes','seconds','lodash','moment','sqlOperator','startsWith','[$or]','and','replace','[$and]','split','length','indexOf','conditions','push','buildExpression','DATE','operator','$eq','$between','value','includes','$lte','add','days','YYYY-MM-DD','castTo','text','CAST(','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$endsWith','LIKE\x20?','$lt','<\x20?','$gt','<=\x20?','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','shift','pop','format'];(function(_0xdca19e,_0x211c0a){var _0x5e3bb8=function(_0x2b57c4){while(--_0x2b57c4){_0xdca19e['push'](_0xdca19e['shift']());}};_0x5e3bb8(++_0x211c0a);}(_0x023a,0x142));var _0xa023=function(_0x11a3a4,_0x297554){_0x11a3a4=_0x11a3a4-0x0;var _0x46ccee=_0x023a[_0x11a3a4];return _0x46ccee;};'use strict';var _=require(_0xa023('0x0'));var moment=require(_0xa023('0x1'));exports['parseSearch']=function(_0x4fc5c6){var _0x1c2208={'conditions':[]};_0x1c2208[_0xa023('0x2')]=_[_0xa023('0x3')](_0x4fc5c6,_0xa023('0x4'))?'or':_0xa023('0x5');var _0x3b6a2d=_0x4fc5c6[_0xa023('0x6')](_0xa023('0x7'),'')['replace']('[$or]','')[_0xa023('0x8')]('||');for(var _0x54be3d=0x0;_0x54be3d<_0x3b6a2d[_0xa023('0x9')];_0x54be3d++){var _0x4c51e8=_0x3b6a2d[_0x54be3d][_0xa023('0x8')](':=');var _0x252db0=_0x4c51e8[0x0];var _0x1a5183=_0x4c51e8['slice'](0x1);_0x1a5183['forEach'](function(_0x223d43){var _0x5006ff=_0x223d43['split']('[')['shift']();var _0x4f12c6=_0x223d43['match'](/\[(.*?)\]/g);_0x4f12c6['forEach'](function(_0x428751){var _0x5e38c1=_0x428751['split']('[')['filter'](function(_0x53b0c7){return _0x53b0c7[_0xa023('0xa')](']')>-0x1;})['map'](function(_0x40bf16){return _0x40bf16[_0xa023('0x8')](']')[0x0];})[0x0];_0x1c2208[_0xa023('0xb')][_0xa023('0xc')]({'field':_0x252db0,'operator':_0x5006ff,'value':_0x5e38c1});});});}return _0x1c2208;};exports[_0xa023('0xd')]=function(_0xf2f36,_0x3b876a,_0xcaf345){var _0x1ba14f={};if(_0x3b876a===_0xa023('0xe')){if(_0xcaf345[_0xa023('0xf')]===_0xa023('0x10')){_0xcaf345[_0xa023('0xf')]=_0xa023('0x11');_0xcaf345[_0xa023('0x12')]+=','+_0xcaf345[_0xa023('0x12')];}else if(_[_0xa023('0x13')](['$gt',_0xa023('0x14')],_0xcaf345[_0xa023('0xf')])){_0xcaf345[_0xa023('0x12')]=moment(_0xcaf345['value'])[_0xa023('0x15')](0x1,_0xa023('0x16'))['format'](_0xa023('0x17'));}}if(_0xcaf345[_0xa023('0x18')]){_0x3b876a=_0xcaf345[_0xa023('0x18')];_0x1ba14f[_0xa023('0x19')]=_0xa023('0x1a')+_0xf2f36+'.'+_0xcaf345['field']+'\x20AS\x20'+_0xcaf345['castTo']+')\x20'+parseOperator(_0xcaf345[_0xa023('0xf')]);}else{_0x1ba14f[_0xa023('0x19')]=_0xf2f36+'.'+_0xcaf345[_0xa023('0x1b')]+'\x20'+parseOperator(_0xcaf345['operator']);}if(_['includes']([_0xa023('0x1c'),_0xa023('0x1d')],_0xcaf345['operator']))_0x1ba14f[_0xa023('0x19')]='('+_0x1ba14f[_0xa023('0x19')]+_0xa023('0x1e')+_0xf2f36+'.'+_0xcaf345['field']+_0xa023('0x1f');_0x1ba14f[_0xa023('0x12')]=parseValue(_0x3b876a,_0xcaf345[_0xa023('0xf')],_0xcaf345['value']);return _0x1ba14f;};function parseOperator(_0x4ccfb5){var _0x46799d;switch(_0x4ccfb5){case _0xa023('0x20'):_0x46799d='IN\x20?';break;case _0xa023('0x1d'):_0x46799d=_0xa023('0x21');break;case'$eq':_0x46799d=_0xa023('0x22');break;case _0xa023('0x1c'):_0x46799d=_0xa023('0x23');break;case _0xa023('0x24'):case'$startsWith':case _0xa023('0x25'):_0x46799d=_0xa023('0x26');break;case _0xa023('0x27'):_0x46799d=_0xa023('0x28');break;case _0xa023('0x29'):_0x46799d='>\x20?';break;case _0xa023('0x14'):_0x46799d=_0xa023('0x2a');break;case'$gte':_0x46799d=_0xa023('0x2b');break;case'$between':_0x46799d=_0xa023('0x2c');break;}return _0x46799d;}function parseValue(_0x16b045,_0x454610,_0x340c79){var _0xc2cb19={'start':undefined,'end':undefined};switch(_0x454610){case _0xa023('0x20'):case _0xa023('0x1d'):_0xc2cb19[_0xa023('0x2d')]=_0x340c79[_0xa023('0x8')](',');break;case'$substring':_0xc2cb19[_0xa023('0x2d')]='%'+_0x340c79+'%';break;case'$startsWith':_0xc2cb19[_0xa023('0x2d')]=_0x340c79+'%';break;case _0xa023('0x25'):_0xc2cb19['start']='%'+_0x340c79;break;case _0xa023('0x11'):var _0x3f06bc=_0x340c79[_0xa023('0x8')](',');var _0x340c79=_0x3f06bc[_0xa023('0x2e')]();var _0x46f29b=_0x3f06bc[_0xa023('0x2f')]();if(_0x16b045===_0xa023('0xe')){_0x340c79=moment(_0x340c79)['utcOffset'](0x0,!![])[_0xa023('0x30')]();_0x46f29b=moment(_0x46f29b)[_0xa023('0x31')](0x0,!![])[_0xa023('0x15')](0x17,_0xa023('0x32'))[_0xa023('0x15')](0x3b,_0xa023('0x33'))['add'](0x3b,_0xa023('0x34'))['format']();}_0xc2cb19={'start':_0x340c79,'end':_0x46f29b};break;default:_0xc2cb19['start']=_0x340c79;break;}return _0xc2cb19;}