Built motion from commit c738b9ac.|2.6.25
[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 _0x7f94=['split','length','slice','forEach','shift','match','filter','push','DATE','operator','$eq','$between','includes','$gt','value','add','days','castTo','text','CAST(','field','\x20AS\x20','$notIn','\x20OR\x20','$in','NOT\x20IN\x20?','=\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?','$lte','<=\x20?','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','pop','utcOffset','format','hours','minutes','seconds','lodash','parseSearch','startsWith','[$or]','and','replace'];(function(_0x2b90dc,_0x10b832){var _0x4794a6=function(_0x3720ca){while(--_0x3720ca){_0x2b90dc['push'](_0x2b90dc['shift']());}};_0x4794a6(++_0x10b832);}(_0x7f94,0x12c));var _0x47f9=function(_0x3bbe07,_0x498d45){_0x3bbe07=_0x3bbe07-0x0;var _0x14c9d=_0x7f94[_0x3bbe07];return _0x14c9d;};'use strict';var _=require(_0x47f9('0x0'));var moment=require('moment');exports[_0x47f9('0x1')]=function(_0x10b4d5){var _0x45c567={'conditions':[]};_0x45c567['sqlOperator']=_[_0x47f9('0x2')](_0x10b4d5,_0x47f9('0x3'))?'or':_0x47f9('0x4');var _0x8397ba=_0x10b4d5['replace']('[$and]','')[_0x47f9('0x5')](_0x47f9('0x3'),'')[_0x47f9('0x6')]('||');for(var _0x481271=0x0;_0x481271<_0x8397ba[_0x47f9('0x7')];_0x481271++){var _0x139195=_0x8397ba[_0x481271]['split'](':=');var _0x9a5429=_0x139195[0x0];var _0x1b81ff=_0x139195[_0x47f9('0x8')](0x1);_0x1b81ff[_0x47f9('0x9')](function(_0x57d0cb){var _0x51f92f=_0x57d0cb[_0x47f9('0x6')]('[')[_0x47f9('0xa')]();var _0xa02e56=_0x57d0cb[_0x47f9('0xb')](/\[(.*?)\]/g);_0xa02e56[_0x47f9('0x9')](function(_0x44ec24){var _0x2eee9d=_0x44ec24[_0x47f9('0x6')]('[')[_0x47f9('0xc')](function(_0x3fecaa){return _0x3fecaa['indexOf'](']')>-0x1;})['map'](function(_0x4842e1){return _0x4842e1[_0x47f9('0x6')](']')[0x0];})[0x0];_0x45c567['conditions'][_0x47f9('0xd')]({'field':_0x9a5429,'operator':_0x51f92f,'value':_0x2eee9d});});});}return _0x45c567;};exports['buildExpression']=function(_0x225d8b,_0x43d1c8,_0x2807b6){var _0xd819a6={};if(_0x43d1c8===_0x47f9('0xe')){if(_0x2807b6[_0x47f9('0xf')]===_0x47f9('0x10')){_0x2807b6[_0x47f9('0xf')]=_0x47f9('0x11');_0x2807b6['value']+=','+_0x2807b6['value'];}else if(_[_0x47f9('0x12')]([_0x47f9('0x13'),'$lte'],_0x2807b6[_0x47f9('0xf')])){_0x2807b6[_0x47f9('0x14')]=moment(_0x2807b6[_0x47f9('0x14')])[_0x47f9('0x15')](0x1,_0x47f9('0x16'))['format']('YYYY-MM-DD');}}if(_0x2807b6[_0x47f9('0x17')]){_0x43d1c8=_0x2807b6[_0x47f9('0x17')];_0xd819a6[_0x47f9('0x18')]=_0x47f9('0x19')+_0x225d8b+'.'+_0x2807b6[_0x47f9('0x1a')]+_0x47f9('0x1b')+_0x2807b6[_0x47f9('0x17')]+')\x20'+parseOperator(_0x2807b6['operator']);}else{_0xd819a6['text']=_0x225d8b+'.'+_0x2807b6[_0x47f9('0x1a')]+'\x20'+parseOperator(_0x2807b6[_0x47f9('0xf')]);}if(_['includes'](['$ne',_0x47f9('0x1c')],_0x2807b6['operator']))_0xd819a6[_0x47f9('0x18')]='('+_0xd819a6['text']+_0x47f9('0x1d')+_0x225d8b+'.'+_0x2807b6[_0x47f9('0x1a')]+'\x20IS\x20NULL)';_0xd819a6['value']=parseValue(_0x43d1c8,_0x2807b6[_0x47f9('0xf')],_0x2807b6[_0x47f9('0x14')]);return _0xd819a6;};function parseOperator(_0x27c8f7){var _0x326cc8;switch(_0x27c8f7){case _0x47f9('0x1e'):_0x326cc8='IN\x20?';break;case _0x47f9('0x1c'):_0x326cc8=_0x47f9('0x1f');break;case _0x47f9('0x10'):_0x326cc8=_0x47f9('0x20');break;case'$ne':_0x326cc8='<>\x20?';break;case _0x47f9('0x21'):case _0x47f9('0x22'):case _0x47f9('0x23'):_0x326cc8=_0x47f9('0x24');break;case _0x47f9('0x25'):_0x326cc8=_0x47f9('0x26');break;case _0x47f9('0x13'):_0x326cc8=_0x47f9('0x27');break;case _0x47f9('0x28'):_0x326cc8=_0x47f9('0x29');break;case'$gte':_0x326cc8=_0x47f9('0x2a');break;case _0x47f9('0x11'):_0x326cc8=_0x47f9('0x2b');break;}return _0x326cc8;}function parseValue(_0x4d4006,_0x2fb657,_0x17809a){var _0x4e1dca={'start':undefined,'end':undefined};switch(_0x2fb657){case _0x47f9('0x1e'):case'$notIn':_0x4e1dca[_0x47f9('0x2c')]=_0x17809a[_0x47f9('0x6')](',');break;case _0x47f9('0x21'):_0x4e1dca[_0x47f9('0x2c')]='%'+_0x17809a+'%';break;case _0x47f9('0x22'):_0x4e1dca[_0x47f9('0x2c')]=_0x17809a+'%';break;case _0x47f9('0x23'):_0x4e1dca[_0x47f9('0x2c')]='%'+_0x17809a;break;case _0x47f9('0x11'):var _0xd88ebc=_0x17809a['split'](',');var _0x17809a=_0xd88ebc[_0x47f9('0xa')]();var _0x25e3ab=_0xd88ebc[_0x47f9('0x2d')]();if(_0x4d4006===_0x47f9('0xe')){_0x17809a=moment(_0x17809a)[_0x47f9('0x2e')](0x0,!![])[_0x47f9('0x2f')]();_0x25e3ab=moment(_0x25e3ab)[_0x47f9('0x2e')](0x0,!![])[_0x47f9('0x15')](0x17,_0x47f9('0x30'))[_0x47f9('0x15')](0x3b,_0x47f9('0x31'))[_0x47f9('0x15')](0x3b,_0x47f9('0x32'))['format']();}_0x4e1dca={'start':_0x17809a,'end':_0x25e3ab};break;default:_0x4e1dca[_0x47f9('0x2c')]=_0x17809a;break;}return _0x4e1dca;}