Built motion from commit 10af8726.|2.6.34
[motion2.git] / server / components / parsers / advancedSearch.js
index 6702ffe..e450e38 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x7fd7=['hours','minutes','seconds','lodash','moment','startsWith','[$or]','replace','[$and]','split','slice','forEach','shift','match','indexOf','map','conditions','push','buildExpression','DATE','operator','$between','value','includes','$gt','$lte','add','days','format','YYYY-MM-DD','castTo','text','\x20AS\x20','field','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','$eq','=\x20?','$ne','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?','<=\x20?','$gte','start','pop','utcOffset'];(function(_0x4b2436,_0x452299){var _0x4f5ab2=function(_0x5c6679){while(--_0x5c6679){_0x4b2436['push'](_0x4b2436['shift']());}};_0x4f5ab2(++_0x452299);}(_0x7fd7,0xdb));var _0x77fd=function(_0x345622,_0x570bbe){_0x345622=_0x345622-0x0;var _0x2e4383=_0x7fd7[_0x345622];return _0x2e4383;};'use strict';var _=require(_0x77fd('0x0'));var moment=require(_0x77fd('0x1'));exports['parseSearch']=function(_0x475347){var _0x4792ce={'conditions':[]};_0x4792ce['sqlOperator']=_[_0x77fd('0x2')](_0x475347,_0x77fd('0x3'))?'or':'and';var _0x8a170f=_0x475347[_0x77fd('0x4')](_0x77fd('0x5'),'')['replace'](_0x77fd('0x3'),'')[_0x77fd('0x6')]('||');for(var _0x17ee90=0x0;_0x17ee90<_0x8a170f['length'];_0x17ee90++){var _0x54ae10=_0x8a170f[_0x17ee90][_0x77fd('0x6')](':=');var _0x21723f=_0x54ae10[0x0];var _0x1197aa=_0x54ae10[_0x77fd('0x7')](0x1);_0x1197aa[_0x77fd('0x8')](function(_0x419949){var _0x3ecbcd=_0x419949[_0x77fd('0x6')]('[')[_0x77fd('0x9')]();var _0x28e633=_0x419949[_0x77fd('0xa')](/\[(.*?)\]/g);_0x28e633[_0x77fd('0x8')](function(_0x523204){var _0x27659e=_0x523204[_0x77fd('0x6')]('[')['filter'](function(_0x1e1260){return _0x1e1260[_0x77fd('0xb')](']')>-0x1;})[_0x77fd('0xc')](function(_0x477654){return _0x477654[_0x77fd('0x6')](']')[0x0];})[0x0];_0x4792ce[_0x77fd('0xd')][_0x77fd('0xe')]({'field':_0x21723f,'operator':_0x3ecbcd,'value':_0x27659e});});});}return _0x4792ce;};exports[_0x77fd('0xf')]=function(_0xdd5911,_0x474fe2,_0x104578){var _0x3c99c4={};if(_0x474fe2===_0x77fd('0x10')){if(_0x104578[_0x77fd('0x11')]==='$eq'){_0x104578[_0x77fd('0x11')]=_0x77fd('0x12');_0x104578['value']+=','+_0x104578[_0x77fd('0x13')];}else if(_[_0x77fd('0x14')]([_0x77fd('0x15'),_0x77fd('0x16')],_0x104578[_0x77fd('0x11')])){_0x104578[_0x77fd('0x13')]=moment(_0x104578[_0x77fd('0x13')])[_0x77fd('0x17')](0x1,_0x77fd('0x18'))[_0x77fd('0x19')](_0x77fd('0x1a'));}}if(_0x104578[_0x77fd('0x1b')]){_0x474fe2=_0x104578[_0x77fd('0x1b')];_0x3c99c4[_0x77fd('0x1c')]='CAST('+_0xdd5911+'.'+_0x104578['field']+_0x77fd('0x1d')+_0x104578[_0x77fd('0x1b')]+')\x20'+parseOperator(_0x104578[_0x77fd('0x11')]);}else{_0x3c99c4[_0x77fd('0x1c')]=_0xdd5911+'.'+_0x104578[_0x77fd('0x1e')]+'\x20'+parseOperator(_0x104578['operator']);}if(_['includes'](['$ne',_0x77fd('0x1f')],_0x104578[_0x77fd('0x11')]))_0x3c99c4[_0x77fd('0x1c')]='('+_0x3c99c4[_0x77fd('0x1c')]+_0x77fd('0x20')+_0xdd5911+'.'+_0x104578['field']+_0x77fd('0x21');_0x3c99c4[_0x77fd('0x13')]=parseValue(_0x474fe2,_0x104578[_0x77fd('0x11')],_0x104578[_0x77fd('0x13')]);return _0x3c99c4;};function parseOperator(_0x2c1222){var _0x5c064c;switch(_0x2c1222){case _0x77fd('0x22'):_0x5c064c='IN\x20?';break;case _0x77fd('0x1f'):_0x5c064c='NOT\x20IN\x20?';break;case _0x77fd('0x23'):_0x5c064c=_0x77fd('0x24');break;case _0x77fd('0x25'):_0x5c064c=_0x77fd('0x26');break;case _0x77fd('0x27'):case _0x77fd('0x28'):case _0x77fd('0x29'):_0x5c064c=_0x77fd('0x2a');break;case _0x77fd('0x2b'):_0x5c064c=_0x77fd('0x2c');break;case _0x77fd('0x15'):_0x5c064c=_0x77fd('0x2d');break;case _0x77fd('0x16'):_0x5c064c=_0x77fd('0x2e');break;case _0x77fd('0x2f'):_0x5c064c='>=\x20?';break;case _0x77fd('0x12'):_0x5c064c='BETWEEN\x20?\x20AND\x20?';break;}return _0x5c064c;}function parseValue(_0x51d54e,_0x3cd501,_0x1940ba){var _0x757591={'start':undefined,'end':undefined};switch(_0x3cd501){case _0x77fd('0x22'):case _0x77fd('0x1f'):_0x757591[_0x77fd('0x30')]=_0x1940ba[_0x77fd('0x6')](',');break;case _0x77fd('0x27'):_0x757591[_0x77fd('0x30')]='%'+_0x1940ba+'%';break;case'$startsWith':_0x757591['start']=_0x1940ba+'%';break;case'$endsWith':_0x757591[_0x77fd('0x30')]='%'+_0x1940ba;break;case'$between':var _0x549f7b=_0x1940ba[_0x77fd('0x6')](',');var _0x1940ba=_0x549f7b[_0x77fd('0x9')]();var _0x4d8c48=_0x549f7b[_0x77fd('0x31')]();if(_0x51d54e===_0x77fd('0x10')){_0x1940ba=moment(_0x1940ba)[_0x77fd('0x32')](0x0,!![])[_0x77fd('0x19')]();_0x4d8c48=moment(_0x4d8c48)[_0x77fd('0x32')](0x0,!![])[_0x77fd('0x17')](0x17,_0x77fd('0x33'))[_0x77fd('0x17')](0x3b,_0x77fd('0x34'))['add'](0x3b,_0x77fd('0x35'))[_0x77fd('0x19')]();}_0x757591={'start':_0x1940ba,'end':_0x4d8c48};break;default:_0x757591[_0x77fd('0x30')]=_0x1940ba;break;}return _0x757591;}
\ No newline at end of file
+var _0x47e6=['split','slice','forEach','shift','indexOf','conditions','buildExpression','operator','$between','value','$gt','$lte','add','days','YYYY-MM-DD','castTo','CAST(','field','\x20AS\x20','$ne','$notIn','text','\x20OR\x20','$in','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','pop','DATE','format','minutes','seconds','moment','parseSearch','sqlOperator','[$or]','and','replace'];(function(_0x1ca93c,_0x3271ab){var _0x185169=function(_0x507763){while(--_0x507763){_0x1ca93c['push'](_0x1ca93c['shift']());}};_0x185169(++_0x3271ab);}(_0x47e6,0x182));var _0x647e=function(_0x635271,_0x6ccc26){_0x635271=_0x635271-0x0;var _0x5e3773=_0x47e6[_0x635271];return _0x5e3773;};'use strict';var _=require('lodash');var moment=require(_0x647e('0x0'));exports[_0x647e('0x1')]=function(_0x138ed2){var _0x4e93dd={'conditions':[]};_0x4e93dd[_0x647e('0x2')]=_['startsWith'](_0x138ed2,_0x647e('0x3'))?'or':_0x647e('0x4');var _0x59f2fd=_0x138ed2[_0x647e('0x5')]('[$and]','')[_0x647e('0x5')](_0x647e('0x3'),'')[_0x647e('0x6')]('||');for(var _0x47de70=0x0;_0x47de70<_0x59f2fd['length'];_0x47de70++){var _0x327f39=_0x59f2fd[_0x47de70][_0x647e('0x6')](':=');var _0x1e8101=_0x327f39[0x0];var _0x185d32=_0x327f39[_0x647e('0x7')](0x1);_0x185d32[_0x647e('0x8')](function(_0x412dd7){var _0x4b7fe6=_0x412dd7[_0x647e('0x6')]('[')[_0x647e('0x9')]();var _0x2d5d1f=_0x412dd7['match'](/\[(.*?)\]/g);_0x2d5d1f[_0x647e('0x8')](function(_0xae699f){var _0x19e848=_0xae699f[_0x647e('0x6')]('[')['filter'](function(_0x337f46){return _0x337f46[_0x647e('0xa')](']')>-0x1;})['map'](function(_0x3d8c5e){return _0x3d8c5e[_0x647e('0x6')](']')[0x0];})[0x0];_0x4e93dd[_0x647e('0xb')]['push']({'field':_0x1e8101,'operator':_0x4b7fe6,'value':_0x19e848});});});}return _0x4e93dd;};exports[_0x647e('0xc')]=function(_0x37c463,_0x51b344,_0x39daf9){var _0x2d2964={};if(_0x51b344==='DATE'){if(_0x39daf9[_0x647e('0xd')]==='$eq'){_0x39daf9[_0x647e('0xd')]=_0x647e('0xe');_0x39daf9[_0x647e('0xf')]+=','+_0x39daf9[_0x647e('0xf')];}else if(_['includes']([_0x647e('0x10'),_0x647e('0x11')],_0x39daf9[_0x647e('0xd')])){_0x39daf9[_0x647e('0xf')]=moment(_0x39daf9[_0x647e('0xf')])[_0x647e('0x12')](0x1,_0x647e('0x13'))['format'](_0x647e('0x14'));}}if(_0x39daf9[_0x647e('0x15')]){_0x51b344=_0x39daf9[_0x647e('0x15')];_0x2d2964['text']=_0x647e('0x16')+_0x37c463+'.'+_0x39daf9[_0x647e('0x17')]+_0x647e('0x18')+_0x39daf9[_0x647e('0x15')]+')\x20'+parseOperator(_0x39daf9[_0x647e('0xd')]);}else{_0x2d2964['text']=_0x37c463+'.'+_0x39daf9['field']+'\x20'+parseOperator(_0x39daf9[_0x647e('0xd')]);}if(_['includes']([_0x647e('0x19'),_0x647e('0x1a')],_0x39daf9['operator']))_0x2d2964[_0x647e('0x1b')]='('+_0x2d2964[_0x647e('0x1b')]+_0x647e('0x1c')+_0x37c463+'.'+_0x39daf9['field']+'\x20IS\x20NULL)';_0x2d2964[_0x647e('0xf')]=parseValue(_0x51b344,_0x39daf9[_0x647e('0xd')],_0x39daf9[_0x647e('0xf')]);return _0x2d2964;};function parseOperator(_0x2722fc){var _0x5240d7;switch(_0x2722fc){case _0x647e('0x1d'):_0x5240d7='IN\x20?';break;case _0x647e('0x1a'):_0x5240d7=_0x647e('0x1e');break;case'$eq':_0x5240d7=_0x647e('0x1f');break;case _0x647e('0x19'):_0x5240d7=_0x647e('0x20');break;case _0x647e('0x21'):case _0x647e('0x22'):case _0x647e('0x23'):_0x5240d7=_0x647e('0x24');break;case'$lt':_0x5240d7=_0x647e('0x25');break;case _0x647e('0x10'):_0x5240d7=_0x647e('0x26');break;case _0x647e('0x11'):_0x5240d7=_0x647e('0x27');break;case _0x647e('0x28'):_0x5240d7=_0x647e('0x29');break;case _0x647e('0xe'):_0x5240d7=_0x647e('0x2a');break;}return _0x5240d7;}function parseValue(_0xad0cc5,_0x279f77,_0x5bd62e){var _0x2bbbf1={'start':undefined,'end':undefined};switch(_0x279f77){case _0x647e('0x1d'):case _0x647e('0x1a'):_0x2bbbf1[_0x647e('0x2b')]=_0x5bd62e['split'](',');break;case _0x647e('0x21'):_0x2bbbf1['start']='%'+_0x5bd62e+'%';break;case _0x647e('0x22'):_0x2bbbf1['start']=_0x5bd62e+'%';break;case'$endsWith':_0x2bbbf1['start']='%'+_0x5bd62e;break;case'$between':var _0x3898e0=_0x5bd62e[_0x647e('0x6')](',');var _0x5bd62e=_0x3898e0[_0x647e('0x9')]();var _0x4d7c4e=_0x3898e0[_0x647e('0x2c')]();if(_0xad0cc5===_0x647e('0x2d')){_0x5bd62e=moment(_0x5bd62e)['utcOffset'](0x0,!![])[_0x647e('0x2e')]();_0x4d7c4e=moment(_0x4d7c4e)['utcOffset'](0x0,!![])[_0x647e('0x12')](0x17,'hours')['add'](0x3b,_0x647e('0x2f'))['add'](0x3b,_0x647e('0x30'))[_0x647e('0x2e')]();}_0x2bbbf1={'start':_0x5bd62e,'end':_0x4d7c4e};break;default:_0x2bbbf1[_0x647e('0x2b')]=_0x5bd62e;break;}return _0x2bbbf1;}
\ No newline at end of file