Built motion from commit (unavailable).|2.5.21
[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 _0x1542=['conditions','buildExpression','operator','$between','value','includes','add','days','format','YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','$in','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','$gt','>\x20?','$lte','<=\x20?','$gte','>=\x20?','start','shift','pop','DATE','utcOffset','hours','minutes','lodash','moment','parseSearch','sqlOperator','[$or]','and','replace','[$and]','split','length','slice','forEach','match','filter','indexOf'];(function(_0x46f925,_0x40dece){var _0x43feab=function(_0x89db2c){while(--_0x89db2c){_0x46f925['push'](_0x46f925['shift']());}};_0x43feab(++_0x40dece);}(_0x1542,0x99));var _0x2154=function(_0x28c0ac,_0x4b016f){_0x28c0ac=_0x28c0ac-0x0;var _0x4906fa=_0x1542[_0x28c0ac];return _0x4906fa;};'use strict';var _=require(_0x2154('0x0'));var moment=require(_0x2154('0x1'));exports[_0x2154('0x2')]=function(_0x31c3fd){var _0x870d21={'conditions':[]};_0x870d21[_0x2154('0x3')]=_['startsWith'](_0x31c3fd,_0x2154('0x4'))?'or':_0x2154('0x5');var _0x5987fb=_0x31c3fd[_0x2154('0x6')](_0x2154('0x7'),'')[_0x2154('0x6')]('[$or]','')[_0x2154('0x8')]('||');for(var _0x37ed0a=0x0;_0x37ed0a<_0x5987fb[_0x2154('0x9')];_0x37ed0a++){var _0x306f64=_0x5987fb[_0x37ed0a]['split'](':=');var _0x3f1a2a=_0x306f64[0x0];var _0x2d9405=_0x306f64[_0x2154('0xa')](0x1);_0x2d9405[_0x2154('0xb')](function(_0x24f16b){var _0xbf8015=_0x24f16b[_0x2154('0x8')]('[')['shift']();var _0x4bdc12=_0x24f16b[_0x2154('0xc')](/\[(.*?)\]/g);_0x4bdc12['forEach'](function(_0x25297d){var _0x5d4af1=_0x25297d[_0x2154('0x8')]('[')[_0x2154('0xd')](function(_0x38b9b5){return _0x38b9b5[_0x2154('0xe')](']')>-0x1;})['map'](function(_0x3f181e){return _0x3f181e[_0x2154('0x8')](']')[0x0];})[0x0];_0x870d21[_0x2154('0xf')]['push']({'field':_0x3f1a2a,'operator':_0xbf8015,'value':_0x5d4af1});});});}return _0x870d21;};exports[_0x2154('0x10')]=function(_0x297da5,_0x579d10,_0x8963cf){var _0x17e949={};if(_0x579d10==='DATE'){if(_0x8963cf[_0x2154('0x11')]==='$eq'){_0x8963cf['operator']=_0x2154('0x12');_0x8963cf[_0x2154('0x13')]+=','+_0x8963cf[_0x2154('0x13')];}else if(_[_0x2154('0x14')](['$gt','$lte'],_0x8963cf[_0x2154('0x11')])){_0x8963cf[_0x2154('0x13')]=moment(_0x8963cf[_0x2154('0x13')])[_0x2154('0x15')](0x1,_0x2154('0x16'))[_0x2154('0x17')](_0x2154('0x18'));}}if(_0x8963cf['castTo']){_0x579d10=_0x8963cf[_0x2154('0x19')];_0x17e949[_0x2154('0x1a')]=_0x2154('0x1b')+_0x297da5+'.'+_0x8963cf[_0x2154('0x1c')]+_0x2154('0x1d')+_0x8963cf['castTo']+')\x20'+parseOperator(_0x8963cf[_0x2154('0x11')]);}else{_0x17e949[_0x2154('0x1a')]=_0x297da5+'.'+_0x8963cf[_0x2154('0x1c')]+'\x20'+parseOperator(_0x8963cf['operator']);}if(_['includes']([_0x2154('0x1e'),_0x2154('0x1f')],_0x8963cf[_0x2154('0x11')]))_0x17e949[_0x2154('0x1a')]='('+_0x17e949[_0x2154('0x1a')]+_0x2154('0x20')+_0x297da5+'.'+_0x8963cf[_0x2154('0x1c')]+'\x20IS\x20NULL)';_0x17e949[_0x2154('0x13')]=parseValue(_0x579d10,_0x8963cf[_0x2154('0x11')],_0x8963cf[_0x2154('0x13')]);return _0x17e949;};function parseOperator(_0x523f4a){var _0xb2cbd7;switch(_0x523f4a){case _0x2154('0x21'):_0xb2cbd7='IN\x20?';break;case _0x2154('0x1f'):_0xb2cbd7=_0x2154('0x22');break;case'$eq':_0xb2cbd7=_0x2154('0x23');break;case _0x2154('0x1e'):_0xb2cbd7=_0x2154('0x24');break;case _0x2154('0x25'):case _0x2154('0x26'):case _0x2154('0x27'):_0xb2cbd7=_0x2154('0x28');break;case _0x2154('0x29'):_0xb2cbd7=_0x2154('0x2a');break;case _0x2154('0x2b'):_0xb2cbd7=_0x2154('0x2c');break;case _0x2154('0x2d'):_0xb2cbd7=_0x2154('0x2e');break;case _0x2154('0x2f'):_0xb2cbd7=_0x2154('0x30');break;case _0x2154('0x12'):_0xb2cbd7='BETWEEN\x20?\x20AND\x20?';break;}return _0xb2cbd7;}function parseValue(_0x239fa1,_0x47a816,_0xb0c863){var _0x414566={'start':undefined,'end':undefined};switch(_0x47a816){case _0x2154('0x21'):case'$notIn':_0x414566[_0x2154('0x31')]=_0xb0c863[_0x2154('0x8')](',');break;case'$substring':_0x414566[_0x2154('0x31')]='%'+_0xb0c863+'%';break;case _0x2154('0x26'):_0x414566[_0x2154('0x31')]=_0xb0c863+'%';break;case _0x2154('0x27'):_0x414566[_0x2154('0x31')]='%'+_0xb0c863;break;case'$between':var _0x1aeb00=_0xb0c863[_0x2154('0x8')](',');var _0xb0c863=_0x1aeb00[_0x2154('0x32')]();var _0x7a4ed2=_0x1aeb00[_0x2154('0x33')]();if(_0x239fa1===_0x2154('0x34')){_0xb0c863=moment(_0xb0c863)[_0x2154('0x35')](0x0,!![])[_0x2154('0x17')]();_0x7a4ed2=moment(_0x7a4ed2)[_0x2154('0x35')](0x0,!![])[_0x2154('0x15')](0x17,_0x2154('0x36'))[_0x2154('0x15')](0x3b,_0x2154('0x37'))['add'](0x3b,'seconds')[_0x2154('0x17')]();}_0x414566={'start':_0xb0c863,'end':_0x7a4ed2};break;default:_0x414566[_0x2154('0x31')]=_0xb0c863;break;}return _0x414566;}