Built motion from commit 449495f6.|2.6.27
[motion2.git] / server / components / parsers / advancedSearch.js
index 455bdaf..6ef41bf 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x14d6=['filter','indexOf','conditions','operator','value','$lte','add','days','format','castTo','\x20AS\x20','text','field','includes','$ne','$in','IN\x20?','$notIn','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','$gt','>\x20?','$gte','start','$between','pop','DATE','utcOffset','minutes','lodash','moment','parseSearch','startsWith','[$or]','and','replace','split','length','forEach','shift'];(function(_0x4c8ef7,_0x24c4c0){var _0x5b785f=function(_0x32e0e3){while(--_0x32e0e3){_0x4c8ef7['push'](_0x4c8ef7['shift']());}};_0x5b785f(++_0x24c4c0);}(_0x14d6,0x7c));var _0x614d=function(_0x4c23cc,_0x46193e){_0x4c23cc=_0x4c23cc-0x0;var _0x1b1dc2=_0x14d6[_0x4c23cc];return _0x1b1dc2;};'use strict';var _=require(_0x614d('0x0'));var moment=require(_0x614d('0x1'));exports[_0x614d('0x2')]=function(_0x5969a1){var _0x5722e1={'conditions':[]};_0x5722e1['sqlOperator']=_[_0x614d('0x3')](_0x5969a1,_0x614d('0x4'))?'or':_0x614d('0x5');var _0x2e02d8=_0x5969a1[_0x614d('0x6')]('[$and]','')[_0x614d('0x6')](_0x614d('0x4'),'')[_0x614d('0x7')]('||');for(var _0x2b71c9=0x0;_0x2b71c9<_0x2e02d8[_0x614d('0x8')];_0x2b71c9++){var _0x5d906e=_0x2e02d8[_0x2b71c9][_0x614d('0x7')](':=');var _0x1c6077=_0x5d906e[0x0];var _0x157079=_0x5d906e['slice'](0x1);_0x157079[_0x614d('0x9')](function(_0x1fcdbf){var _0xfdaa77=_0x1fcdbf['split']('[')[_0x614d('0xa')]();var _0xbac184=_0x1fcdbf['match'](/\[(.*?)\]/g);_0xbac184[_0x614d('0x9')](function(_0x1bda1f){var _0xf97eaf=_0x1bda1f[_0x614d('0x7')]('[')[_0x614d('0xb')](function(_0x387ead){return _0x387ead[_0x614d('0xc')](']')>-0x1;})['map'](function(_0x2368d2){return _0x2368d2[_0x614d('0x7')](']')[0x0];})[0x0];_0x5722e1[_0x614d('0xd')]['push']({'field':_0x1c6077,'operator':_0xfdaa77,'value':_0xf97eaf});});});}return _0x5722e1;};exports['buildExpression']=function(_0x214ede,_0x302a8c,_0x32aa28){var _0x476d47={};if(_0x302a8c==='DATE'){if(_0x32aa28['operator']==='$eq'){_0x32aa28[_0x614d('0xe')]='$between';_0x32aa28[_0x614d('0xf')]+=','+_0x32aa28[_0x614d('0xf')];}else if(_['includes'](['$gt',_0x614d('0x10')],_0x32aa28[_0x614d('0xe')])){_0x32aa28[_0x614d('0xf')]=moment(_0x32aa28['value'])[_0x614d('0x11')](0x1,_0x614d('0x12'))[_0x614d('0x13')]('YYYY-MM-DD');}}if(_0x32aa28['castTo']){_0x302a8c=_0x32aa28[_0x614d('0x14')];_0x476d47['text']='CAST('+_0x214ede+'.'+_0x32aa28['field']+_0x614d('0x15')+_0x32aa28[_0x614d('0x14')]+')\x20'+parseOperator(_0x32aa28[_0x614d('0xe')]);}else{_0x476d47[_0x614d('0x16')]=_0x214ede+'.'+_0x32aa28[_0x614d('0x17')]+'\x20'+parseOperator(_0x32aa28[_0x614d('0xe')]);}if(_[_0x614d('0x18')]([_0x614d('0x19'),'$notIn'],_0x32aa28[_0x614d('0xe')]))_0x476d47[_0x614d('0x16')]='('+_0x476d47[_0x614d('0x16')]+'\x20OR\x20'+_0x214ede+'.'+_0x32aa28['field']+'\x20IS\x20NULL)';_0x476d47[_0x614d('0xf')]=parseValue(_0x302a8c,_0x32aa28[_0x614d('0xe')],_0x32aa28['value']);return _0x476d47;};function parseOperator(_0x332a50){var _0x321752;switch(_0x332a50){case _0x614d('0x1a'):_0x321752=_0x614d('0x1b');break;case _0x614d('0x1c'):_0x321752='NOT\x20IN\x20?';break;case'$eq':_0x321752=_0x614d('0x1d');break;case'$ne':_0x321752=_0x614d('0x1e');break;case _0x614d('0x1f'):case _0x614d('0x20'):case _0x614d('0x21'):_0x321752=_0x614d('0x22');break;case'$lt':_0x321752=_0x614d('0x23');break;case _0x614d('0x24'):_0x321752=_0x614d('0x25');break;case _0x614d('0x10'):_0x321752='<=\x20?';break;case _0x614d('0x26'):_0x321752='>=\x20?';break;case'$between':_0x321752='BETWEEN\x20?\x20AND\x20?';break;}return _0x321752;}function parseValue(_0x20260e,_0x4ce764,_0x2ed6af){var _0x4d9a39={'start':undefined,'end':undefined};switch(_0x4ce764){case'$in':case _0x614d('0x1c'):_0x4d9a39['start']=_0x2ed6af['split'](',');break;case _0x614d('0x1f'):_0x4d9a39[_0x614d('0x27')]='%'+_0x2ed6af+'%';break;case'$startsWith':_0x4d9a39[_0x614d('0x27')]=_0x2ed6af+'%';break;case'$endsWith':_0x4d9a39['start']='%'+_0x2ed6af;break;case _0x614d('0x28'):var _0x3a081f=_0x2ed6af['split'](',');var _0x2ed6af=_0x3a081f[_0x614d('0xa')]();var _0x39b424=_0x3a081f[_0x614d('0x29')]();if(_0x20260e===_0x614d('0x2a')){_0x2ed6af=moment(_0x2ed6af)[_0x614d('0x2b')](0x0,!![])['format']();_0x39b424=moment(_0x39b424)[_0x614d('0x2b')](0x0,!![])['add'](0x17,'hours')[_0x614d('0x11')](0x3b,_0x614d('0x2c'))['add'](0x3b,'seconds')[_0x614d('0x13')]();}_0x4d9a39={'start':_0x2ed6af,'end':_0x39b424};break;default:_0x4d9a39[_0x614d('0x27')]=_0x2ed6af;break;}return _0x4d9a39;}
\ No newline at end of file
+var _0xeaca=['$substring','start','utcOffset','hours','seconds','lodash','moment','sqlOperator','startsWith','and','replace','[$and]','[$or]','split','length','slice','forEach','shift','match','filter','indexOf','map','conditions','push','buildExpression','DATE','operator','$eq','value','$gt','$lte','add','days','format','YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','includes','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','$startsWith','$endsWith','$lt','<\x20?','<=\x20?','$gte','>=\x20?','$between'];(function(_0x5cc8b9,_0x20e3c3){var _0x58892e=function(_0x87457a){while(--_0x87457a){_0x5cc8b9['push'](_0x5cc8b9['shift']());}};_0x58892e(++_0x20e3c3);}(_0xeaca,0xad));var _0xaeac=function(_0x10d367,_0x31a35c){_0x10d367=_0x10d367-0x0;var _0x541332=_0xeaca[_0x10d367];return _0x541332;};'use strict';var _=require(_0xaeac('0x0'));var moment=require(_0xaeac('0x1'));exports['parseSearch']=function(_0x267bfe){var _0x4d41cd={'conditions':[]};_0x4d41cd[_0xaeac('0x2')]=_[_0xaeac('0x3')](_0x267bfe,'[$or]')?'or':_0xaeac('0x4');var _0x10c5cb=_0x267bfe[_0xaeac('0x5')](_0xaeac('0x6'),'')[_0xaeac('0x5')](_0xaeac('0x7'),'')[_0xaeac('0x8')]('||');for(var _0x5b4f3e=0x0;_0x5b4f3e<_0x10c5cb[_0xaeac('0x9')];_0x5b4f3e++){var _0x10735e=_0x10c5cb[_0x5b4f3e]['split'](':=');var _0x2bde7a=_0x10735e[0x0];var _0x2ab8ff=_0x10735e[_0xaeac('0xa')](0x1);_0x2ab8ff[_0xaeac('0xb')](function(_0x13174c){var _0x2376d0=_0x13174c[_0xaeac('0x8')]('[')[_0xaeac('0xc')]();var _0x1a7e11=_0x13174c[_0xaeac('0xd')](/\[(.*?)\]/g);_0x1a7e11[_0xaeac('0xb')](function(_0x49fc91){var _0x18f61f=_0x49fc91[_0xaeac('0x8')]('[')[_0xaeac('0xe')](function(_0x4b11df){return _0x4b11df[_0xaeac('0xf')](']')>-0x1;})[_0xaeac('0x10')](function(_0x80500){return _0x80500['split'](']')[0x0];})[0x0];_0x4d41cd[_0xaeac('0x11')][_0xaeac('0x12')]({'field':_0x2bde7a,'operator':_0x2376d0,'value':_0x18f61f});});});}return _0x4d41cd;};exports[_0xaeac('0x13')]=function(_0x37f866,_0x36ee18,_0x3af13d){var _0x6d400f={};if(_0x36ee18===_0xaeac('0x14')){if(_0x3af13d[_0xaeac('0x15')]===_0xaeac('0x16')){_0x3af13d['operator']='$between';_0x3af13d[_0xaeac('0x17')]+=','+_0x3af13d[_0xaeac('0x17')];}else if(_['includes']([_0xaeac('0x18'),_0xaeac('0x19')],_0x3af13d[_0xaeac('0x15')])){_0x3af13d[_0xaeac('0x17')]=moment(_0x3af13d['value'])[_0xaeac('0x1a')](0x1,_0xaeac('0x1b'))[_0xaeac('0x1c')](_0xaeac('0x1d'));}}if(_0x3af13d[_0xaeac('0x1e')]){_0x36ee18=_0x3af13d['castTo'];_0x6d400f[_0xaeac('0x1f')]=_0xaeac('0x20')+_0x37f866+'.'+_0x3af13d[_0xaeac('0x21')]+_0xaeac('0x22')+_0x3af13d[_0xaeac('0x1e')]+')\x20'+parseOperator(_0x3af13d['operator']);}else{_0x6d400f['text']=_0x37f866+'.'+_0x3af13d['field']+'\x20'+parseOperator(_0x3af13d['operator']);}if(_[_0xaeac('0x23')]([_0xaeac('0x24'),_0xaeac('0x25')],_0x3af13d[_0xaeac('0x15')]))_0x6d400f[_0xaeac('0x1f')]='('+_0x6d400f['text']+_0xaeac('0x26')+_0x37f866+'.'+_0x3af13d['field']+_0xaeac('0x27');_0x6d400f[_0xaeac('0x17')]=parseValue(_0x36ee18,_0x3af13d[_0xaeac('0x15')],_0x3af13d[_0xaeac('0x17')]);return _0x6d400f;};function parseOperator(_0x3f3d6a){var _0x4b3141;switch(_0x3f3d6a){case _0xaeac('0x28'):_0x4b3141=_0xaeac('0x29');break;case _0xaeac('0x25'):_0x4b3141=_0xaeac('0x2a');break;case _0xaeac('0x16'):_0x4b3141='=\x20?';break;case _0xaeac('0x24'):_0x4b3141='<>\x20?';break;case'$substring':case _0xaeac('0x2b'):case _0xaeac('0x2c'):_0x4b3141='LIKE\x20?';break;case _0xaeac('0x2d'):_0x4b3141=_0xaeac('0x2e');break;case _0xaeac('0x18'):_0x4b3141='>\x20?';break;case _0xaeac('0x19'):_0x4b3141=_0xaeac('0x2f');break;case _0xaeac('0x30'):_0x4b3141=_0xaeac('0x31');break;case _0xaeac('0x32'):_0x4b3141='BETWEEN\x20?\x20AND\x20?';break;}return _0x4b3141;}function parseValue(_0x5db087,_0x4bd849,_0x53e419){var _0x18a62a={'start':undefined,'end':undefined};switch(_0x4bd849){case _0xaeac('0x28'):case _0xaeac('0x25'):_0x18a62a['start']=_0x53e419[_0xaeac('0x8')](',');break;case _0xaeac('0x33'):_0x18a62a['start']='%'+_0x53e419+'%';break;case _0xaeac('0x2b'):_0x18a62a[_0xaeac('0x34')]=_0x53e419+'%';break;case'$endsWith':_0x18a62a['start']='%'+_0x53e419;break;case _0xaeac('0x32'):var _0x22a774=_0x53e419[_0xaeac('0x8')](',');var _0x53e419=_0x22a774[_0xaeac('0xc')]();var _0x2eb076=_0x22a774['pop']();if(_0x5db087===_0xaeac('0x14')){_0x53e419=moment(_0x53e419)[_0xaeac('0x35')](0x0,!![])['format']();_0x2eb076=moment(_0x2eb076)[_0xaeac('0x35')](0x0,!![])[_0xaeac('0x1a')](0x17,_0xaeac('0x36'))[_0xaeac('0x1a')](0x3b,'minutes')['add'](0x3b,_0xaeac('0x37'))['format']();}_0x18a62a={'start':_0x53e419,'end':_0x2eb076};break;default:_0x18a62a[_0xaeac('0x34')]=_0x53e419;break;}return _0x18a62a;}
\ No newline at end of file