7fa93dbd1530d7a57a32950912803c1334a13edb
[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 _0xd2ad=['lodash','moment','parseSearch','sqlOperator','[$or]','and','[$and]','replace','split','slice','shift','match','forEach','filter','indexOf','map','conditions','push','buildExpression','DATE','operator','$eq','$between','value','includes','$gt','$lte','add','days','format','YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','$notIn','\x20OR\x20','$in','=\x20?','<>\x20?','$substring','$endsWith','LIKE\x20?','<\x20?','>\x20?','<=\x20?','$gte','>=\x20?','start','$startsWith','pop','utcOffset','hours','seconds'];(function(_0x596c43,_0x28647a){var _0x4e1315=function(_0x58e910){while(--_0x58e910){_0x596c43['push'](_0x596c43['shift']());}};_0x4e1315(++_0x28647a);}(_0xd2ad,0x1ef));var _0xdd2a=function(_0x198446,_0x119c8f){_0x198446=_0x198446-0x0;var _0x38d7b7=_0xd2ad[_0x198446];return _0x38d7b7;};'use strict';var _=require(_0xdd2a('0x0'));var moment=require(_0xdd2a('0x1'));exports[_0xdd2a('0x2')]=function(_0x359a4f){var _0x1314bd={'conditions':[]};_0x1314bd[_0xdd2a('0x3')]=_['startsWith'](_0x359a4f,_0xdd2a('0x4'))?'or':_0xdd2a('0x5');var _0x3416e1=_0x359a4f['replace'](_0xdd2a('0x6'),'')[_0xdd2a('0x7')](_0xdd2a('0x4'),'')[_0xdd2a('0x8')]('||');for(var _0x5df24f=0x0;_0x5df24f<_0x3416e1['length'];_0x5df24f++){var _0x5ba890=_0x3416e1[_0x5df24f]['split'](':=');var _0xd66916=_0x5ba890[0x0];var _0x49efa5=_0x5ba890[_0xdd2a('0x9')](0x1);_0x49efa5['forEach'](function(_0x579c6){var _0x4d6a42=_0x579c6['split']('[')[_0xdd2a('0xa')]();var _0x4112c4=_0x579c6[_0xdd2a('0xb')](/\[(.*?)\]/g);_0x4112c4[_0xdd2a('0xc')](function(_0x264274){var _0x29995c=_0x264274[_0xdd2a('0x8')]('[')[_0xdd2a('0xd')](function(_0x4f78b7){return _0x4f78b7[_0xdd2a('0xe')](']')>-0x1;})[_0xdd2a('0xf')](function(_0x138770){return _0x138770[_0xdd2a('0x8')](']')[0x0];})[0x0];_0x1314bd[_0xdd2a('0x10')][_0xdd2a('0x11')]({'field':_0xd66916,'operator':_0x4d6a42,'value':_0x29995c});});});}return _0x1314bd;};exports[_0xdd2a('0x12')]=function(_0x1a11ff,_0x4d56bf,_0x26e72e){var _0x22a4ff={};if(_0x4d56bf===_0xdd2a('0x13')){if(_0x26e72e[_0xdd2a('0x14')]===_0xdd2a('0x15')){_0x26e72e[_0xdd2a('0x14')]=_0xdd2a('0x16');_0x26e72e[_0xdd2a('0x17')]+=','+_0x26e72e[_0xdd2a('0x17')];}else if(_[_0xdd2a('0x18')]([_0xdd2a('0x19'),_0xdd2a('0x1a')],_0x26e72e[_0xdd2a('0x14')])){_0x26e72e[_0xdd2a('0x17')]=moment(_0x26e72e['value'])[_0xdd2a('0x1b')](0x1,_0xdd2a('0x1c'))[_0xdd2a('0x1d')](_0xdd2a('0x1e'));}}if(_0x26e72e[_0xdd2a('0x1f')]){_0x4d56bf=_0x26e72e[_0xdd2a('0x1f')];_0x22a4ff[_0xdd2a('0x20')]=_0xdd2a('0x21')+_0x1a11ff+'.'+_0x26e72e[_0xdd2a('0x22')]+_0xdd2a('0x23')+_0x26e72e[_0xdd2a('0x1f')]+')\x20'+parseOperator(_0x26e72e[_0xdd2a('0x14')]);}else{_0x22a4ff[_0xdd2a('0x20')]=_0x1a11ff+'.'+_0x26e72e[_0xdd2a('0x22')]+'\x20'+parseOperator(_0x26e72e[_0xdd2a('0x14')]);}if(_['includes'](['$ne',_0xdd2a('0x24')],_0x26e72e['operator']))_0x22a4ff[_0xdd2a('0x20')]='('+_0x22a4ff[_0xdd2a('0x20')]+_0xdd2a('0x25')+_0x1a11ff+'.'+_0x26e72e[_0xdd2a('0x22')]+'\x20IS\x20NULL)';_0x22a4ff[_0xdd2a('0x17')]=parseValue(_0x4d56bf,_0x26e72e['operator'],_0x26e72e['value']);return _0x22a4ff;};function parseOperator(_0x2dc2ef){var _0x293df9;switch(_0x2dc2ef){case _0xdd2a('0x26'):_0x293df9='IN\x20?';break;case'$notIn':_0x293df9='NOT\x20IN\x20?';break;case _0xdd2a('0x15'):_0x293df9=_0xdd2a('0x27');break;case'$ne':_0x293df9=_0xdd2a('0x28');break;case _0xdd2a('0x29'):case'$startsWith':case _0xdd2a('0x2a'):_0x293df9=_0xdd2a('0x2b');break;case'$lt':_0x293df9=_0xdd2a('0x2c');break;case _0xdd2a('0x19'):_0x293df9=_0xdd2a('0x2d');break;case _0xdd2a('0x1a'):_0x293df9=_0xdd2a('0x2e');break;case _0xdd2a('0x2f'):_0x293df9=_0xdd2a('0x30');break;case _0xdd2a('0x16'):_0x293df9='BETWEEN\x20?\x20AND\x20?';break;}return _0x293df9;}function parseValue(_0x30c7e0,_0x4a82be,_0x53c5dd){var _0x1cb4ef={'start':undefined,'end':undefined};switch(_0x4a82be){case _0xdd2a('0x26'):case _0xdd2a('0x24'):_0x1cb4ef[_0xdd2a('0x31')]=_0x53c5dd['split'](',');break;case'$substring':_0x1cb4ef[_0xdd2a('0x31')]='%'+_0x53c5dd+'%';break;case _0xdd2a('0x32'):_0x1cb4ef[_0xdd2a('0x31')]=_0x53c5dd+'%';break;case _0xdd2a('0x2a'):_0x1cb4ef[_0xdd2a('0x31')]='%'+_0x53c5dd;break;case'$between':var _0x478dd5=_0x53c5dd['split'](',');var _0x53c5dd=_0x478dd5[_0xdd2a('0xa')]();var _0x27f4eb=_0x478dd5[_0xdd2a('0x33')]();if(_0x30c7e0===_0xdd2a('0x13')){_0x53c5dd=moment(_0x53c5dd)['utcOffset'](0x0,!![])[_0xdd2a('0x1d')]();_0x27f4eb=moment(_0x27f4eb)[_0xdd2a('0x34')](0x0,!![])[_0xdd2a('0x1b')](0x17,_0xdd2a('0x35'))[_0xdd2a('0x1b')](0x3b,'minutes')[_0xdd2a('0x1b')](0x3b,_0xdd2a('0x36'))[_0xdd2a('0x1d')]();}_0x1cb4ef={'start':_0x53c5dd,'end':_0x27f4eb};break;default:_0x1cb4ef['start']=_0x53c5dd;break;}return _0x1cb4ef;}