Built motion from commit (unavailable).|2.5.29
[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 _0x8fb0=['operator','$between','value','$lte','add','YYYY-MM-DD','castTo','CAST(','field','\x20AS\x20','text','includes','$ne','$notIn','\x20OR\x20','IN\x20?','$eq','<>\x20?','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','$in','start','$substring','pop','DATE','utcOffset','format','hours','minutes','seconds','lodash','moment','startsWith','[$or]','replace','[$and]','split','shift','filter','indexOf','conditions','push','buildExpression'];(function(_0x2cce47,_0x2361b8){var _0x39d4b1=function(_0xdc3d2c){while(--_0xdc3d2c){_0x2cce47['push'](_0x2cce47['shift']());}};_0x39d4b1(++_0x2361b8);}(_0x8fb0,0x151));var _0x08fb=function(_0x11c573,_0x9e7c6e){_0x11c573=_0x11c573-0x0;var _0x6b72de=_0x8fb0[_0x11c573];return _0x6b72de;};'use strict';var _=require(_0x08fb('0x0'));var moment=require(_0x08fb('0x1'));exports['parseSearch']=function(_0x3c5cb6){var _0x41633b={'conditions':[]};_0x41633b['sqlOperator']=_[_0x08fb('0x2')](_0x3c5cb6,_0x08fb('0x3'))?'or':'and';var _0x29562d=_0x3c5cb6[_0x08fb('0x4')](_0x08fb('0x5'),'')[_0x08fb('0x4')](_0x08fb('0x3'),'')[_0x08fb('0x6')]('||');for(var _0x111a57=0x0;_0x111a57<_0x29562d['length'];_0x111a57++){var _0xaa0f49=_0x29562d[_0x111a57]['split'](':=');var _0x4325e1=_0xaa0f49[0x0];var _0x64ac05=_0xaa0f49['slice'](0x1);_0x64ac05['forEach'](function(_0x37c8b6){var _0x3d8171=_0x37c8b6[_0x08fb('0x6')]('[')[_0x08fb('0x7')]();var _0x3a351d=_0x37c8b6['match'](/\[(.*?)\]/g);_0x3a351d['forEach'](function(_0x44de83){var _0x923776=_0x44de83[_0x08fb('0x6')]('[')[_0x08fb('0x8')](function(_0x4cb633){return _0x4cb633[_0x08fb('0x9')](']')>-0x1;})['map'](function(_0x1cfb17){return _0x1cfb17['split'](']')[0x0];})[0x0];_0x41633b[_0x08fb('0xa')][_0x08fb('0xb')]({'field':_0x4325e1,'operator':_0x3d8171,'value':_0x923776});});});}return _0x41633b;};exports[_0x08fb('0xc')]=function(_0x18e5fe,_0x116251,_0x599cb2){var _0x2dfc98={};if(_0x116251==='DATE'){if(_0x599cb2[_0x08fb('0xd')]==='$eq'){_0x599cb2['operator']=_0x08fb('0xe');_0x599cb2[_0x08fb('0xf')]+=','+_0x599cb2[_0x08fb('0xf')];}else if(_['includes'](['$gt',_0x08fb('0x10')],_0x599cb2['operator'])){_0x599cb2[_0x08fb('0xf')]=moment(_0x599cb2['value'])[_0x08fb('0x11')](0x1,'days')['format'](_0x08fb('0x12'));}}if(_0x599cb2[_0x08fb('0x13')]){_0x116251=_0x599cb2[_0x08fb('0x13')];_0x2dfc98['text']=_0x08fb('0x14')+_0x18e5fe+'.'+_0x599cb2[_0x08fb('0x15')]+_0x08fb('0x16')+_0x599cb2[_0x08fb('0x13')]+')\x20'+parseOperator(_0x599cb2[_0x08fb('0xd')]);}else{_0x2dfc98[_0x08fb('0x17')]=_0x18e5fe+'.'+_0x599cb2['field']+'\x20'+parseOperator(_0x599cb2[_0x08fb('0xd')]);}if(_[_0x08fb('0x18')]([_0x08fb('0x19'),_0x08fb('0x1a')],_0x599cb2[_0x08fb('0xd')]))_0x2dfc98[_0x08fb('0x17')]='('+_0x2dfc98['text']+_0x08fb('0x1b')+_0x18e5fe+'.'+_0x599cb2[_0x08fb('0x15')]+'\x20IS\x20NULL)';_0x2dfc98[_0x08fb('0xf')]=parseValue(_0x116251,_0x599cb2[_0x08fb('0xd')],_0x599cb2[_0x08fb('0xf')]);return _0x2dfc98;};function parseOperator(_0x1594e7){var _0x191747;switch(_0x1594e7){case'$in':_0x191747=_0x08fb('0x1c');break;case _0x08fb('0x1a'):_0x191747='NOT\x20IN\x20?';break;case _0x08fb('0x1d'):_0x191747='=\x20?';break;case'$ne':_0x191747=_0x08fb('0x1e');break;case'$substring':case _0x08fb('0x1f'):case _0x08fb('0x20'):_0x191747=_0x08fb('0x21');break;case'$lt':_0x191747=_0x08fb('0x22');break;case'$gt':_0x191747=_0x08fb('0x23');break;case _0x08fb('0x10'):_0x191747=_0x08fb('0x24');break;case _0x08fb('0x25'):_0x191747=_0x08fb('0x26');break;case _0x08fb('0xe'):_0x191747=_0x08fb('0x27');break;}return _0x191747;}function parseValue(_0x3953c7,_0x4464e7,_0x563cb9){var _0x43e0c7={'start':undefined,'end':undefined};switch(_0x4464e7){case _0x08fb('0x28'):case _0x08fb('0x1a'):_0x43e0c7[_0x08fb('0x29')]=_0x563cb9[_0x08fb('0x6')](',');break;case _0x08fb('0x2a'):_0x43e0c7[_0x08fb('0x29')]='%'+_0x563cb9+'%';break;case _0x08fb('0x1f'):_0x43e0c7[_0x08fb('0x29')]=_0x563cb9+'%';break;case _0x08fb('0x20'):_0x43e0c7[_0x08fb('0x29')]='%'+_0x563cb9;break;case _0x08fb('0xe'):var _0x46db8b=_0x563cb9[_0x08fb('0x6')](',');var _0x563cb9=_0x46db8b[_0x08fb('0x7')]();var _0x26c489=_0x46db8b[_0x08fb('0x2b')]();if(_0x3953c7===_0x08fb('0x2c')){_0x563cb9=moment(_0x563cb9)[_0x08fb('0x2d')](0x0,!![])[_0x08fb('0x2e')]();_0x26c489=moment(_0x26c489)[_0x08fb('0x2d')](0x0,!![])[_0x08fb('0x11')](0x17,_0x08fb('0x2f'))[_0x08fb('0x11')](0x3b,_0x08fb('0x30'))['add'](0x3b,_0x08fb('0x31'))['format']();}_0x43e0c7={'start':_0x563cb9,'end':_0x26c489};break;default:_0x43e0c7[_0x08fb('0x29')]=_0x563cb9;break;}return _0x43e0c7;}