Built motion from commit e02f907f.|2.6.14
[motion2.git] / server / components / parsers / advancedSearch.js
index bce823a..1447d91 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x810a=['$in','$eq','=\x20?','<>\x20?','$substring','LIKE\x20?','$lt','>\x20?','$lte','$gte','>=\x20?','$startsWith','start','utcOffset','hours','minutes','seconds','lodash','moment','parseSearch','sqlOperator','startsWith','[$or]','and','replace','[$and]','length','slice','forEach','split','shift','match','filter','indexOf','push','buildExpression','DATE','$between','includes','$gt','operator','value','add','days','YYYY-MM-DD','castTo','text','CAST(','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)'];(function(_0x2a6800,_0x227a4a){var _0x444df9=function(_0x45eb2f){while(--_0x45eb2f){_0x2a6800['push'](_0x2a6800['shift']());}};_0x444df9(++_0x227a4a);}(_0x810a,0x14f));var _0xa810=function(_0x22385b,_0x5383f8){_0x22385b=_0x22385b-0x0;var _0x487ceb=_0x810a[_0x22385b];return _0x487ceb;};'use strict';var _=require(_0xa810('0x0'));var moment=require(_0xa810('0x1'));exports[_0xa810('0x2')]=function(_0xc2436e){var _0x205f46={'conditions':[]};_0x205f46[_0xa810('0x3')]=_[_0xa810('0x4')](_0xc2436e,_0xa810('0x5'))?'or':_0xa810('0x6');var _0x469691=_0xc2436e[_0xa810('0x7')](_0xa810('0x8'),'')[_0xa810('0x7')](_0xa810('0x5'),'')['split']('||');for(var _0x567391=0x0;_0x567391<_0x469691[_0xa810('0x9')];_0x567391++){var _0x4de1c4=_0x469691[_0x567391]['split'](':=');var _0x179502=_0x4de1c4[0x0];var _0x5a8155=_0x4de1c4[_0xa810('0xa')](0x1);_0x5a8155[_0xa810('0xb')](function(_0xf6ef40){var _0xd3e1c6=_0xf6ef40[_0xa810('0xc')]('[')[_0xa810('0xd')]();var _0x5c236b=_0xf6ef40[_0xa810('0xe')](/\[(.*?)\]/g);_0x5c236b[_0xa810('0xb')](function(_0x1e7a83){var _0x3fd19a=_0x1e7a83[_0xa810('0xc')]('[')[_0xa810('0xf')](function(_0x58b885){return _0x58b885[_0xa810('0x10')](']')>-0x1;})['map'](function(_0x1f1a74){return _0x1f1a74[_0xa810('0xc')](']')[0x0];})[0x0];_0x205f46['conditions'][_0xa810('0x11')]({'field':_0x179502,'operator':_0xd3e1c6,'value':_0x3fd19a});});});}return _0x205f46;};exports[_0xa810('0x12')]=function(_0x52e8bb,_0x2c8a41,_0x2b4549){var _0x497d5b={};if(_0x2c8a41===_0xa810('0x13')){if(_0x2b4549['operator']==='$eq'){_0x2b4549['operator']=_0xa810('0x14');_0x2b4549['value']+=','+_0x2b4549['value'];}else if(_[_0xa810('0x15')]([_0xa810('0x16'),'$lte'],_0x2b4549[_0xa810('0x17')])){_0x2b4549['value']=moment(_0x2b4549[_0xa810('0x18')])[_0xa810('0x19')](0x1,_0xa810('0x1a'))['format'](_0xa810('0x1b'));}}if(_0x2b4549['castTo']){_0x2c8a41=_0x2b4549[_0xa810('0x1c')];_0x497d5b[_0xa810('0x1d')]=_0xa810('0x1e')+_0x52e8bb+'.'+_0x2b4549[_0xa810('0x1f')]+'\x20AS\x20'+_0x2b4549['castTo']+')\x20'+parseOperator(_0x2b4549[_0xa810('0x17')]);}else{_0x497d5b[_0xa810('0x1d')]=_0x52e8bb+'.'+_0x2b4549['field']+'\x20'+parseOperator(_0x2b4549['operator']);}if(_['includes']([_0xa810('0x20'),_0xa810('0x21')],_0x2b4549[_0xa810('0x17')]))_0x497d5b[_0xa810('0x1d')]='('+_0x497d5b[_0xa810('0x1d')]+_0xa810('0x22')+_0x52e8bb+'.'+_0x2b4549[_0xa810('0x1f')]+_0xa810('0x23');_0x497d5b['value']=parseValue(_0x2c8a41,_0x2b4549['operator'],_0x2b4549[_0xa810('0x18')]);return _0x497d5b;};function parseOperator(_0x1d2452){var _0x4a6ee1;switch(_0x1d2452){case _0xa810('0x24'):_0x4a6ee1='IN\x20?';break;case _0xa810('0x21'):_0x4a6ee1='NOT\x20IN\x20?';break;case _0xa810('0x25'):_0x4a6ee1=_0xa810('0x26');break;case _0xa810('0x20'):_0x4a6ee1=_0xa810('0x27');break;case _0xa810('0x28'):case'$startsWith':case'$endsWith':_0x4a6ee1=_0xa810('0x29');break;case _0xa810('0x2a'):_0x4a6ee1='<\x20?';break;case _0xa810('0x16'):_0x4a6ee1=_0xa810('0x2b');break;case _0xa810('0x2c'):_0x4a6ee1='<=\x20?';break;case _0xa810('0x2d'):_0x4a6ee1=_0xa810('0x2e');break;case'$between':_0x4a6ee1='BETWEEN\x20?\x20AND\x20?';break;}return _0x4a6ee1;}function parseValue(_0x31cf7d,_0x2cf8ce,_0x20acbd){var _0x7a7ec5={'start':undefined,'end':undefined};switch(_0x2cf8ce){case _0xa810('0x24'):case _0xa810('0x21'):_0x7a7ec5['start']=_0x20acbd['split'](',');break;case'$substring':_0x7a7ec5['start']='%'+_0x20acbd+'%';break;case _0xa810('0x2f'):_0x7a7ec5[_0xa810('0x30')]=_0x20acbd+'%';break;case'$endsWith':_0x7a7ec5[_0xa810('0x30')]='%'+_0x20acbd;break;case _0xa810('0x14'):var _0xd2e291=_0x20acbd[_0xa810('0xc')](',');var _0x20acbd=_0xd2e291[_0xa810('0xd')]();var _0x4a57c2=_0xd2e291['pop']();if(_0x31cf7d===_0xa810('0x13')){_0x20acbd=moment(_0x20acbd)['utcOffset'](0x0,!![])['format']();_0x4a57c2=moment(_0x4a57c2)[_0xa810('0x31')](0x0,!![])['add'](0x17,_0xa810('0x32'))[_0xa810('0x19')](0x3b,_0xa810('0x33'))[_0xa810('0x19')](0x3b,_0xa810('0x34'))['format']();}_0x7a7ec5={'start':_0x20acbd,'end':_0x4a57c2};break;default:_0x7a7ec5['start']=_0x20acbd;break;}return _0x7a7ec5;}
\ No newline at end of file
+var _0x3520=['YYYY-MM-DD','castTo','text','CAST(','field','$ne','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','$notIn','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','pop','utcOffset','hours','minutes','seconds','moment','sqlOperator','and','replace','[$and]','[$or]','split','length','slice','forEach','shift','match','filter','indexOf','map','buildExpression','DATE','operator','$eq','$between','value','includes','$gt','$lte','add','days','format'];(function(_0x4d5cfd,_0x5b5c6c){var _0x442f17=function(_0x32a375){while(--_0x32a375){_0x4d5cfd['push'](_0x4d5cfd['shift']());}};_0x442f17(++_0x5b5c6c);}(_0x3520,0x166));var _0x0352=function(_0x28405b,_0x583b9f){_0x28405b=_0x28405b-0x0;var _0x47a902=_0x3520[_0x28405b];return _0x47a902;};'use strict';var _=require('lodash');var moment=require(_0x0352('0x0'));exports['parseSearch']=function(_0x22b811){var _0x3fefa8={'conditions':[]};_0x3fefa8[_0x0352('0x1')]=_['startsWith'](_0x22b811,'[$or]')?'or':_0x0352('0x2');var _0x424591=_0x22b811[_0x0352('0x3')](_0x0352('0x4'),'')['replace'](_0x0352('0x5'),'')[_0x0352('0x6')]('||');for(var _0x526aaa=0x0;_0x526aaa<_0x424591[_0x0352('0x7')];_0x526aaa++){var _0x45df15=_0x424591[_0x526aaa][_0x0352('0x6')](':=');var _0x34e301=_0x45df15[0x0];var _0x64f791=_0x45df15[_0x0352('0x8')](0x1);_0x64f791[_0x0352('0x9')](function(_0x563323){var _0x4d1471=_0x563323['split']('[')[_0x0352('0xa')]();var _0x8a3da0=_0x563323[_0x0352('0xb')](/\[(.*?)\]/g);_0x8a3da0['forEach'](function(_0x534fa0){var _0x2a1012=_0x534fa0[_0x0352('0x6')]('[')[_0x0352('0xc')](function(_0xf05173){return _0xf05173[_0x0352('0xd')](']')>-0x1;})[_0x0352('0xe')](function(_0x19386b){return _0x19386b[_0x0352('0x6')](']')[0x0];})[0x0];_0x3fefa8['conditions']['push']({'field':_0x34e301,'operator':_0x4d1471,'value':_0x2a1012});});});}return _0x3fefa8;};exports[_0x0352('0xf')]=function(_0x47d188,_0x1a8313,_0x11a698){var _0x2a66ab={};if(_0x1a8313===_0x0352('0x10')){if(_0x11a698[_0x0352('0x11')]===_0x0352('0x12')){_0x11a698[_0x0352('0x11')]=_0x0352('0x13');_0x11a698[_0x0352('0x14')]+=','+_0x11a698[_0x0352('0x14')];}else if(_[_0x0352('0x15')]([_0x0352('0x16'),_0x0352('0x17')],_0x11a698[_0x0352('0x11')])){_0x11a698[_0x0352('0x14')]=moment(_0x11a698['value'])[_0x0352('0x18')](0x1,_0x0352('0x19'))[_0x0352('0x1a')](_0x0352('0x1b'));}}if(_0x11a698[_0x0352('0x1c')]){_0x1a8313=_0x11a698[_0x0352('0x1c')];_0x2a66ab[_0x0352('0x1d')]=_0x0352('0x1e')+_0x47d188+'.'+_0x11a698[_0x0352('0x1f')]+'\x20AS\x20'+_0x11a698[_0x0352('0x1c')]+')\x20'+parseOperator(_0x11a698[_0x0352('0x11')]);}else{_0x2a66ab['text']=_0x47d188+'.'+_0x11a698[_0x0352('0x1f')]+'\x20'+parseOperator(_0x11a698[_0x0352('0x11')]);}if(_[_0x0352('0x15')]([_0x0352('0x20'),'$notIn'],_0x11a698[_0x0352('0x11')]))_0x2a66ab[_0x0352('0x1d')]='('+_0x2a66ab[_0x0352('0x1d')]+_0x0352('0x21')+_0x47d188+'.'+_0x11a698['field']+_0x0352('0x22');_0x2a66ab[_0x0352('0x14')]=parseValue(_0x1a8313,_0x11a698[_0x0352('0x11')],_0x11a698[_0x0352('0x14')]);return _0x2a66ab;};function parseOperator(_0x246667){var _0x441669;switch(_0x246667){case _0x0352('0x23'):_0x441669=_0x0352('0x24');break;case _0x0352('0x25'):_0x441669='NOT\x20IN\x20?';break;case'$eq':_0x441669=_0x0352('0x26');break;case _0x0352('0x20'):_0x441669=_0x0352('0x27');break;case _0x0352('0x28'):case _0x0352('0x29'):case _0x0352('0x2a'):_0x441669=_0x0352('0x2b');break;case'$lt':_0x441669=_0x0352('0x2c');break;case _0x0352('0x16'):_0x441669=_0x0352('0x2d');break;case _0x0352('0x17'):_0x441669='<=\x20?';break;case _0x0352('0x2e'):_0x441669=_0x0352('0x2f');break;case'$between':_0x441669=_0x0352('0x30');break;}return _0x441669;}function parseValue(_0x16122c,_0x404829,_0x2639da){var _0xfc8543={'start':undefined,'end':undefined};switch(_0x404829){case _0x0352('0x23'):case _0x0352('0x25'):_0xfc8543[_0x0352('0x31')]=_0x2639da[_0x0352('0x6')](',');break;case'$substring':_0xfc8543[_0x0352('0x31')]='%'+_0x2639da+'%';break;case _0x0352('0x29'):_0xfc8543['start']=_0x2639da+'%';break;case'$endsWith':_0xfc8543['start']='%'+_0x2639da;break;case _0x0352('0x13'):var _0x466fa9=_0x2639da[_0x0352('0x6')](',');var _0x2639da=_0x466fa9['shift']();var _0x126bce=_0x466fa9[_0x0352('0x32')]();if(_0x16122c===_0x0352('0x10')){_0x2639da=moment(_0x2639da)[_0x0352('0x33')](0x0,!![])[_0x0352('0x1a')]();_0x126bce=moment(_0x126bce)[_0x0352('0x33')](0x0,!![])[_0x0352('0x18')](0x17,_0x0352('0x34'))[_0x0352('0x18')](0x3b,_0x0352('0x35'))['add'](0x3b,_0x0352('0x36'))['format']();}_0xfc8543={'start':_0x2639da,'end':_0x126bce};break;default:_0xfc8543[_0x0352('0x31')]=_0x2639da;break;}return _0xfc8543;}
\ No newline at end of file