Built motion from commit 52c8a02d.|2.6.29
[motion2.git] / server / components / parsers / advancedSearch.js
index df8f4c1..5732b8b 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 _0xa229=['conditions','push','buildExpression','$eq','value','includes','$gt','operator','add','days','YYYY-MM-DD','castTo','text','CAST(','field','$ne','$notIn','\x20IS\x20NULL)','IN\x20?','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','$between','pop','DATE','utcOffset','format','hours','minutes','seconds','lodash','moment','sqlOperator','[$or]','and','replace','[$and]','split','length','slice','shift','match','filter','indexOf','map'];(function(_0x5bb648,_0x4a6cdb){var _0x40d1eb=function(_0x447db){while(--_0x447db){_0x5bb648['push'](_0x5bb648['shift']());}};_0x40d1eb(++_0x4a6cdb);}(_0xa229,0x179));var _0x9a22=function(_0x321bb2,_0x202794){_0x321bb2=_0x321bb2-0x0;var _0x9c12ed=_0xa229[_0x321bb2];return _0x9c12ed;};'use strict';var _=require(_0x9a22('0x0'));var moment=require(_0x9a22('0x1'));exports['parseSearch']=function(_0x5abb38){var _0x258bba={'conditions':[]};_0x258bba[_0x9a22('0x2')]=_['startsWith'](_0x5abb38,_0x9a22('0x3'))?'or':_0x9a22('0x4');var _0x113c91=_0x5abb38[_0x9a22('0x5')](_0x9a22('0x6'),'')[_0x9a22('0x5')](_0x9a22('0x3'),'')[_0x9a22('0x7')]('||');for(var _0xefd803=0x0;_0xefd803<_0x113c91[_0x9a22('0x8')];_0xefd803++){var _0x32c17d=_0x113c91[_0xefd803][_0x9a22('0x7')](':=');var _0x44969d=_0x32c17d[0x0];var _0x2d0901=_0x32c17d[_0x9a22('0x9')](0x1);_0x2d0901['forEach'](function(_0x3d868c){var _0x592475=_0x3d868c[_0x9a22('0x7')]('[')[_0x9a22('0xa')]();var _0x2f2c23=_0x3d868c[_0x9a22('0xb')](/\[(.*?)\]/g);_0x2f2c23['forEach'](function(_0x2722ef){var _0x3044f1=_0x2722ef[_0x9a22('0x7')]('[')[_0x9a22('0xc')](function(_0x263990){return _0x263990[_0x9a22('0xd')](']')>-0x1;})[_0x9a22('0xe')](function(_0x3be942){return _0x3be942[_0x9a22('0x7')](']')[0x0];})[0x0];_0x258bba[_0x9a22('0xf')][_0x9a22('0x10')]({'field':_0x44969d,'operator':_0x592475,'value':_0x3044f1});});});}return _0x258bba;};exports[_0x9a22('0x11')]=function(_0x1297d3,_0x5c084d,_0x34d3e5){var _0x38e541={};if(_0x5c084d==='DATE'){if(_0x34d3e5['operator']===_0x9a22('0x12')){_0x34d3e5['operator']='$between';_0x34d3e5[_0x9a22('0x13')]+=','+_0x34d3e5[_0x9a22('0x13')];}else if(_[_0x9a22('0x14')]([_0x9a22('0x15'),'$lte'],_0x34d3e5[_0x9a22('0x16')])){_0x34d3e5['value']=moment(_0x34d3e5[_0x9a22('0x13')])[_0x9a22('0x17')](0x1,_0x9a22('0x18'))['format'](_0x9a22('0x19'));}}if(_0x34d3e5[_0x9a22('0x1a')]){_0x5c084d=_0x34d3e5[_0x9a22('0x1a')];_0x38e541[_0x9a22('0x1b')]=_0x9a22('0x1c')+_0x1297d3+'.'+_0x34d3e5[_0x9a22('0x1d')]+'\x20AS\x20'+_0x34d3e5[_0x9a22('0x1a')]+')\x20'+parseOperator(_0x34d3e5[_0x9a22('0x16')]);}else{_0x38e541[_0x9a22('0x1b')]=_0x1297d3+'.'+_0x34d3e5['field']+'\x20'+parseOperator(_0x34d3e5['operator']);}if(_[_0x9a22('0x14')]([_0x9a22('0x1e'),_0x9a22('0x1f')],_0x34d3e5['operator']))_0x38e541[_0x9a22('0x1b')]='('+_0x38e541[_0x9a22('0x1b')]+'\x20OR\x20'+_0x1297d3+'.'+_0x34d3e5[_0x9a22('0x1d')]+_0x9a22('0x20');_0x38e541[_0x9a22('0x13')]=parseValue(_0x5c084d,_0x34d3e5[_0x9a22('0x16')],_0x34d3e5['value']);return _0x38e541;};function parseOperator(_0x3a09f1){var _0x489159;switch(_0x3a09f1){case'$in':_0x489159=_0x9a22('0x21');break;case'$notIn':_0x489159=_0x9a22('0x22');break;case _0x9a22('0x12'):_0x489159=_0x9a22('0x23');break;case _0x9a22('0x1e'):_0x489159=_0x9a22('0x24');break;case _0x9a22('0x25'):case _0x9a22('0x26'):case _0x9a22('0x27'):_0x489159=_0x9a22('0x28');break;case'$lt':_0x489159=_0x9a22('0x29');break;case _0x9a22('0x15'):_0x489159=_0x9a22('0x2a');break;case'$lte':_0x489159=_0x9a22('0x2b');break;case _0x9a22('0x2c'):_0x489159=_0x9a22('0x2d');break;case'$between':_0x489159=_0x9a22('0x2e');break;}return _0x489159;}function parseValue(_0x1a4b31,_0x300326,_0x4b815d){var _0x32c5ad={'start':undefined,'end':undefined};switch(_0x300326){case'$in':case'$notIn':_0x32c5ad[_0x9a22('0x2f')]=_0x4b815d[_0x9a22('0x7')](',');break;case _0x9a22('0x25'):_0x32c5ad[_0x9a22('0x2f')]='%'+_0x4b815d+'%';break;case'$startsWith':_0x32c5ad[_0x9a22('0x2f')]=_0x4b815d+'%';break;case'$endsWith':_0x32c5ad['start']='%'+_0x4b815d;break;case _0x9a22('0x30'):var _0x635598=_0x4b815d[_0x9a22('0x7')](',');var _0x4b815d=_0x635598[_0x9a22('0xa')]();var _0x3e98e1=_0x635598[_0x9a22('0x31')]();if(_0x1a4b31===_0x9a22('0x32')){_0x4b815d=moment(_0x4b815d)[_0x9a22('0x33')](0x0,!![])[_0x9a22('0x34')]();_0x3e98e1=moment(_0x3e98e1)[_0x9a22('0x33')](0x0,!![])['add'](0x17,_0x9a22('0x35'))[_0x9a22('0x17')](0x3b,_0x9a22('0x36'))[_0x9a22('0x17')](0x3b,_0x9a22('0x37'))[_0x9a22('0x34')]();}_0x32c5ad={'start':_0x4b815d,'end':_0x3e98e1};break;default:_0x32c5ad[_0x9a22('0x2f')]=_0x4b815d;break;}return _0x32c5ad;}
\ No newline at end of file