Built motion from commit 85328c08.|2.5.50
[motion2.git] / server / components / parsers / advancedSearch.js
index 9b23fa4..deffe60 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x289f=['LIKE\x20?','$lt','<\x20?','<=\x20?','$gte','>=\x20?','start','shift','pop','hours','lodash','moment','parseSearch','sqlOperator','startsWith','replace','[$and]','[$or]','split','length','match','forEach','indexOf','map','conditions','buildExpression','DATE','operator','$between','value','includes','$lte','add','days','format','YYYY-MM-DD','castTo','CAST(','text','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','$eq','$substring','$startsWith','$endsWith'];(function(_0x52cbc6,_0x3a9e07){var _0x5b7ee5=function(_0x5caebb){while(--_0x5caebb){_0x52cbc6['push'](_0x52cbc6['shift']());}};_0x5b7ee5(++_0x3a9e07);}(_0x289f,0x1d5));var _0xf289=function(_0x40220a,_0x22feb1){_0x40220a=_0x40220a-0x0;var _0x3903cc=_0x289f[_0x40220a];return _0x3903cc;};'use strict';var _=require(_0xf289('0x0'));var moment=require(_0xf289('0x1'));exports[_0xf289('0x2')]=function(_0x18c6aa){var _0x4c722c={'conditions':[]};_0x4c722c[_0xf289('0x3')]=_[_0xf289('0x4')](_0x18c6aa,'[$or]')?'or':'and';var _0x4410c0=_0x18c6aa[_0xf289('0x5')](_0xf289('0x6'),'')[_0xf289('0x5')](_0xf289('0x7'),'')[_0xf289('0x8')]('||');for(var _0x48c500=0x0;_0x48c500<_0x4410c0[_0xf289('0x9')];_0x48c500++){var _0x1fdb00=_0x4410c0[_0x48c500]['split'](':=');var _0xec8124=_0x1fdb00[0x0];var _0x4cd307=_0x1fdb00['slice'](0x1);_0x4cd307['forEach'](function(_0x208bdc){var _0x3f8911=_0x208bdc['split']('[')['shift']();var _0x58c684=_0x208bdc[_0xf289('0xa')](/\[(.*?)\]/g);_0x58c684[_0xf289('0xb')](function(_0x1d5649){var _0x2664aa=_0x1d5649[_0xf289('0x8')]('[')['filter'](function(_0x45631c){return _0x45631c[_0xf289('0xc')](']')>-0x1;})[_0xf289('0xd')](function(_0x2832d6){return _0x2832d6[_0xf289('0x8')](']')[0x0];})[0x0];_0x4c722c[_0xf289('0xe')]['push']({'field':_0xec8124,'operator':_0x3f8911,'value':_0x2664aa});});});}return _0x4c722c;};exports[_0xf289('0xf')]=function(_0x2cff8d,_0x2ee8a3,_0x58b2ea){var _0x3a3462={};if(_0x2ee8a3===_0xf289('0x10')){if(_0x58b2ea[_0xf289('0x11')]==='$eq'){_0x58b2ea['operator']=_0xf289('0x12');_0x58b2ea[_0xf289('0x13')]+=','+_0x58b2ea[_0xf289('0x13')];}else if(_[_0xf289('0x14')](['$gt',_0xf289('0x15')],_0x58b2ea[_0xf289('0x11')])){_0x58b2ea[_0xf289('0x13')]=moment(_0x58b2ea[_0xf289('0x13')])[_0xf289('0x16')](0x1,_0xf289('0x17'))[_0xf289('0x18')](_0xf289('0x19'));}}if(_0x58b2ea[_0xf289('0x1a')]){_0x2ee8a3=_0x58b2ea[_0xf289('0x1a')];_0x3a3462['text']=_0xf289('0x1b')+_0x2cff8d+'.'+_0x58b2ea['field']+'\x20AS\x20'+_0x58b2ea[_0xf289('0x1a')]+')\x20'+parseOperator(_0x58b2ea[_0xf289('0x11')]);}else{_0x3a3462[_0xf289('0x1c')]=_0x2cff8d+'.'+_0x58b2ea[_0xf289('0x1d')]+'\x20'+parseOperator(_0x58b2ea['operator']);}if(_[_0xf289('0x14')]([_0xf289('0x1e'),_0xf289('0x1f')],_0x58b2ea[_0xf289('0x11')]))_0x3a3462[_0xf289('0x1c')]='('+_0x3a3462['text']+_0xf289('0x20')+_0x2cff8d+'.'+_0x58b2ea[_0xf289('0x1d')]+_0xf289('0x21');_0x3a3462[_0xf289('0x13')]=parseValue(_0x2ee8a3,_0x58b2ea[_0xf289('0x11')],_0x58b2ea[_0xf289('0x13')]);return _0x3a3462;};function parseOperator(_0x3b1b4b){var _0xbb39ba;switch(_0x3b1b4b){case _0xf289('0x22'):_0xbb39ba=_0xf289('0x23');break;case _0xf289('0x1f'):_0xbb39ba=_0xf289('0x24');break;case _0xf289('0x25'):_0xbb39ba='=\x20?';break;case'$ne':_0xbb39ba='<>\x20?';break;case _0xf289('0x26'):case _0xf289('0x27'):case _0xf289('0x28'):_0xbb39ba=_0xf289('0x29');break;case _0xf289('0x2a'):_0xbb39ba=_0xf289('0x2b');break;case'$gt':_0xbb39ba='>\x20?';break;case _0xf289('0x15'):_0xbb39ba=_0xf289('0x2c');break;case _0xf289('0x2d'):_0xbb39ba=_0xf289('0x2e');break;case'$between':_0xbb39ba='BETWEEN\x20?\x20AND\x20?';break;}return _0xbb39ba;}function parseValue(_0x2fd8ca,_0x3d93d6,_0x5a736c){var _0x806eb={'start':undefined,'end':undefined};switch(_0x3d93d6){case _0xf289('0x22'):case _0xf289('0x1f'):_0x806eb[_0xf289('0x2f')]=_0x5a736c['split'](',');break;case'$substring':_0x806eb[_0xf289('0x2f')]='%'+_0x5a736c+'%';break;case _0xf289('0x27'):_0x806eb[_0xf289('0x2f')]=_0x5a736c+'%';break;case _0xf289('0x28'):_0x806eb[_0xf289('0x2f')]='%'+_0x5a736c;break;case _0xf289('0x12'):var _0x401ea8=_0x5a736c[_0xf289('0x8')](',');var _0x5a736c=_0x401ea8[_0xf289('0x30')]();var _0x3bf84a=_0x401ea8[_0xf289('0x31')]();if(_0x2fd8ca==='DATE'){_0x5a736c=moment(_0x5a736c)['utcOffset'](0x0,!![])[_0xf289('0x18')]();_0x3bf84a=moment(_0x3bf84a)['utcOffset'](0x0,!![])['add'](0x17,_0xf289('0x32'))['add'](0x3b,'minutes')[_0xf289('0x16')](0x3b,'seconds')[_0xf289('0x18')]();}_0x806eb={'start':_0x5a736c,'end':_0x3bf84a};break;default:_0x806eb[_0xf289('0x2f')]=_0x5a736c;break;}return _0x806eb;}
\ No newline at end of file
+var _0x5421=['>\x20?','<=\x20?','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','$endsWith','pop','DATE','utcOffset','format','hours','minutes','seconds','moment','sqlOperator','startsWith','[$or]','and','[$and]','split','length','slice','forEach','shift','match','map','conditions','push','buildExpression','operator','$between','value','includes','$gt','$lte','add','days','castTo','CAST(','field','$notIn','text','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','<>\x20?','$substring','LIKE\x20?','$lt'];(function(_0x4cd685,_0x472697){var _0x37743e=function(_0x238ec8){while(--_0x238ec8){_0x4cd685['push'](_0x4cd685['shift']());}};_0x37743e(++_0x472697);}(_0x5421,0x10c));var _0x1542=function(_0x76faa4,_0x4a8b9c){_0x76faa4=_0x76faa4-0x0;var _0x5cab58=_0x5421[_0x76faa4];return _0x5cab58;};'use strict';var _=require('lodash');var moment=require(_0x1542('0x0'));exports['parseSearch']=function(_0x10c0c4){var _0x4119ef={'conditions':[]};_0x4119ef[_0x1542('0x1')]=_[_0x1542('0x2')](_0x10c0c4,_0x1542('0x3'))?'or':_0x1542('0x4');var _0x5cdc1a=_0x10c0c4['replace'](_0x1542('0x5'),'')['replace'](_0x1542('0x3'),'')[_0x1542('0x6')]('||');for(var _0x1ce0e7=0x0;_0x1ce0e7<_0x5cdc1a[_0x1542('0x7')];_0x1ce0e7++){var _0x11f954=_0x5cdc1a[_0x1ce0e7]['split'](':=');var _0x184dfb=_0x11f954[0x0];var _0x228103=_0x11f954[_0x1542('0x8')](0x1);_0x228103[_0x1542('0x9')](function(_0x335454){var _0x380dfc=_0x335454['split']('[')[_0x1542('0xa')]();var _0x31214c=_0x335454[_0x1542('0xb')](/\[(.*?)\]/g);_0x31214c[_0x1542('0x9')](function(_0x205169){var _0x22cb08=_0x205169[_0x1542('0x6')]('[')['filter'](function(_0x4651fb){return _0x4651fb['indexOf'](']')>-0x1;})[_0x1542('0xc')](function(_0xef4abf){return _0xef4abf[_0x1542('0x6')](']')[0x0];})[0x0];_0x4119ef[_0x1542('0xd')][_0x1542('0xe')]({'field':_0x184dfb,'operator':_0x380dfc,'value':_0x22cb08});});});}return _0x4119ef;};exports[_0x1542('0xf')]=function(_0x52bb73,_0x12228c,_0x13ecad){var _0x313860={};if(_0x12228c==='DATE'){if(_0x13ecad[_0x1542('0x10')]==='$eq'){_0x13ecad['operator']=_0x1542('0x11');_0x13ecad[_0x1542('0x12')]+=','+_0x13ecad[_0x1542('0x12')];}else if(_[_0x1542('0x13')]([_0x1542('0x14'),_0x1542('0x15')],_0x13ecad[_0x1542('0x10')])){_0x13ecad['value']=moment(_0x13ecad[_0x1542('0x12')])[_0x1542('0x16')](0x1,_0x1542('0x17'))['format']('YYYY-MM-DD');}}if(_0x13ecad[_0x1542('0x18')]){_0x12228c=_0x13ecad['castTo'];_0x313860['text']=_0x1542('0x19')+_0x52bb73+'.'+_0x13ecad[_0x1542('0x1a')]+'\x20AS\x20'+_0x13ecad[_0x1542('0x18')]+')\x20'+parseOperator(_0x13ecad[_0x1542('0x10')]);}else{_0x313860['text']=_0x52bb73+'.'+_0x13ecad['field']+'\x20'+parseOperator(_0x13ecad[_0x1542('0x10')]);}if(_[_0x1542('0x13')](['$ne',_0x1542('0x1b')],_0x13ecad['operator']))_0x313860[_0x1542('0x1c')]='('+_0x313860['text']+_0x1542('0x1d')+_0x52bb73+'.'+_0x13ecad[_0x1542('0x1a')]+_0x1542('0x1e');_0x313860[_0x1542('0x12')]=parseValue(_0x12228c,_0x13ecad[_0x1542('0x10')],_0x13ecad[_0x1542('0x12')]);return _0x313860;};function parseOperator(_0x4051ae){var _0x1b7b0e;switch(_0x4051ae){case _0x1542('0x1f'):_0x1b7b0e=_0x1542('0x20');break;case _0x1542('0x1b'):_0x1b7b0e=_0x1542('0x21');break;case'$eq':_0x1b7b0e='=\x20?';break;case'$ne':_0x1b7b0e=_0x1542('0x22');break;case _0x1542('0x23'):case'$startsWith':case'$endsWith':_0x1b7b0e=_0x1542('0x24');break;case _0x1542('0x25'):_0x1b7b0e='<\x20?';break;case _0x1542('0x14'):_0x1b7b0e=_0x1542('0x26');break;case _0x1542('0x15'):_0x1b7b0e=_0x1542('0x27');break;case'$gte':_0x1b7b0e=_0x1542('0x28');break;case _0x1542('0x11'):_0x1b7b0e=_0x1542('0x29');break;}return _0x1b7b0e;}function parseValue(_0x15e4f8,_0x3437f9,_0x144003){var _0x271a27={'start':undefined,'end':undefined};switch(_0x3437f9){case _0x1542('0x1f'):case _0x1542('0x1b'):_0x271a27[_0x1542('0x2a')]=_0x144003[_0x1542('0x6')](',');break;case _0x1542('0x23'):_0x271a27[_0x1542('0x2a')]='%'+_0x144003+'%';break;case'$startsWith':_0x271a27[_0x1542('0x2a')]=_0x144003+'%';break;case _0x1542('0x2b'):_0x271a27[_0x1542('0x2a')]='%'+_0x144003;break;case _0x1542('0x11'):var _0x2b66c1=_0x144003[_0x1542('0x6')](',');var _0x144003=_0x2b66c1[_0x1542('0xa')]();var _0x1776de=_0x2b66c1[_0x1542('0x2c')]();if(_0x15e4f8===_0x1542('0x2d')){_0x144003=moment(_0x144003)[_0x1542('0x2e')](0x0,!![])[_0x1542('0x2f')]();_0x1776de=moment(_0x1776de)[_0x1542('0x2e')](0x0,!![])['add'](0x17,_0x1542('0x30'))[_0x1542('0x16')](0x3b,_0x1542('0x31'))['add'](0x3b,_0x1542('0x32'))[_0x1542('0x2f')]();}_0x271a27={'start':_0x144003,'end':_0x1776de};break;default:_0x271a27['start']=_0x144003;break;}return _0x271a27;}
\ No newline at end of file