Built motion from commit e02f907f.|2.6.14
[motion2.git] / server / components / parsers / advancedSearch.js
index 98c0e1b..1447d91 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x65a8=['$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','NOT\x20IN\x20?','=\x20?','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?','$between','BETWEEN\x20?\x20AND\x20?','start','$substring','shift','pop','DATE','utcOffset','minutes','seconds','lodash','parseSearch','startsWith','[$or]','replace','[$and]','split','slice','forEach','indexOf','map','conditions','operator','$eq','value','includes','$gt','$lte','add','days','format','YYYY-MM-DD','castTo','text','CAST(','field','$ne'];(function(_0x28fcdc,_0x17e930){var _0x80bd4c=function(_0x2c490d){while(--_0x2c490d){_0x28fcdc['push'](_0x28fcdc['shift']());}};_0x80bd4c(++_0x17e930);}(_0x65a8,0x1cf));var _0x865a=function(_0x57b54c,_0x54ce0d){_0x57b54c=_0x57b54c-0x0;var _0x59cc19=_0x65a8[_0x57b54c];return _0x59cc19;};'use strict';var _=require(_0x865a('0x0'));var moment=require('moment');exports[_0x865a('0x1')]=function(_0x38b04d){var _0x5c51e4={'conditions':[]};_0x5c51e4['sqlOperator']=_[_0x865a('0x2')](_0x38b04d,_0x865a('0x3'))?'or':'and';var _0x42b006=_0x38b04d[_0x865a('0x4')](_0x865a('0x5'),'')[_0x865a('0x4')](_0x865a('0x3'),'')[_0x865a('0x6')]('||');for(var _0x4cf4e8=0x0;_0x4cf4e8<_0x42b006['length'];_0x4cf4e8++){var _0x487b52=_0x42b006[_0x4cf4e8][_0x865a('0x6')](':=');var _0x25a6e0=_0x487b52[0x0];var _0x3935e0=_0x487b52[_0x865a('0x7')](0x1);_0x3935e0[_0x865a('0x8')](function(_0x427cfd){var _0x4b86fa=_0x427cfd[_0x865a('0x6')]('[')['shift']();var _0x4d07ad=_0x427cfd['match'](/\[(.*?)\]/g);_0x4d07ad['forEach'](function(_0x49958a){var _0x926454=_0x49958a['split']('[')['filter'](function(_0x522f04){return _0x522f04[_0x865a('0x9')](']')>-0x1;})[_0x865a('0xa')](function(_0x366a32){return _0x366a32[_0x865a('0x6')](']')[0x0];})[0x0];_0x5c51e4[_0x865a('0xb')]['push']({'field':_0x25a6e0,'operator':_0x4b86fa,'value':_0x926454});});});}return _0x5c51e4;};exports['buildExpression']=function(_0x122773,_0x1f1efa,_0x1977a6){var _0x332b5b={};if(_0x1f1efa==='DATE'){if(_0x1977a6[_0x865a('0xc')]===_0x865a('0xd')){_0x1977a6['operator']='$between';_0x1977a6[_0x865a('0xe')]+=','+_0x1977a6[_0x865a('0xe')];}else if(_[_0x865a('0xf')]([_0x865a('0x10'),_0x865a('0x11')],_0x1977a6[_0x865a('0xc')])){_0x1977a6[_0x865a('0xe')]=moment(_0x1977a6[_0x865a('0xe')])[_0x865a('0x12')](0x1,_0x865a('0x13'))[_0x865a('0x14')](_0x865a('0x15'));}}if(_0x1977a6[_0x865a('0x16')]){_0x1f1efa=_0x1977a6['castTo'];_0x332b5b[_0x865a('0x17')]=_0x865a('0x18')+_0x122773+'.'+_0x1977a6[_0x865a('0x19')]+'\x20AS\x20'+_0x1977a6[_0x865a('0x16')]+')\x20'+parseOperator(_0x1977a6['operator']);}else{_0x332b5b['text']=_0x122773+'.'+_0x1977a6[_0x865a('0x19')]+'\x20'+parseOperator(_0x1977a6[_0x865a('0xc')]);}if(_['includes']([_0x865a('0x1a'),_0x865a('0x1b')],_0x1977a6['operator']))_0x332b5b[_0x865a('0x17')]='('+_0x332b5b[_0x865a('0x17')]+_0x865a('0x1c')+_0x122773+'.'+_0x1977a6['field']+_0x865a('0x1d');_0x332b5b['value']=parseValue(_0x1f1efa,_0x1977a6[_0x865a('0xc')],_0x1977a6[_0x865a('0xe')]);return _0x332b5b;};function parseOperator(_0x464580){var _0x1b8f58;switch(_0x464580){case _0x865a('0x1e'):_0x1b8f58='IN\x20?';break;case'$notIn':_0x1b8f58=_0x865a('0x1f');break;case _0x865a('0xd'):_0x1b8f58=_0x865a('0x20');break;case _0x865a('0x1a'):_0x1b8f58='<>\x20?';break;case'$substring':case _0x865a('0x21'):case _0x865a('0x22'):_0x1b8f58=_0x865a('0x23');break;case _0x865a('0x24'):_0x1b8f58=_0x865a('0x25');break;case _0x865a('0x10'):_0x1b8f58=_0x865a('0x26');break;case _0x865a('0x11'):_0x1b8f58='<=\x20?';break;case'$gte':_0x1b8f58='>=\x20?';break;case _0x865a('0x27'):_0x1b8f58=_0x865a('0x28');break;}return _0x1b8f58;}function parseValue(_0x1bc71a,_0x43eb8b,_0x3ef8dd){var _0x5f3119={'start':undefined,'end':undefined};switch(_0x43eb8b){case _0x865a('0x1e'):case _0x865a('0x1b'):_0x5f3119[_0x865a('0x29')]=_0x3ef8dd['split'](',');break;case _0x865a('0x2a'):_0x5f3119[_0x865a('0x29')]='%'+_0x3ef8dd+'%';break;case _0x865a('0x21'):_0x5f3119['start']=_0x3ef8dd+'%';break;case'$endsWith':_0x5f3119[_0x865a('0x29')]='%'+_0x3ef8dd;break;case'$between':var _0x343b10=_0x3ef8dd[_0x865a('0x6')](',');var _0x3ef8dd=_0x343b10[_0x865a('0x2b')]();var _0x1bad16=_0x343b10[_0x865a('0x2c')]();if(_0x1bc71a===_0x865a('0x2d')){_0x3ef8dd=moment(_0x3ef8dd)[_0x865a('0x2e')](0x0,!![])['format']();_0x1bad16=moment(_0x1bad16)[_0x865a('0x2e')](0x0,!![])[_0x865a('0x12')](0x17,'hours')['add'](0x3b,_0x865a('0x2f'))['add'](0x3b,_0x865a('0x30'))[_0x865a('0x14')]();}_0x5f3119={'start':_0x3ef8dd,'end':_0x1bad16};break;default:_0x5f3119[_0x865a('0x29')]=_0x3ef8dd;break;}return _0x5f3119;}
\ No newline at end of file
+var _0x3520=['YYYY-MM-DD','castTo','text','CAST(','field','$ne','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','$notIn','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','>\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','pop','utcOffset','hours','minutes','seconds','moment','sqlOperator','and','replace','[$and]','[$or]','split','length','slice','forEach','shift','match','filter','indexOf','map','buildExpression','DATE','operator','$eq','$between','value','includes','$gt','$lte','add','days','format'];(function(_0x4d5cfd,_0x5b5c6c){var _0x442f17=function(_0x32a375){while(--_0x32a375){_0x4d5cfd['push'](_0x4d5cfd['shift']());}};_0x442f17(++_0x5b5c6c);}(_0x3520,0x166));var _0x0352=function(_0x28405b,_0x583b9f){_0x28405b=_0x28405b-0x0;var _0x47a902=_0x3520[_0x28405b];return _0x47a902;};'use strict';var _=require('lodash');var moment=require(_0x0352('0x0'));exports['parseSearch']=function(_0x22b811){var _0x3fefa8={'conditions':[]};_0x3fefa8[_0x0352('0x1')]=_['startsWith'](_0x22b811,'[$or]')?'or':_0x0352('0x2');var _0x424591=_0x22b811[_0x0352('0x3')](_0x0352('0x4'),'')['replace'](_0x0352('0x5'),'')[_0x0352('0x6')]('||');for(var _0x526aaa=0x0;_0x526aaa<_0x424591[_0x0352('0x7')];_0x526aaa++){var _0x45df15=_0x424591[_0x526aaa][_0x0352('0x6')](':=');var _0x34e301=_0x45df15[0x0];var _0x64f791=_0x45df15[_0x0352('0x8')](0x1);_0x64f791[_0x0352('0x9')](function(_0x563323){var _0x4d1471=_0x563323['split']('[')[_0x0352('0xa')]();var _0x8a3da0=_0x563323[_0x0352('0xb')](/\[(.*?)\]/g);_0x8a3da0['forEach'](function(_0x534fa0){var _0x2a1012=_0x534fa0[_0x0352('0x6')]('[')[_0x0352('0xc')](function(_0xf05173){return _0xf05173[_0x0352('0xd')](']')>-0x1;})[_0x0352('0xe')](function(_0x19386b){return _0x19386b[_0x0352('0x6')](']')[0x0];})[0x0];_0x3fefa8['conditions']['push']({'field':_0x34e301,'operator':_0x4d1471,'value':_0x2a1012});});});}return _0x3fefa8;};exports[_0x0352('0xf')]=function(_0x47d188,_0x1a8313,_0x11a698){var _0x2a66ab={};if(_0x1a8313===_0x0352('0x10')){if(_0x11a698[_0x0352('0x11')]===_0x0352('0x12')){_0x11a698[_0x0352('0x11')]=_0x0352('0x13');_0x11a698[_0x0352('0x14')]+=','+_0x11a698[_0x0352('0x14')];}else if(_[_0x0352('0x15')]([_0x0352('0x16'),_0x0352('0x17')],_0x11a698[_0x0352('0x11')])){_0x11a698[_0x0352('0x14')]=moment(_0x11a698['value'])[_0x0352('0x18')](0x1,_0x0352('0x19'))[_0x0352('0x1a')](_0x0352('0x1b'));}}if(_0x11a698[_0x0352('0x1c')]){_0x1a8313=_0x11a698[_0x0352('0x1c')];_0x2a66ab[_0x0352('0x1d')]=_0x0352('0x1e')+_0x47d188+'.'+_0x11a698[_0x0352('0x1f')]+'\x20AS\x20'+_0x11a698[_0x0352('0x1c')]+')\x20'+parseOperator(_0x11a698[_0x0352('0x11')]);}else{_0x2a66ab['text']=_0x47d188+'.'+_0x11a698[_0x0352('0x1f')]+'\x20'+parseOperator(_0x11a698[_0x0352('0x11')]);}if(_[_0x0352('0x15')]([_0x0352('0x20'),'$notIn'],_0x11a698[_0x0352('0x11')]))_0x2a66ab[_0x0352('0x1d')]='('+_0x2a66ab[_0x0352('0x1d')]+_0x0352('0x21')+_0x47d188+'.'+_0x11a698['field']+_0x0352('0x22');_0x2a66ab[_0x0352('0x14')]=parseValue(_0x1a8313,_0x11a698[_0x0352('0x11')],_0x11a698[_0x0352('0x14')]);return _0x2a66ab;};function parseOperator(_0x246667){var _0x441669;switch(_0x246667){case _0x0352('0x23'):_0x441669=_0x0352('0x24');break;case _0x0352('0x25'):_0x441669='NOT\x20IN\x20?';break;case'$eq':_0x441669=_0x0352('0x26');break;case _0x0352('0x20'):_0x441669=_0x0352('0x27');break;case _0x0352('0x28'):case _0x0352('0x29'):case _0x0352('0x2a'):_0x441669=_0x0352('0x2b');break;case'$lt':_0x441669=_0x0352('0x2c');break;case _0x0352('0x16'):_0x441669=_0x0352('0x2d');break;case _0x0352('0x17'):_0x441669='<=\x20?';break;case _0x0352('0x2e'):_0x441669=_0x0352('0x2f');break;case'$between':_0x441669=_0x0352('0x30');break;}return _0x441669;}function parseValue(_0x16122c,_0x404829,_0x2639da){var _0xfc8543={'start':undefined,'end':undefined};switch(_0x404829){case _0x0352('0x23'):case _0x0352('0x25'):_0xfc8543[_0x0352('0x31')]=_0x2639da[_0x0352('0x6')](',');break;case'$substring':_0xfc8543[_0x0352('0x31')]='%'+_0x2639da+'%';break;case _0x0352('0x29'):_0xfc8543['start']=_0x2639da+'%';break;case'$endsWith':_0xfc8543['start']='%'+_0x2639da;break;case _0x0352('0x13'):var _0x466fa9=_0x2639da[_0x0352('0x6')](',');var _0x2639da=_0x466fa9['shift']();var _0x126bce=_0x466fa9[_0x0352('0x32')]();if(_0x16122c===_0x0352('0x10')){_0x2639da=moment(_0x2639da)[_0x0352('0x33')](0x0,!![])[_0x0352('0x1a')]();_0x126bce=moment(_0x126bce)[_0x0352('0x33')](0x0,!![])[_0x0352('0x18')](0x17,_0x0352('0x34'))[_0x0352('0x18')](0x3b,_0x0352('0x35'))['add'](0x3b,_0x0352('0x36'))['format']();}_0xfc8543={'start':_0x2639da,'end':_0x126bce};break;default:_0xfc8543[_0x0352('0x31')]=_0x2639da;break;}return _0xfc8543;}
\ No newline at end of file