Built motion from commit 85328c08.|2.5.50
[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 _0x5481=['YYYY-MM-DD','castTo','CAST(','field','text','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?','<=\x20?','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','shift','pop','utcOffset','hours','seconds','moment','parseSearch','sqlOperator','startsWith','[$or]','replace','[$and]','length','slice','forEach','split','match','map','conditions','DATE','operator','$eq','$between','value','includes','$gt','$lte','add','days','format'];(function(_0x32215e,_0x192fab){var _0x4377f8=function(_0x1b59e2){while(--_0x1b59e2){_0x32215e['push'](_0x32215e['shift']());}};_0x4377f8(++_0x192fab);}(_0x5481,0xf5));var _0x1548=function(_0x48df6e,_0xd49de5){_0x48df6e=_0x48df6e-0x0;var _0x2f9610=_0x5481[_0x48df6e];return _0x2f9610;};'use strict';var _=require('lodash');var moment=require(_0x1548('0x0'));exports[_0x1548('0x1')]=function(_0x59d227){var _0x38634b={'conditions':[]};_0x38634b[_0x1548('0x2')]=_[_0x1548('0x3')](_0x59d227,_0x1548('0x4'))?'or':'and';var _0x420af9=_0x59d227[_0x1548('0x5')](_0x1548('0x6'),'')[_0x1548('0x5')]('[$or]','')['split']('||');for(var _0x503e4b=0x0;_0x503e4b<_0x420af9[_0x1548('0x7')];_0x503e4b++){var _0x3955f6=_0x420af9[_0x503e4b]['split'](':=');var _0x231b31=_0x3955f6[0x0];var _0x549989=_0x3955f6[_0x1548('0x8')](0x1);_0x549989[_0x1548('0x9')](function(_0x4d520a){var _0x2979f8=_0x4d520a[_0x1548('0xa')]('[')['shift']();var _0xf2a0eb=_0x4d520a[_0x1548('0xb')](/\[(.*?)\]/g);_0xf2a0eb[_0x1548('0x9')](function(_0xab116d){var _0x219f54=_0xab116d[_0x1548('0xa')]('[')['filter'](function(_0x3d4512){return _0x3d4512['indexOf'](']')>-0x1;})[_0x1548('0xc')](function(_0x3f9e3f){return _0x3f9e3f['split'](']')[0x0];})[0x0];_0x38634b[_0x1548('0xd')]['push']({'field':_0x231b31,'operator':_0x2979f8,'value':_0x219f54});});});}return _0x38634b;};exports['buildExpression']=function(_0x233461,_0x58ee68,_0x5b69db){var _0x5dd7b4={};if(_0x58ee68===_0x1548('0xe')){if(_0x5b69db[_0x1548('0xf')]===_0x1548('0x10')){_0x5b69db[_0x1548('0xf')]=_0x1548('0x11');_0x5b69db['value']+=','+_0x5b69db[_0x1548('0x12')];}else if(_[_0x1548('0x13')]([_0x1548('0x14'),_0x1548('0x15')],_0x5b69db['operator'])){_0x5b69db[_0x1548('0x12')]=moment(_0x5b69db[_0x1548('0x12')])[_0x1548('0x16')](0x1,_0x1548('0x17'))[_0x1548('0x18')](_0x1548('0x19'));}}if(_0x5b69db[_0x1548('0x1a')]){_0x58ee68=_0x5b69db['castTo'];_0x5dd7b4['text']=_0x1548('0x1b')+_0x233461+'.'+_0x5b69db[_0x1548('0x1c')]+'\x20AS\x20'+_0x5b69db[_0x1548('0x1a')]+')\x20'+parseOperator(_0x5b69db['operator']);}else{_0x5dd7b4[_0x1548('0x1d')]=_0x233461+'.'+_0x5b69db['field']+'\x20'+parseOperator(_0x5b69db[_0x1548('0xf')]);}if(_[_0x1548('0x13')]([_0x1548('0x1e'),_0x1548('0x1f')],_0x5b69db['operator']))_0x5dd7b4[_0x1548('0x1d')]='('+_0x5dd7b4[_0x1548('0x1d')]+_0x1548('0x20')+_0x233461+'.'+_0x5b69db['field']+_0x1548('0x21');_0x5dd7b4[_0x1548('0x12')]=parseValue(_0x58ee68,_0x5b69db['operator'],_0x5b69db[_0x1548('0x12')]);return _0x5dd7b4;};function parseOperator(_0x48f940){var _0xd76313;switch(_0x48f940){case _0x1548('0x22'):_0xd76313=_0x1548('0x23');break;case'$notIn':_0xd76313=_0x1548('0x24');break;case _0x1548('0x10'):_0xd76313='=\x20?';break;case'$ne':_0xd76313=_0x1548('0x25');break;case _0x1548('0x26'):case _0x1548('0x27'):case _0x1548('0x28'):_0xd76313=_0x1548('0x29');break;case _0x1548('0x2a'):_0xd76313=_0x1548('0x2b');break;case _0x1548('0x14'):_0xd76313=_0x1548('0x2c');break;case _0x1548('0x15'):_0xd76313=_0x1548('0x2d');break;case'$gte':_0xd76313=_0x1548('0x2e');break;case _0x1548('0x11'):_0xd76313=_0x1548('0x2f');break;}return _0xd76313;}function parseValue(_0x2299b5,_0x37d65e,_0x3be19c){var _0x5a2623={'start':undefined,'end':undefined};switch(_0x37d65e){case _0x1548('0x22'):case _0x1548('0x1f'):_0x5a2623[_0x1548('0x30')]=_0x3be19c[_0x1548('0xa')](',');break;case _0x1548('0x26'):_0x5a2623[_0x1548('0x30')]='%'+_0x3be19c+'%';break;case'$startsWith':_0x5a2623['start']=_0x3be19c+'%';break;case'$endsWith':_0x5a2623[_0x1548('0x30')]='%'+_0x3be19c;break;case _0x1548('0x11'):var _0x1ee763=_0x3be19c['split'](',');var _0x3be19c=_0x1ee763[_0x1548('0x31')]();var _0x1de2a8=_0x1ee763[_0x1548('0x32')]();if(_0x2299b5===_0x1548('0xe')){_0x3be19c=moment(_0x3be19c)[_0x1548('0x33')](0x0,!![])['format']();_0x1de2a8=moment(_0x1de2a8)[_0x1548('0x33')](0x0,!![])['add'](0x17,_0x1548('0x34'))[_0x1548('0x16')](0x3b,'minutes')['add'](0x3b,_0x1548('0x35'))[_0x1548('0x18')]();}_0x5a2623={'start':_0x3be19c,'end':_0x1de2a8};break;default:_0x5a2623['start']=_0x3be19c;break;}return _0x5a2623;}