Built motion from commit b0a9a629.|2.6.33
[motion2.git] / server / components / parsers / advancedSearch.js
index 7b7577f..14b883f 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xb98f=['BETWEEN\x20?\x20AND\x20?','start','$endsWith','$between','utcOffset','hours','moment','sqlOperator','startsWith','[$or]','and','split','length','forEach','shift','filter','indexOf','map','push','buildExpression','operator','$eq','value','includes','$lte','add','days','format','castTo','text','CAST(','\x20AS\x20','field','$ne','$notIn','\x20OR\x20','$in','IN\x20?','NOT\x20IN\x20?','<>\x20?','$substring','$startsWith','LIKE\x20?','$lt','<\x20?','$gt','>\x20?','<=\x20?','$gte','>=\x20?'];(function(_0x129e52,_0x549e39){var _0x12a841=function(_0x434502){while(--_0x434502){_0x129e52['push'](_0x129e52['shift']());}};_0x12a841(++_0x549e39);}(_0xb98f,0x196));var _0xfb98=function(_0x520710,_0x4cbf3a){_0x520710=_0x520710-0x0;var _0x45f014=_0xb98f[_0x520710];return _0x45f014;};'use strict';var _=require('lodash');var moment=require(_0xfb98('0x0'));exports['parseSearch']=function(_0x254368){var _0x510608={'conditions':[]};_0x510608[_0xfb98('0x1')]=_[_0xfb98('0x2')](_0x254368,_0xfb98('0x3'))?'or':_0xfb98('0x4');var _0x501d80=_0x254368['replace']('[$and]','')['replace'](_0xfb98('0x3'),'')[_0xfb98('0x5')]('||');for(var _0x511949=0x0;_0x511949<_0x501d80[_0xfb98('0x6')];_0x511949++){var _0x1fff51=_0x501d80[_0x511949][_0xfb98('0x5')](':=');var _0x2193b5=_0x1fff51[0x0];var _0x424ec3=_0x1fff51['slice'](0x1);_0x424ec3[_0xfb98('0x7')](function(_0x2f424c){var _0x128cb9=_0x2f424c[_0xfb98('0x5')]('[')[_0xfb98('0x8')]();var _0x3e172d=_0x2f424c['match'](/\[(.*?)\]/g);_0x3e172d[_0xfb98('0x7')](function(_0x45205b){var _0xbb0c64=_0x45205b[_0xfb98('0x5')]('[')[_0xfb98('0x9')](function(_0x551645){return _0x551645[_0xfb98('0xa')](']')>-0x1;})[_0xfb98('0xb')](function(_0x5972d8){return _0x5972d8['split'](']')[0x0];})[0x0];_0x510608['conditions'][_0xfb98('0xc')]({'field':_0x2193b5,'operator':_0x128cb9,'value':_0xbb0c64});});});}return _0x510608;};exports[_0xfb98('0xd')]=function(_0x53c13a,_0x5502ba,_0x39b568){var _0x27359b={};if(_0x5502ba==='DATE'){if(_0x39b568[_0xfb98('0xe')]===_0xfb98('0xf')){_0x39b568[_0xfb98('0xe')]='$between';_0x39b568['value']+=','+_0x39b568[_0xfb98('0x10')];}else if(_[_0xfb98('0x11')](['$gt',_0xfb98('0x12')],_0x39b568[_0xfb98('0xe')])){_0x39b568[_0xfb98('0x10')]=moment(_0x39b568['value'])[_0xfb98('0x13')](0x1,_0xfb98('0x14'))[_0xfb98('0x15')]('YYYY-MM-DD');}}if(_0x39b568[_0xfb98('0x16')]){_0x5502ba=_0x39b568[_0xfb98('0x16')];_0x27359b[_0xfb98('0x17')]=_0xfb98('0x18')+_0x53c13a+'.'+_0x39b568['field']+_0xfb98('0x19')+_0x39b568[_0xfb98('0x16')]+')\x20'+parseOperator(_0x39b568['operator']);}else{_0x27359b[_0xfb98('0x17')]=_0x53c13a+'.'+_0x39b568[_0xfb98('0x1a')]+'\x20'+parseOperator(_0x39b568[_0xfb98('0xe')]);}if(_['includes']([_0xfb98('0x1b'),_0xfb98('0x1c')],_0x39b568[_0xfb98('0xe')]))_0x27359b['text']='('+_0x27359b[_0xfb98('0x17')]+_0xfb98('0x1d')+_0x53c13a+'.'+_0x39b568['field']+'\x20IS\x20NULL)';_0x27359b[_0xfb98('0x10')]=parseValue(_0x5502ba,_0x39b568['operator'],_0x39b568[_0xfb98('0x10')]);return _0x27359b;};function parseOperator(_0x5b5b54){var _0x264d6e;switch(_0x5b5b54){case _0xfb98('0x1e'):_0x264d6e=_0xfb98('0x1f');break;case _0xfb98('0x1c'):_0x264d6e=_0xfb98('0x20');break;case _0xfb98('0xf'):_0x264d6e='=\x20?';break;case _0xfb98('0x1b'):_0x264d6e=_0xfb98('0x21');break;case _0xfb98('0x22'):case _0xfb98('0x23'):case'$endsWith':_0x264d6e=_0xfb98('0x24');break;case _0xfb98('0x25'):_0x264d6e=_0xfb98('0x26');break;case _0xfb98('0x27'):_0x264d6e=_0xfb98('0x28');break;case _0xfb98('0x12'):_0x264d6e=_0xfb98('0x29');break;case _0xfb98('0x2a'):_0x264d6e=_0xfb98('0x2b');break;case'$between':_0x264d6e=_0xfb98('0x2c');break;}return _0x264d6e;}function parseValue(_0x53f125,_0x5f0396,_0x46378b){var _0x42322c={'start':undefined,'end':undefined};switch(_0x5f0396){case _0xfb98('0x1e'):case'$notIn':_0x42322c[_0xfb98('0x2d')]=_0x46378b[_0xfb98('0x5')](',');break;case _0xfb98('0x22'):_0x42322c[_0xfb98('0x2d')]='%'+_0x46378b+'%';break;case _0xfb98('0x23'):_0x42322c['start']=_0x46378b+'%';break;case _0xfb98('0x2e'):_0x42322c[_0xfb98('0x2d')]='%'+_0x46378b;break;case _0xfb98('0x2f'):var _0x2a97fb=_0x46378b[_0xfb98('0x5')](',');var _0x46378b=_0x2a97fb[_0xfb98('0x8')]();var _0x4c6be7=_0x2a97fb['pop']();if(_0x53f125==='DATE'){_0x46378b=moment(_0x46378b)['utcOffset'](0x0,!![])[_0xfb98('0x15')]();_0x4c6be7=moment(_0x4c6be7)[_0xfb98('0x30')](0x0,!![])[_0xfb98('0x13')](0x17,_0xfb98('0x31'))[_0xfb98('0x13')](0x3b,'minutes')[_0xfb98('0x13')](0x3b,'seconds')[_0xfb98('0x15')]();}_0x42322c={'start':_0x46378b,'end':_0x4c6be7};break;default:_0x42322c[_0xfb98('0x2d')]=_0x46378b;break;}return _0x42322c;}
\ No newline at end of file
+var _0x33a7=['<=\x20?','$gte','>=\x20?','start','$between','shift','pop','utcOffset','hours','minutes','seconds','lodash','moment','parseSearch','startsWith','and','[$and]','replace','split','slice','forEach','match','filter','indexOf','map','conditions','push','buildExpression','DATE','operator','value','includes','$gt','$lte','add','days','YYYY-MM-DD','castTo','CAST(','field','text','$ne','$notIn','\x20OR\x20','$in','NOT\x20IN\x20?','$eq','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?'];(function(_0x47f2c5,_0x40c84b){var _0x38b405=function(_0x22c2aa){while(--_0x22c2aa){_0x47f2c5['push'](_0x47f2c5['shift']());}};_0x38b405(++_0x40c84b);}(_0x33a7,0x1c3));var _0x733a=function(_0x3011b7,_0x56b4b0){_0x3011b7=_0x3011b7-0x0;var _0x304ca2=_0x33a7[_0x3011b7];return _0x304ca2;};'use strict';var _=require(_0x733a('0x0'));var moment=require(_0x733a('0x1'));exports[_0x733a('0x2')]=function(_0x25fbe3){var _0x597ecf={'conditions':[]};_0x597ecf['sqlOperator']=_[_0x733a('0x3')](_0x25fbe3,'[$or]')?'or':_0x733a('0x4');var _0x551bfc=_0x25fbe3['replace'](_0x733a('0x5'),'')[_0x733a('0x6')]('[$or]','')[_0x733a('0x7')]('||');for(var _0x2ab366=0x0;_0x2ab366<_0x551bfc['length'];_0x2ab366++){var _0x73d632=_0x551bfc[_0x2ab366][_0x733a('0x7')](':=');var _0x5e7365=_0x73d632[0x0];var _0x20a53d=_0x73d632[_0x733a('0x8')](0x1);_0x20a53d[_0x733a('0x9')](function(_0xcceb9){var _0x5dcc0c=_0xcceb9[_0x733a('0x7')]('[')['shift']();var _0xc3ecca=_0xcceb9[_0x733a('0xa')](/\[(.*?)\]/g);_0xc3ecca[_0x733a('0x9')](function(_0x47cea8){var _0xdf457f=_0x47cea8['split']('[')[_0x733a('0xb')](function(_0x5a04fd){return _0x5a04fd[_0x733a('0xc')](']')>-0x1;})[_0x733a('0xd')](function(_0x1d0e42){return _0x1d0e42[_0x733a('0x7')](']')[0x0];})[0x0];_0x597ecf[_0x733a('0xe')][_0x733a('0xf')]({'field':_0x5e7365,'operator':_0x5dcc0c,'value':_0xdf457f});});});}return _0x597ecf;};exports[_0x733a('0x10')]=function(_0xf49ae4,_0x429d6d,_0x503a15){var _0x19e1a9={};if(_0x429d6d===_0x733a('0x11')){if(_0x503a15[_0x733a('0x12')]==='$eq'){_0x503a15['operator']='$between';_0x503a15['value']+=','+_0x503a15[_0x733a('0x13')];}else if(_[_0x733a('0x14')]([_0x733a('0x15'),_0x733a('0x16')],_0x503a15[_0x733a('0x12')])){_0x503a15[_0x733a('0x13')]=moment(_0x503a15['value'])[_0x733a('0x17')](0x1,_0x733a('0x18'))['format'](_0x733a('0x19'));}}if(_0x503a15[_0x733a('0x1a')]){_0x429d6d=_0x503a15['castTo'];_0x19e1a9['text']=_0x733a('0x1b')+_0xf49ae4+'.'+_0x503a15[_0x733a('0x1c')]+'\x20AS\x20'+_0x503a15[_0x733a('0x1a')]+')\x20'+parseOperator(_0x503a15[_0x733a('0x12')]);}else{_0x19e1a9[_0x733a('0x1d')]=_0xf49ae4+'.'+_0x503a15[_0x733a('0x1c')]+'\x20'+parseOperator(_0x503a15['operator']);}if(_['includes']([_0x733a('0x1e'),_0x733a('0x1f')],_0x503a15['operator']))_0x19e1a9[_0x733a('0x1d')]='('+_0x19e1a9[_0x733a('0x1d')]+_0x733a('0x20')+_0xf49ae4+'.'+_0x503a15['field']+'\x20IS\x20NULL)';_0x19e1a9['value']=parseValue(_0x429d6d,_0x503a15['operator'],_0x503a15[_0x733a('0x13')]);return _0x19e1a9;};function parseOperator(_0x4708b6){var _0x2a5cd2;switch(_0x4708b6){case _0x733a('0x21'):_0x2a5cd2='IN\x20?';break;case _0x733a('0x1f'):_0x2a5cd2=_0x733a('0x22');break;case _0x733a('0x23'):_0x2a5cd2='=\x20?';break;case _0x733a('0x1e'):_0x2a5cd2=_0x733a('0x24');break;case _0x733a('0x25'):case _0x733a('0x26'):case _0x733a('0x27'):_0x2a5cd2=_0x733a('0x28');break;case _0x733a('0x29'):_0x2a5cd2=_0x733a('0x2a');break;case _0x733a('0x15'):_0x2a5cd2=_0x733a('0x2b');break;case _0x733a('0x16'):_0x2a5cd2=_0x733a('0x2c');break;case _0x733a('0x2d'):_0x2a5cd2=_0x733a('0x2e');break;case'$between':_0x2a5cd2='BETWEEN\x20?\x20AND\x20?';break;}return _0x2a5cd2;}function parseValue(_0x32d36c,_0x1f45d4,_0x33b658){var _0x5514c0={'start':undefined,'end':undefined};switch(_0x1f45d4){case'$in':case'$notIn':_0x5514c0[_0x733a('0x2f')]=_0x33b658[_0x733a('0x7')](',');break;case _0x733a('0x25'):_0x5514c0['start']='%'+_0x33b658+'%';break;case _0x733a('0x26'):_0x5514c0['start']=_0x33b658+'%';break;case _0x733a('0x27'):_0x5514c0[_0x733a('0x2f')]='%'+_0x33b658;break;case _0x733a('0x30'):var _0x451788=_0x33b658[_0x733a('0x7')](',');var _0x33b658=_0x451788[_0x733a('0x31')]();var _0x34792d=_0x451788[_0x733a('0x32')]();if(_0x32d36c===_0x733a('0x11')){_0x33b658=moment(_0x33b658)[_0x733a('0x33')](0x0,!![])['format']();_0x34792d=moment(_0x34792d)[_0x733a('0x33')](0x0,!![])[_0x733a('0x17')](0x17,_0x733a('0x34'))['add'](0x3b,_0x733a('0x35'))[_0x733a('0x17')](0x3b,_0x733a('0x36'))['format']();}_0x5514c0={'start':_0x33b658,'end':_0x34792d};break;default:_0x5514c0[_0x733a('0x2f')]=_0x33b658;break;}return _0x5514c0;}
\ No newline at end of file