Built motion from commit (unavailable).|2.5.14
[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 _0x8d6d=['lodash','parseSearch','sqlOperator','startsWith','[$or]','and','[$and]','replace','split','length','slice','forEach','match','indexOf','map','push','buildExpression','DATE','operator','$eq','value','includes','$gt','add','days','format','YYYY-MM-DD','castTo','text','CAST(','\x20AS\x20','field','$ne','$notIn','\x20OR\x20','IN\x20?','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','LIKE\x20?','<\x20?','>\x20?','$lte','<=\x20?','$gte','>=\x20?','$in','start','$endsWith','$between','shift','pop','hours','minutes','seconds'];(function(_0x336eaa,_0x2ffc61){var _0x2fed2c=function(_0x4eed9f){while(--_0x4eed9f){_0x336eaa['push'](_0x336eaa['shift']());}};_0x2fed2c(++_0x2ffc61);}(_0x8d6d,0x156));var _0xd8d6=function(_0x4bbed4,_0xc9746a){_0x4bbed4=_0x4bbed4-0x0;var _0x178457=_0x8d6d[_0x4bbed4];return _0x178457;};'use strict';var _=require(_0xd8d6('0x0'));var moment=require('moment');exports[_0xd8d6('0x1')]=function(_0xcd5d1f){var _0x1f029d={'conditions':[]};_0x1f029d[_0xd8d6('0x2')]=_[_0xd8d6('0x3')](_0xcd5d1f,_0xd8d6('0x4'))?'or':_0xd8d6('0x5');var _0x1ddbcb=_0xcd5d1f['replace'](_0xd8d6('0x6'),'')[_0xd8d6('0x7')](_0xd8d6('0x4'),'')[_0xd8d6('0x8')]('||');for(var _0x30eadc=0x0;_0x30eadc<_0x1ddbcb[_0xd8d6('0x9')];_0x30eadc++){var _0x404a31=_0x1ddbcb[_0x30eadc][_0xd8d6('0x8')](':=');var _0x23d6bb=_0x404a31[0x0];var _0x3a825f=_0x404a31[_0xd8d6('0xa')](0x1);_0x3a825f[_0xd8d6('0xb')](function(_0x2f0a8d){var _0x42cc51=_0x2f0a8d[_0xd8d6('0x8')]('[')['shift']();var _0x544019=_0x2f0a8d[_0xd8d6('0xc')](/\[(.*?)\]/g);_0x544019[_0xd8d6('0xb')](function(_0x406577){var _0xd1c2f9=_0x406577['split']('[')['filter'](function(_0x3b4766){return _0x3b4766[_0xd8d6('0xd')](']')>-0x1;})[_0xd8d6('0xe')](function(_0x335e2b){return _0x335e2b['split'](']')[0x0];})[0x0];_0x1f029d['conditions'][_0xd8d6('0xf')]({'field':_0x23d6bb,'operator':_0x42cc51,'value':_0xd1c2f9});});});}return _0x1f029d;};exports[_0xd8d6('0x10')]=function(_0x400e40,_0x19f814,_0xdfd3dc){var _0x47628d={};if(_0x19f814===_0xd8d6('0x11')){if(_0xdfd3dc[_0xd8d6('0x12')]===_0xd8d6('0x13')){_0xdfd3dc[_0xd8d6('0x12')]='$between';_0xdfd3dc[_0xd8d6('0x14')]+=','+_0xdfd3dc['value'];}else if(_[_0xd8d6('0x15')]([_0xd8d6('0x16'),'$lte'],_0xdfd3dc[_0xd8d6('0x12')])){_0xdfd3dc['value']=moment(_0xdfd3dc[_0xd8d6('0x14')])[_0xd8d6('0x17')](0x1,_0xd8d6('0x18'))[_0xd8d6('0x19')](_0xd8d6('0x1a'));}}if(_0xdfd3dc['castTo']){_0x19f814=_0xdfd3dc[_0xd8d6('0x1b')];_0x47628d[_0xd8d6('0x1c')]=_0xd8d6('0x1d')+_0x400e40+'.'+_0xdfd3dc['field']+_0xd8d6('0x1e')+_0xdfd3dc[_0xd8d6('0x1b')]+')\x20'+parseOperator(_0xdfd3dc[_0xd8d6('0x12')]);}else{_0x47628d['text']=_0x400e40+'.'+_0xdfd3dc[_0xd8d6('0x1f')]+'\x20'+parseOperator(_0xdfd3dc[_0xd8d6('0x12')]);}if(_[_0xd8d6('0x15')]([_0xd8d6('0x20'),_0xd8d6('0x21')],_0xdfd3dc[_0xd8d6('0x12')]))_0x47628d['text']='('+_0x47628d['text']+_0xd8d6('0x22')+_0x400e40+'.'+_0xdfd3dc[_0xd8d6('0x1f')]+'\x20IS\x20NULL)';_0x47628d[_0xd8d6('0x14')]=parseValue(_0x19f814,_0xdfd3dc[_0xd8d6('0x12')],_0xdfd3dc[_0xd8d6('0x14')]);return _0x47628d;};function parseOperator(_0x591d60){var _0x3b2f10;switch(_0x591d60){case'$in':_0x3b2f10=_0xd8d6('0x23');break;case _0xd8d6('0x21'):_0x3b2f10=_0xd8d6('0x24');break;case _0xd8d6('0x13'):_0x3b2f10=_0xd8d6('0x25');break;case _0xd8d6('0x20'):_0x3b2f10=_0xd8d6('0x26');break;case _0xd8d6('0x27'):case _0xd8d6('0x28'):case'$endsWith':_0x3b2f10=_0xd8d6('0x29');break;case'$lt':_0x3b2f10=_0xd8d6('0x2a');break;case'$gt':_0x3b2f10=_0xd8d6('0x2b');break;case _0xd8d6('0x2c'):_0x3b2f10=_0xd8d6('0x2d');break;case _0xd8d6('0x2e'):_0x3b2f10=_0xd8d6('0x2f');break;case'$between':_0x3b2f10='BETWEEN\x20?\x20AND\x20?';break;}return _0x3b2f10;}function parseValue(_0x3c71b6,_0x2b7461,_0x4767a0){var _0x5d799a={'start':undefined,'end':undefined};switch(_0x2b7461){case _0xd8d6('0x30'):case'$notIn':_0x5d799a[_0xd8d6('0x31')]=_0x4767a0[_0xd8d6('0x8')](',');break;case _0xd8d6('0x27'):_0x5d799a['start']='%'+_0x4767a0+'%';break;case _0xd8d6('0x28'):_0x5d799a[_0xd8d6('0x31')]=_0x4767a0+'%';break;case _0xd8d6('0x32'):_0x5d799a[_0xd8d6('0x31')]='%'+_0x4767a0;break;case _0xd8d6('0x33'):var _0x267382=_0x4767a0[_0xd8d6('0x8')](',');var _0x4767a0=_0x267382[_0xd8d6('0x34')]();var _0x13c605=_0x267382[_0xd8d6('0x35')]();if(_0x3c71b6===_0xd8d6('0x11')){_0x4767a0=moment(_0x4767a0)['utcOffset'](0x0,!![])[_0xd8d6('0x19')]();_0x13c605=moment(_0x13c605)['utcOffset'](0x0,!![])['add'](0x17,_0xd8d6('0x36'))[_0xd8d6('0x17')](0x3b,_0xd8d6('0x37'))[_0xd8d6('0x17')](0x3b,_0xd8d6('0x38'))[_0xd8d6('0x19')]();}_0x5d799a={'start':_0x4767a0,'end':_0x13c605};break;default:_0x5d799a[_0xd8d6('0x31')]=_0x4767a0;break;}return _0x5d799a;}