Built motion from commit (unavailable).|2.5.7
[motion2.git] / server / components / parsers / advancedSearch.js
1 // *************************************************************************
2 // *                                                                       *
3 // * xCALLY Motion -  The Omnichannel Contact Center                       *
4 // * Copyright (c) Xenialab s.r.l. All Rights Reserved                     *
5 // *                                                                       *
6 // *************************************************************************
7 // *                                                                       *
8 // * Email: info@xcally.com                                                *
9 // * Website: https://www.xcally.com                                       *
10 // *                                                                       *
11 // *************************************************************************
12 // *                                                                       *
13 // * The SOFTWARE PRODUCT is protected by copyright laws and international *
14 // * copyright treaties, as well as other intellectual property laws and   *
15 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                         *
16 // *                                                                       *
17 // *************************************************************************
18 var _0x21f0=['conditions','DATE','$eq','operator','$between','value','includes','$gt','$lte','castTo','text','CAST(','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','=\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','pop','utcOffset','format','add','hours','minutes','seconds','lodash','moment','sqlOperator','startsWith','[$or]','and','[$and]','replace','split','length','slice','forEach','shift','map'];(function(_0x4b369d,_0x265eb8){var _0x571a98=function(_0x56341a){while(--_0x56341a){_0x4b369d['push'](_0x4b369d['shift']());}};_0x571a98(++_0x265eb8);}(_0x21f0,0x16c));var _0x021f=function(_0x5a0040,_0x445600){_0x5a0040=_0x5a0040-0x0;var _0x139d00=_0x21f0[_0x5a0040];return _0x139d00;};'use strict';var _=require(_0x021f('0x0'));var moment=require(_0x021f('0x1'));exports['parseSearch']=function(_0x128f73){var _0x42dda4={'conditions':[]};_0x42dda4[_0x021f('0x2')]=_[_0x021f('0x3')](_0x128f73,_0x021f('0x4'))?'or':_0x021f('0x5');var _0x2f1ced=_0x128f73['replace'](_0x021f('0x6'),'')[_0x021f('0x7')]('[$or]','')[_0x021f('0x8')]('||');for(var _0x38779e=0x0;_0x38779e<_0x2f1ced[_0x021f('0x9')];_0x38779e++){var _0x1a9a73=_0x2f1ced[_0x38779e][_0x021f('0x8')](':=');var _0x58477c=_0x1a9a73[0x0];var _0x140577=_0x1a9a73[_0x021f('0xa')](0x1);_0x140577[_0x021f('0xb')](function(_0x5d0e47){var _0x3e3929=_0x5d0e47['split']('[')[_0x021f('0xc')]();var _0x5dfd3d=_0x5d0e47['match'](/\[(.*?)\]/g);_0x5dfd3d['forEach'](function(_0x51624f){var _0x540f58=_0x51624f[_0x021f('0x8')]('[')['filter'](function(_0x1aa8ab){return _0x1aa8ab['indexOf'](']')>-0x1;})[_0x021f('0xd')](function(_0x31b5ff){return _0x31b5ff['split'](']')[0x0];})[0x0];_0x42dda4[_0x021f('0xe')]['push']({'field':_0x58477c,'operator':_0x3e3929,'value':_0x540f58});});});}return _0x42dda4;};exports['buildExpression']=function(_0x19e2f3,_0x46560b,_0xdb58f8){var _0x3287a4={};if(_0x46560b===_0x021f('0xf')){if(_0xdb58f8['operator']===_0x021f('0x10')){_0xdb58f8[_0x021f('0x11')]=_0x021f('0x12');_0xdb58f8[_0x021f('0x13')]+=','+_0xdb58f8['value'];}else if(_[_0x021f('0x14')]([_0x021f('0x15'),_0x021f('0x16')],_0xdb58f8[_0x021f('0x11')])){_0xdb58f8[_0x021f('0x13')]=moment(_0xdb58f8['value'])['add'](0x1,'days')['format']('YYYY-MM-DD');}}if(_0xdb58f8['castTo']){_0x46560b=_0xdb58f8[_0x021f('0x17')];_0x3287a4[_0x021f('0x18')]=_0x021f('0x19')+_0x19e2f3+'.'+_0xdb58f8[_0x021f('0x1a')]+_0x021f('0x1b')+_0xdb58f8[_0x021f('0x17')]+')\x20'+parseOperator(_0xdb58f8[_0x021f('0x11')]);}else{_0x3287a4[_0x021f('0x18')]=_0x19e2f3+'.'+_0xdb58f8['field']+'\x20'+parseOperator(_0xdb58f8[_0x021f('0x11')]);}if(_[_0x021f('0x14')]([_0x021f('0x1c'),_0x021f('0x1d')],_0xdb58f8['operator']))_0x3287a4[_0x021f('0x18')]='('+_0x3287a4[_0x021f('0x18')]+_0x021f('0x1e')+_0x19e2f3+'.'+_0xdb58f8[_0x021f('0x1a')]+_0x021f('0x1f');_0x3287a4[_0x021f('0x13')]=parseValue(_0x46560b,_0xdb58f8[_0x021f('0x11')],_0xdb58f8[_0x021f('0x13')]);return _0x3287a4;};function parseOperator(_0x7a0746){var _0x56d36d;switch(_0x7a0746){case _0x021f('0x20'):_0x56d36d=_0x021f('0x21');break;case'$notIn':_0x56d36d=_0x021f('0x22');break;case'$eq':_0x56d36d=_0x021f('0x23');break;case _0x021f('0x1c'):_0x56d36d='<>\x20?';break;case _0x021f('0x24'):case _0x021f('0x25'):case _0x021f('0x26'):_0x56d36d=_0x021f('0x27');break;case _0x021f('0x28'):_0x56d36d=_0x021f('0x29');break;case'$gt':_0x56d36d='>\x20?';break;case'$lte':_0x56d36d=_0x021f('0x2a');break;case _0x021f('0x2b'):_0x56d36d=_0x021f('0x2c');break;case'$between':_0x56d36d=_0x021f('0x2d');break;}return _0x56d36d;}function parseValue(_0x57d098,_0x2d7624,_0x592230){var _0x3bc3d7={'start':undefined,'end':undefined};switch(_0x2d7624){case _0x021f('0x20'):case'$notIn':_0x3bc3d7['start']=_0x592230[_0x021f('0x8')](',');break;case _0x021f('0x24'):_0x3bc3d7[_0x021f('0x2e')]='%'+_0x592230+'%';break;case _0x021f('0x25'):_0x3bc3d7['start']=_0x592230+'%';break;case _0x021f('0x26'):_0x3bc3d7[_0x021f('0x2e')]='%'+_0x592230;break;case _0x021f('0x12'):var _0x3b8395=_0x592230[_0x021f('0x8')](',');var _0x592230=_0x3b8395[_0x021f('0xc')]();var _0x1fd345=_0x3b8395[_0x021f('0x2f')]();if(_0x57d098==='DATE'){_0x592230=moment(_0x592230)[_0x021f('0x30')](0x0,!![])[_0x021f('0x31')]();_0x1fd345=moment(_0x1fd345)[_0x021f('0x30')](0x0,!![])[_0x021f('0x32')](0x17,_0x021f('0x33'))['add'](0x3b,_0x021f('0x34'))[_0x021f('0x32')](0x3b,_0x021f('0x35'))[_0x021f('0x31')]();}_0x3bc3d7={'start':_0x592230,'end':_0x1fd345};break;default:_0x3bc3d7[_0x021f('0x2e')]=_0x592230;break;}return _0x3bc3d7;}