Built motion from commit da617fac.|2.6.6
[motion2.git] / server / components / parsers / advancedSearch.js
index 4806364..89354ef 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x74d5=['$in','IN\x20?','NOT\x20IN\x20?','=\x20?','<>\x20?','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','$substring','DATE','utcOffset','format','hours','seconds','lodash','moment','parseSearch','sqlOperator','startsWith','and','replace','[$or]','length','slice','split','shift','forEach','filter','indexOf','map','conditions','buildExpression','operator','$eq','$between','value','includes','$gt','$lte','add','days','YYYY-MM-DD','castTo','text','CAST(','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)'];(function(_0x9d5a92,_0x34875d){var _0x3d84f2=function(_0x4bde89){while(--_0x4bde89){_0x9d5a92['push'](_0x9d5a92['shift']());}};_0x3d84f2(++_0x34875d);}(_0x74d5,0x132));var _0x574d=function(_0x1bb11e,_0x58fd78){_0x1bb11e=_0x1bb11e-0x0;var _0x422492=_0x74d5[_0x1bb11e];return _0x422492;};'use strict';var _=require(_0x574d('0x0'));var moment=require(_0x574d('0x1'));exports[_0x574d('0x2')]=function(_0x18b676){var _0xce589c={'conditions':[]};_0xce589c[_0x574d('0x3')]=_[_0x574d('0x4')](_0x18b676,'[$or]')?'or':_0x574d('0x5');var _0x2cf7e9=_0x18b676[_0x574d('0x6')]('[$and]','')[_0x574d('0x6')](_0x574d('0x7'),'')['split']('||');for(var _0x1edf0e=0x0;_0x1edf0e<_0x2cf7e9[_0x574d('0x8')];_0x1edf0e++){var _0x262b43=_0x2cf7e9[_0x1edf0e]['split'](':=');var _0x10e345=_0x262b43[0x0];var _0x5ca786=_0x262b43[_0x574d('0x9')](0x1);_0x5ca786['forEach'](function(_0x4d7fb6){var _0x1a4db6=_0x4d7fb6[_0x574d('0xa')]('[')[_0x574d('0xb')]();var _0x379f09=_0x4d7fb6['match'](/\[(.*?)\]/g);_0x379f09[_0x574d('0xc')](function(_0xd84313){var _0x42350d=_0xd84313[_0x574d('0xa')]('[')[_0x574d('0xd')](function(_0x26fb35){return _0x26fb35[_0x574d('0xe')](']')>-0x1;})[_0x574d('0xf')](function(_0x4974be){return _0x4974be[_0x574d('0xa')](']')[0x0];})[0x0];_0xce589c[_0x574d('0x10')]['push']({'field':_0x10e345,'operator':_0x1a4db6,'value':_0x42350d});});});}return _0xce589c;};exports[_0x574d('0x11')]=function(_0x1a4084,_0x57d585,_0x3adaba){var _0x3e1d42={};if(_0x57d585==='DATE'){if(_0x3adaba[_0x574d('0x12')]===_0x574d('0x13')){_0x3adaba[_0x574d('0x12')]=_0x574d('0x14');_0x3adaba[_0x574d('0x15')]+=','+_0x3adaba[_0x574d('0x15')];}else if(_[_0x574d('0x16')]([_0x574d('0x17'),_0x574d('0x18')],_0x3adaba[_0x574d('0x12')])){_0x3adaba[_0x574d('0x15')]=moment(_0x3adaba[_0x574d('0x15')])[_0x574d('0x19')](0x1,_0x574d('0x1a'))['format'](_0x574d('0x1b'));}}if(_0x3adaba[_0x574d('0x1c')]){_0x57d585=_0x3adaba[_0x574d('0x1c')];_0x3e1d42[_0x574d('0x1d')]=_0x574d('0x1e')+_0x1a4084+'.'+_0x3adaba[_0x574d('0x1f')]+'\x20AS\x20'+_0x3adaba[_0x574d('0x1c')]+')\x20'+parseOperator(_0x3adaba['operator']);}else{_0x3e1d42['text']=_0x1a4084+'.'+_0x3adaba[_0x574d('0x1f')]+'\x20'+parseOperator(_0x3adaba[_0x574d('0x12')]);}if(_['includes']([_0x574d('0x20'),_0x574d('0x21')],_0x3adaba[_0x574d('0x12')]))_0x3e1d42['text']='('+_0x3e1d42[_0x574d('0x1d')]+_0x574d('0x22')+_0x1a4084+'.'+_0x3adaba['field']+_0x574d('0x23');_0x3e1d42[_0x574d('0x15')]=parseValue(_0x57d585,_0x3adaba[_0x574d('0x12')],_0x3adaba[_0x574d('0x15')]);return _0x3e1d42;};function parseOperator(_0x1d8e55){var _0x5e10a6;switch(_0x1d8e55){case _0x574d('0x24'):_0x5e10a6=_0x574d('0x25');break;case _0x574d('0x21'):_0x5e10a6=_0x574d('0x26');break;case _0x574d('0x13'):_0x5e10a6=_0x574d('0x27');break;case _0x574d('0x20'):_0x5e10a6=_0x574d('0x28');break;case'$substring':case _0x574d('0x29'):case _0x574d('0x2a'):_0x5e10a6=_0x574d('0x2b');break;case'$lt':_0x5e10a6=_0x574d('0x2c');break;case _0x574d('0x17'):_0x5e10a6=_0x574d('0x2d');break;case _0x574d('0x18'):_0x5e10a6=_0x574d('0x2e');break;case _0x574d('0x2f'):_0x5e10a6=_0x574d('0x30');break;case _0x574d('0x14'):_0x5e10a6=_0x574d('0x31');break;}return _0x5e10a6;}function parseValue(_0xbc235c,_0x38655f,_0x2d88bd){var _0x120696={'start':undefined,'end':undefined};switch(_0x38655f){case _0x574d('0x24'):case'$notIn':_0x120696[_0x574d('0x32')]=_0x2d88bd[_0x574d('0xa')](',');break;case _0x574d('0x33'):_0x120696[_0x574d('0x32')]='%'+_0x2d88bd+'%';break;case'$startsWith':_0x120696[_0x574d('0x32')]=_0x2d88bd+'%';break;case'$endsWith':_0x120696[_0x574d('0x32')]='%'+_0x2d88bd;break;case _0x574d('0x14'):var _0x4b725f=_0x2d88bd[_0x574d('0xa')](',');var _0x2d88bd=_0x4b725f['shift']();var _0x354f5b=_0x4b725f['pop']();if(_0xbc235c===_0x574d('0x34')){_0x2d88bd=moment(_0x2d88bd)[_0x574d('0x35')](0x0,!![])[_0x574d('0x36')]();_0x354f5b=moment(_0x354f5b)[_0x574d('0x35')](0x0,!![])[_0x574d('0x19')](0x17,_0x574d('0x37'))[_0x574d('0x19')](0x3b,'minutes')[_0x574d('0x19')](0x3b,_0x574d('0x38'))[_0x574d('0x36')]();}_0x120696={'start':_0x2d88bd,'end':_0x354f5b};break;default:_0x120696[_0x574d('0x32')]=_0x2d88bd;break;}return _0x120696;}
\ No newline at end of file
+var _0x9433=['operator','$between','value','includes','$gt','$lte','days','format','YYYY-MM-DD','castTo','CAST(','field','\x20AS\x20','text','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','NOT\x20IN\x20?','<>\x20?','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','<=\x20?','$gte','BETWEEN\x20?\x20AND\x20?','start','$substring','pop','DATE','utcOffset','add','hours','lodash','startsWith','[$or]','replace','[$and]','split','length','forEach','shift','match','filter','indexOf','map','conditions','push','$eq'];(function(_0x864a12,_0x25ba1e){var _0x2af0b1=function(_0xb64868){while(--_0xb64868){_0x864a12['push'](_0x864a12['shift']());}};_0x2af0b1(++_0x25ba1e);}(_0x9433,0xc0));var _0x3943=function(_0x1fbc1c,_0x3e353f){_0x1fbc1c=_0x1fbc1c-0x0;var _0x43f984=_0x9433[_0x1fbc1c];return _0x43f984;};'use strict';var _=require(_0x3943('0x0'));var moment=require('moment');exports['parseSearch']=function(_0x394d6a){var _0x18e6eb={'conditions':[]};_0x18e6eb['sqlOperator']=_[_0x3943('0x1')](_0x394d6a,_0x3943('0x2'))?'or':'and';var _0x2ba547=_0x394d6a[_0x3943('0x3')](_0x3943('0x4'),'')[_0x3943('0x3')](_0x3943('0x2'),'')[_0x3943('0x5')]('||');for(var _0x3c08bf=0x0;_0x3c08bf<_0x2ba547[_0x3943('0x6')];_0x3c08bf++){var _0x28b19e=_0x2ba547[_0x3c08bf][_0x3943('0x5')](':=');var _0x26af98=_0x28b19e[0x0];var _0x40ea77=_0x28b19e['slice'](0x1);_0x40ea77[_0x3943('0x7')](function(_0x301bd2){var _0x425635=_0x301bd2[_0x3943('0x5')]('[')[_0x3943('0x8')]();var _0x8cdf98=_0x301bd2[_0x3943('0x9')](/\[(.*?)\]/g);_0x8cdf98[_0x3943('0x7')](function(_0x5ea439){var _0x2888c7=_0x5ea439[_0x3943('0x5')]('[')[_0x3943('0xa')](function(_0x223fb4){return _0x223fb4[_0x3943('0xb')](']')>-0x1;})[_0x3943('0xc')](function(_0x5cd9b5){return _0x5cd9b5[_0x3943('0x5')](']')[0x0];})[0x0];_0x18e6eb[_0x3943('0xd')][_0x3943('0xe')]({'field':_0x26af98,'operator':_0x425635,'value':_0x2888c7});});});}return _0x18e6eb;};exports['buildExpression']=function(_0x4cf390,_0x557934,_0x5011c7){var _0x581e8c={};if(_0x557934==='DATE'){if(_0x5011c7['operator']===_0x3943('0xf')){_0x5011c7[_0x3943('0x10')]=_0x3943('0x11');_0x5011c7['value']+=','+_0x5011c7[_0x3943('0x12')];}else if(_[_0x3943('0x13')]([_0x3943('0x14'),_0x3943('0x15')],_0x5011c7[_0x3943('0x10')])){_0x5011c7[_0x3943('0x12')]=moment(_0x5011c7['value'])['add'](0x1,_0x3943('0x16'))[_0x3943('0x17')](_0x3943('0x18'));}}if(_0x5011c7[_0x3943('0x19')]){_0x557934=_0x5011c7[_0x3943('0x19')];_0x581e8c['text']=_0x3943('0x1a')+_0x4cf390+'.'+_0x5011c7[_0x3943('0x1b')]+_0x3943('0x1c')+_0x5011c7['castTo']+')\x20'+parseOperator(_0x5011c7['operator']);}else{_0x581e8c[_0x3943('0x1d')]=_0x4cf390+'.'+_0x5011c7['field']+'\x20'+parseOperator(_0x5011c7['operator']);}if(_[_0x3943('0x13')]([_0x3943('0x1e'),_0x3943('0x1f')],_0x5011c7[_0x3943('0x10')]))_0x581e8c[_0x3943('0x1d')]='('+_0x581e8c[_0x3943('0x1d')]+_0x3943('0x20')+_0x4cf390+'.'+_0x5011c7[_0x3943('0x1b')]+_0x3943('0x21');_0x581e8c[_0x3943('0x12')]=parseValue(_0x557934,_0x5011c7['operator'],_0x5011c7[_0x3943('0x12')]);return _0x581e8c;};function parseOperator(_0x16a31d){var _0x47e82d;switch(_0x16a31d){case _0x3943('0x22'):_0x47e82d='IN\x20?';break;case _0x3943('0x1f'):_0x47e82d=_0x3943('0x23');break;case'$eq':_0x47e82d='=\x20?';break;case'$ne':_0x47e82d=_0x3943('0x24');break;case'$substring':case _0x3943('0x25'):case _0x3943('0x26'):_0x47e82d=_0x3943('0x27');break;case _0x3943('0x28'):_0x47e82d=_0x3943('0x29');break;case _0x3943('0x14'):_0x47e82d='>\x20?';break;case _0x3943('0x15'):_0x47e82d=_0x3943('0x2a');break;case _0x3943('0x2b'):_0x47e82d='>=\x20?';break;case _0x3943('0x11'):_0x47e82d=_0x3943('0x2c');break;}return _0x47e82d;}function parseValue(_0x508ef9,_0x4ba363,_0x19d1dc){var _0x158760={'start':undefined,'end':undefined};switch(_0x4ba363){case'$in':case _0x3943('0x1f'):_0x158760[_0x3943('0x2d')]=_0x19d1dc['split'](',');break;case _0x3943('0x2e'):_0x158760[_0x3943('0x2d')]='%'+_0x19d1dc+'%';break;case'$startsWith':_0x158760[_0x3943('0x2d')]=_0x19d1dc+'%';break;case _0x3943('0x26'):_0x158760[_0x3943('0x2d')]='%'+_0x19d1dc;break;case _0x3943('0x11'):var _0x1cf1dd=_0x19d1dc['split'](',');var _0x19d1dc=_0x1cf1dd[_0x3943('0x8')]();var _0x579ddb=_0x1cf1dd[_0x3943('0x2f')]();if(_0x508ef9===_0x3943('0x30')){_0x19d1dc=moment(_0x19d1dc)[_0x3943('0x31')](0x0,!![])['format']();_0x579ddb=moment(_0x579ddb)['utcOffset'](0x0,!![])[_0x3943('0x32')](0x17,_0x3943('0x33'))[_0x3943('0x32')](0x3b,'minutes')[_0x3943('0x32')](0x3b,'seconds')['format']();}_0x158760={'start':_0x19d1dc,'end':_0x579ddb};break;default:_0x158760[_0x3943('0x2d')]=_0x19d1dc;break;}return _0x158760;}
\ No newline at end of file