Built motion from commit da617fac.|2.6.6
[motion2.git] / server / components / parsers / advancedSearch.js
index 6702ffe..29d9dc1 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 _0xc962=['replace','split','length','forEach','conditions','push','buildExpression','DATE','$eq','operator','value','includes','$lte','days','format','YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','$gt','>\x20?','<=\x20?','>=\x20?','$between','BETWEEN\x20?\x20AND\x20?','start','shift','pop','utcOffset','hours','add','seconds','lodash','moment','parseSearch','sqlOperator','[$or]','and'];(function(_0x19950b,_0x53d0d7){var _0x3c6b41=function(_0x3924ad){while(--_0x3924ad){_0x19950b['push'](_0x19950b['shift']());}};_0x3c6b41(++_0x53d0d7);}(_0xc962,0x66));var _0x2c96=function(_0x1b626f,_0x3ec9de){_0x1b626f=_0x1b626f-0x0;var _0xb91df7=_0xc962[_0x1b626f];return _0xb91df7;};'use strict';var _=require(_0x2c96('0x0'));var moment=require(_0x2c96('0x1'));exports[_0x2c96('0x2')]=function(_0x1867df){var _0x16f1d4={'conditions':[]};_0x16f1d4[_0x2c96('0x3')]=_['startsWith'](_0x1867df,_0x2c96('0x4'))?'or':_0x2c96('0x5');var _0x307e6c=_0x1867df[_0x2c96('0x6')]('[$and]','')[_0x2c96('0x6')](_0x2c96('0x4'),'')[_0x2c96('0x7')]('||');for(var _0x5f28bc=0x0;_0x5f28bc<_0x307e6c[_0x2c96('0x8')];_0x5f28bc++){var _0x2219d1=_0x307e6c[_0x5f28bc]['split'](':=');var _0x324b6d=_0x2219d1[0x0];var _0x11b6a3=_0x2219d1['slice'](0x1);_0x11b6a3[_0x2c96('0x9')](function(_0x58932e){var _0x15378d=_0x58932e[_0x2c96('0x7')]('[')['shift']();var _0x393322=_0x58932e['match'](/\[(.*?)\]/g);_0x393322[_0x2c96('0x9')](function(_0x29f30e){var _0x7e0db1=_0x29f30e[_0x2c96('0x7')]('[')['filter'](function(_0x26f192){return _0x26f192['indexOf'](']')>-0x1;})['map'](function(_0x47d8d0){return _0x47d8d0[_0x2c96('0x7')](']')[0x0];})[0x0];_0x16f1d4[_0x2c96('0xa')][_0x2c96('0xb')]({'field':_0x324b6d,'operator':_0x15378d,'value':_0x7e0db1});});});}return _0x16f1d4;};exports[_0x2c96('0xc')]=function(_0x287825,_0x152770,_0x14eee5){var _0x2452f8={};if(_0x152770===_0x2c96('0xd')){if(_0x14eee5['operator']===_0x2c96('0xe')){_0x14eee5[_0x2c96('0xf')]='$between';_0x14eee5[_0x2c96('0x10')]+=','+_0x14eee5['value'];}else if(_[_0x2c96('0x11')](['$gt',_0x2c96('0x12')],_0x14eee5[_0x2c96('0xf')])){_0x14eee5[_0x2c96('0x10')]=moment(_0x14eee5['value'])['add'](0x1,_0x2c96('0x13'))[_0x2c96('0x14')](_0x2c96('0x15'));}}if(_0x14eee5[_0x2c96('0x16')]){_0x152770=_0x14eee5['castTo'];_0x2452f8[_0x2c96('0x17')]=_0x2c96('0x18')+_0x287825+'.'+_0x14eee5[_0x2c96('0x19')]+_0x2c96('0x1a')+_0x14eee5[_0x2c96('0x16')]+')\x20'+parseOperator(_0x14eee5[_0x2c96('0xf')]);}else{_0x2452f8[_0x2c96('0x17')]=_0x287825+'.'+_0x14eee5['field']+'\x20'+parseOperator(_0x14eee5[_0x2c96('0xf')]);}if(_[_0x2c96('0x11')]([_0x2c96('0x1b'),_0x2c96('0x1c')],_0x14eee5[_0x2c96('0xf')]))_0x2452f8[_0x2c96('0x17')]='('+_0x2452f8[_0x2c96('0x17')]+_0x2c96('0x1d')+_0x287825+'.'+_0x14eee5[_0x2c96('0x19')]+_0x2c96('0x1e');_0x2452f8[_0x2c96('0x10')]=parseValue(_0x152770,_0x14eee5[_0x2c96('0xf')],_0x14eee5[_0x2c96('0x10')]);return _0x2452f8;};function parseOperator(_0x5e9fc0){var _0x19bb06;switch(_0x5e9fc0){case _0x2c96('0x1f'):_0x19bb06=_0x2c96('0x20');break;case _0x2c96('0x1c'):_0x19bb06=_0x2c96('0x21');break;case _0x2c96('0xe'):_0x19bb06='=\x20?';break;case _0x2c96('0x1b'):_0x19bb06=_0x2c96('0x22');break;case _0x2c96('0x23'):case _0x2c96('0x24'):case _0x2c96('0x25'):_0x19bb06=_0x2c96('0x26');break;case _0x2c96('0x27'):_0x19bb06=_0x2c96('0x28');break;case _0x2c96('0x29'):_0x19bb06=_0x2c96('0x2a');break;case'$lte':_0x19bb06=_0x2c96('0x2b');break;case'$gte':_0x19bb06=_0x2c96('0x2c');break;case _0x2c96('0x2d'):_0x19bb06=_0x2c96('0x2e');break;}return _0x19bb06;}function parseValue(_0x37f5e7,_0x4efe72,_0x214e60){var _0x52e8f2={'start':undefined,'end':undefined};switch(_0x4efe72){case _0x2c96('0x1f'):case _0x2c96('0x1c'):_0x52e8f2[_0x2c96('0x2f')]=_0x214e60[_0x2c96('0x7')](',');break;case _0x2c96('0x23'):_0x52e8f2['start']='%'+_0x214e60+'%';break;case'$startsWith':_0x52e8f2[_0x2c96('0x2f')]=_0x214e60+'%';break;case'$endsWith':_0x52e8f2['start']='%'+_0x214e60;break;case _0x2c96('0x2d'):var _0x276db6=_0x214e60[_0x2c96('0x7')](',');var _0x214e60=_0x276db6[_0x2c96('0x30')]();var _0x29a607=_0x276db6[_0x2c96('0x31')]();if(_0x37f5e7===_0x2c96('0xd')){_0x214e60=moment(_0x214e60)[_0x2c96('0x32')](0x0,!![])['format']();_0x29a607=moment(_0x29a607)[_0x2c96('0x32')](0x0,!![])['add'](0x17,_0x2c96('0x33'))[_0x2c96('0x34')](0x3b,'minutes')[_0x2c96('0x34')](0x3b,_0x2c96('0x35'))['format']();}_0x52e8f2={'start':_0x214e60,'end':_0x29a607};break;default:_0x52e8f2[_0x2c96('0x2f')]=_0x214e60;break;}return _0x52e8f2;}
\ No newline at end of file