9e9636bc15401ae4de31761fb0e6792d5b9d78e7
[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 _0x7c08=['[$and]','split','slice','forEach','match','filter','map','push','DATE','operator','$between','value','includes','$lte','add','days','format','castTo','text','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','$eq','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','<\x20?','$gt','<=\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','shift','utcOffset','hours','minutes','seconds','moment','sqlOperator','startsWith','[$or]','replace'];(function(_0x391300,_0x30d61d){var _0x4e5652=function(_0x7bd299){while(--_0x7bd299){_0x391300['push'](_0x391300['shift']());}};_0x4e5652(++_0x30d61d);}(_0x7c08,0x133));var _0x87c0=function(_0x4ba20b,_0x2a6f25){_0x4ba20b=_0x4ba20b-0x0;var _0x396068=_0x7c08[_0x4ba20b];return _0x396068;};'use strict';var _=require('lodash');var moment=require(_0x87c0('0x0'));exports['parseSearch']=function(_0x47ae72){var _0x45c4af={'conditions':[]};_0x45c4af[_0x87c0('0x1')]=_[_0x87c0('0x2')](_0x47ae72,_0x87c0('0x3'))?'or':'and';var _0x56dfba=_0x47ae72[_0x87c0('0x4')](_0x87c0('0x5'),'')[_0x87c0('0x4')]('[$or]','')[_0x87c0('0x6')]('||');for(var _0xeb9ddc=0x0;_0xeb9ddc<_0x56dfba['length'];_0xeb9ddc++){var _0x429a3b=_0x56dfba[_0xeb9ddc][_0x87c0('0x6')](':=');var _0x48a6bd=_0x429a3b[0x0];var _0x281228=_0x429a3b[_0x87c0('0x7')](0x1);_0x281228[_0x87c0('0x8')](function(_0x5af348){var _0x22f686=_0x5af348[_0x87c0('0x6')]('[')['shift']();var _0x1dd00d=_0x5af348[_0x87c0('0x9')](/\[(.*?)\]/g);_0x1dd00d[_0x87c0('0x8')](function(_0x5f1142){var _0x5d6d3b=_0x5f1142['split']('[')[_0x87c0('0xa')](function(_0x5829b5){return _0x5829b5['indexOf'](']')>-0x1;})[_0x87c0('0xb')](function(_0x15cf47){return _0x15cf47[_0x87c0('0x6')](']')[0x0];})[0x0];_0x45c4af['conditions'][_0x87c0('0xc')]({'field':_0x48a6bd,'operator':_0x22f686,'value':_0x5d6d3b});});});}return _0x45c4af;};exports['buildExpression']=function(_0x1a2454,_0x1054de,_0x4d980c){var _0x160ca6={};if(_0x1054de===_0x87c0('0xd')){if(_0x4d980c[_0x87c0('0xe')]==='$eq'){_0x4d980c[_0x87c0('0xe')]=_0x87c0('0xf');_0x4d980c[_0x87c0('0x10')]+=','+_0x4d980c[_0x87c0('0x10')];}else if(_[_0x87c0('0x11')](['$gt',_0x87c0('0x12')],_0x4d980c['operator'])){_0x4d980c[_0x87c0('0x10')]=moment(_0x4d980c['value'])[_0x87c0('0x13')](0x1,_0x87c0('0x14'))[_0x87c0('0x15')]('YYYY-MM-DD');}}if(_0x4d980c[_0x87c0('0x16')]){_0x1054de=_0x4d980c[_0x87c0('0x16')];_0x160ca6[_0x87c0('0x17')]='CAST('+_0x1a2454+'.'+_0x4d980c[_0x87c0('0x18')]+_0x87c0('0x19')+_0x4d980c[_0x87c0('0x16')]+')\x20'+parseOperator(_0x4d980c[_0x87c0('0xe')]);}else{_0x160ca6[_0x87c0('0x17')]=_0x1a2454+'.'+_0x4d980c[_0x87c0('0x18')]+'\x20'+parseOperator(_0x4d980c[_0x87c0('0xe')]);}if(_[_0x87c0('0x11')]([_0x87c0('0x1a'),_0x87c0('0x1b')],_0x4d980c[_0x87c0('0xe')]))_0x160ca6[_0x87c0('0x17')]='('+_0x160ca6[_0x87c0('0x17')]+_0x87c0('0x1c')+_0x1a2454+'.'+_0x4d980c[_0x87c0('0x18')]+_0x87c0('0x1d');_0x160ca6['value']=parseValue(_0x1054de,_0x4d980c['operator'],_0x4d980c[_0x87c0('0x10')]);return _0x160ca6;};function parseOperator(_0x4b3629){var _0x407794;switch(_0x4b3629){case _0x87c0('0x1e'):_0x407794=_0x87c0('0x1f');break;case _0x87c0('0x1b'):_0x407794=_0x87c0('0x20');break;case _0x87c0('0x21'):_0x407794=_0x87c0('0x22');break;case'$ne':_0x407794=_0x87c0('0x23');break;case _0x87c0('0x24'):case _0x87c0('0x25'):case _0x87c0('0x26'):_0x407794=_0x87c0('0x27');break;case'$lt':_0x407794=_0x87c0('0x28');break;case _0x87c0('0x29'):_0x407794='>\x20?';break;case _0x87c0('0x12'):_0x407794=_0x87c0('0x2a');break;case _0x87c0('0x2b'):_0x407794=_0x87c0('0x2c');break;case _0x87c0('0xf'):_0x407794=_0x87c0('0x2d');break;}return _0x407794;}function parseValue(_0x24124b,_0x12fdda,_0x3b5954){var _0x5365ba={'start':undefined,'end':undefined};switch(_0x12fdda){case'$in':case'$notIn':_0x5365ba[_0x87c0('0x2e')]=_0x3b5954[_0x87c0('0x6')](',');break;case _0x87c0('0x24'):_0x5365ba[_0x87c0('0x2e')]='%'+_0x3b5954+'%';break;case _0x87c0('0x25'):_0x5365ba[_0x87c0('0x2e')]=_0x3b5954+'%';break;case _0x87c0('0x26'):_0x5365ba['start']='%'+_0x3b5954;break;case _0x87c0('0xf'):var _0x40bdde=_0x3b5954[_0x87c0('0x6')](',');var _0x3b5954=_0x40bdde[_0x87c0('0x2f')]();var _0x37317d=_0x40bdde['pop']();if(_0x24124b===_0x87c0('0xd')){_0x3b5954=moment(_0x3b5954)[_0x87c0('0x30')](0x0,!![])[_0x87c0('0x15')]();_0x37317d=moment(_0x37317d)['utcOffset'](0x0,!![])['add'](0x17,_0x87c0('0x31'))[_0x87c0('0x13')](0x3b,_0x87c0('0x32'))[_0x87c0('0x13')](0x3b,_0x87c0('0x33'))[_0x87c0('0x15')]();}_0x5365ba={'start':_0x3b5954,'end':_0x37317d};break;default:_0x5365ba['start']=_0x3b5954;break;}return _0x5365ba;}