Built motion from commit 449495f6.|2.6.27
[motion2.git] / server / components / parsers / advancedSearch.js
index df8f4c1..6ef41bf 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x294b=['$lt','>\x20?','$lte','>=\x20?','start','$endsWith','shift','pop','utcOffset','minutes','seconds','moment','startsWith','[$or]','and','[$and]','replace','split','length','forEach','match','map','conditions','push','buildExpression','DATE','operator','$eq','$between','includes','$gt','value','add','days','castTo','field','\x20AS\x20','text','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','=\x20?','$ne','<>\x20?','$substring','$startsWith','LIKE\x20?'];(function(_0x13962c,_0x18e542){var _0x24abef=function(_0x20fc83){while(--_0x20fc83){_0x13962c['push'](_0x13962c['shift']());}};_0x24abef(++_0x18e542);}(_0x294b,0x105));var _0xb294=function(_0x3dd15e,_0x1f0015){_0x3dd15e=_0x3dd15e-0x0;var _0x231fd0=_0x294b[_0x3dd15e];return _0x231fd0;};'use strict';var _=require('lodash');var moment=require(_0xb294('0x0'));exports['parseSearch']=function(_0x150689){var _0x29d44e={'conditions':[]};_0x29d44e['sqlOperator']=_[_0xb294('0x1')](_0x150689,_0xb294('0x2'))?'or':_0xb294('0x3');var _0x4e77d0=_0x150689['replace'](_0xb294('0x4'),'')[_0xb294('0x5')]('[$or]','')[_0xb294('0x6')]('||');for(var _0x538606=0x0;_0x538606<_0x4e77d0[_0xb294('0x7')];_0x538606++){var _0x1c90aa=_0x4e77d0[_0x538606]['split'](':=');var _0x102c62=_0x1c90aa[0x0];var _0x19a567=_0x1c90aa['slice'](0x1);_0x19a567[_0xb294('0x8')](function(_0x3b12b2){var _0x11be0a=_0x3b12b2[_0xb294('0x6')]('[')['shift']();var _0x1cd2bd=_0x3b12b2[_0xb294('0x9')](/\[(.*?)\]/g);_0x1cd2bd['forEach'](function(_0x18df6c){var _0x113176=_0x18df6c[_0xb294('0x6')]('[')['filter'](function(_0x3a05cd){return _0x3a05cd['indexOf'](']')>-0x1;})[_0xb294('0xa')](function(_0x4f6ab3){return _0x4f6ab3['split'](']')[0x0];})[0x0];_0x29d44e[_0xb294('0xb')][_0xb294('0xc')]({'field':_0x102c62,'operator':_0x11be0a,'value':_0x113176});});});}return _0x29d44e;};exports[_0xb294('0xd')]=function(_0x53320e,_0x439b34,_0x58b847){var _0x1e1dfe={};if(_0x439b34===_0xb294('0xe')){if(_0x58b847[_0xb294('0xf')]===_0xb294('0x10')){_0x58b847[_0xb294('0xf')]=_0xb294('0x11');_0x58b847['value']+=','+_0x58b847['value'];}else if(_[_0xb294('0x12')]([_0xb294('0x13'),'$lte'],_0x58b847['operator'])){_0x58b847[_0xb294('0x14')]=moment(_0x58b847[_0xb294('0x14')])[_0xb294('0x15')](0x1,_0xb294('0x16'))['format']('YYYY-MM-DD');}}if(_0x58b847[_0xb294('0x17')]){_0x439b34=_0x58b847['castTo'];_0x1e1dfe['text']='CAST('+_0x53320e+'.'+_0x58b847[_0xb294('0x18')]+_0xb294('0x19')+_0x58b847[_0xb294('0x17')]+')\x20'+parseOperator(_0x58b847[_0xb294('0xf')]);}else{_0x1e1dfe[_0xb294('0x1a')]=_0x53320e+'.'+_0x58b847[_0xb294('0x18')]+'\x20'+parseOperator(_0x58b847[_0xb294('0xf')]);}if(_[_0xb294('0x12')](['$ne',_0xb294('0x1b')],_0x58b847['operator']))_0x1e1dfe['text']='('+_0x1e1dfe[_0xb294('0x1a')]+_0xb294('0x1c')+_0x53320e+'.'+_0x58b847[_0xb294('0x18')]+_0xb294('0x1d');_0x1e1dfe[_0xb294('0x14')]=parseValue(_0x439b34,_0x58b847[_0xb294('0xf')],_0x58b847[_0xb294('0x14')]);return _0x1e1dfe;};function parseOperator(_0x132d2d){var _0x197dbc;switch(_0x132d2d){case _0xb294('0x1e'):_0x197dbc=_0xb294('0x1f');break;case'$notIn':_0x197dbc=_0xb294('0x20');break;case _0xb294('0x10'):_0x197dbc=_0xb294('0x21');break;case _0xb294('0x22'):_0x197dbc=_0xb294('0x23');break;case _0xb294('0x24'):case _0xb294('0x25'):case'$endsWith':_0x197dbc=_0xb294('0x26');break;case _0xb294('0x27'):_0x197dbc='<\x20?';break;case'$gt':_0x197dbc=_0xb294('0x28');break;case _0xb294('0x29'):_0x197dbc='<=\x20?';break;case'$gte':_0x197dbc=_0xb294('0x2a');break;case _0xb294('0x11'):_0x197dbc='BETWEEN\x20?\x20AND\x20?';break;}return _0x197dbc;}function parseValue(_0x58be8b,_0x3f95f1,_0x5888da){var _0x241590={'start':undefined,'end':undefined};switch(_0x3f95f1){case'$in':case _0xb294('0x1b'):_0x241590[_0xb294('0x2b')]=_0x5888da[_0xb294('0x6')](',');break;case _0xb294('0x24'):_0x241590[_0xb294('0x2b')]='%'+_0x5888da+'%';break;case _0xb294('0x25'):_0x241590[_0xb294('0x2b')]=_0x5888da+'%';break;case _0xb294('0x2c'):_0x241590['start']='%'+_0x5888da;break;case _0xb294('0x11'):var _0x132b30=_0x5888da[_0xb294('0x6')](',');var _0x5888da=_0x132b30[_0xb294('0x2d')]();var _0x3f57cd=_0x132b30[_0xb294('0x2e')]();if(_0x58be8b===_0xb294('0xe')){_0x5888da=moment(_0x5888da)[_0xb294('0x2f')](0x0,!![])['format']();_0x3f57cd=moment(_0x3f57cd)['utcOffset'](0x0,!![])[_0xb294('0x15')](0x17,'hours')[_0xb294('0x15')](0x3b,_0xb294('0x30'))[_0xb294('0x15')](0x3b,_0xb294('0x31'))['format']();}_0x241590={'start':_0x5888da,'end':_0x3f57cd};break;default:_0x241590[_0xb294('0x2b')]=_0x5888da;break;}return _0x241590;}
\ 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