Built motion from commit 25580385.|2.6.2
[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 _0x673c=['add','hours','minutes','seconds','moment','parseSearch','sqlOperator','startsWith','[$or]','and','replace','split','slice','forEach','match','indexOf','map','conditions','push','buildExpression','operator','value','includes','$lte','days','format','YYYY-MM-DD','castTo','text','CAST(','\x20AS\x20','$ne','$notIn','field','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','$eq','=\x20?','$startsWith','LIKE\x20?','$gt','>\x20?','<=\x20?','$gte','BETWEEN\x20?\x20AND\x20?','start','$substring','$between','shift','pop','DATE','utcOffset'];(function(_0x3dd15e,_0x1f0015){var _0x231fd0=function(_0x4f680a){while(--_0x4f680a){_0x3dd15e['push'](_0x3dd15e['shift']());}};_0x231fd0(++_0x1f0015);}(_0x673c,0x70));var _0xc673=function(_0x3dd15e,_0x1f0015){_0x3dd15e=_0x3dd15e-0x0;var _0x231fd0=_0x673c[_0x3dd15e];return _0x231fd0;};'use strict';var _=require('lodash');var moment=require(_0xc673('0x0'));exports[_0xc673('0x1')]=function(_0x513381){var _0x3b0360={'conditions':[]};_0x3b0360[_0xc673('0x2')]=_[_0xc673('0x3')](_0x513381,_0xc673('0x4'))?'or':_0xc673('0x5');var _0x5e155f=_0x513381[_0xc673('0x6')]('[$and]','')[_0xc673('0x6')](_0xc673('0x4'),'')[_0xc673('0x7')]('||');for(var _0x12ffde=0x0;_0x12ffde<_0x5e155f['length'];_0x12ffde++){var _0x24e034=_0x5e155f[_0x12ffde][_0xc673('0x7')](':=');var _0x4f4af1=_0x24e034[0x0];var _0x1ea6da=_0x24e034[_0xc673('0x8')](0x1);_0x1ea6da[_0xc673('0x9')](function(_0x4197f3){var _0x1034fe=_0x4197f3[_0xc673('0x7')]('[')['shift']();var _0x5ebcc7=_0x4197f3[_0xc673('0xa')](/\[(.*?)\]/g);_0x5ebcc7[_0xc673('0x9')](function(_0xb3fe45){var _0x50e199=_0xb3fe45[_0xc673('0x7')]('[')['filter'](function(_0x53908b){return _0x53908b[_0xc673('0xb')](']')>-0x1;})[_0xc673('0xc')](function(_0x34a6b4){return _0x34a6b4[_0xc673('0x7')](']')[0x0];})[0x0];_0x3b0360[_0xc673('0xd')][_0xc673('0xe')]({'field':_0x4f4af1,'operator':_0x1034fe,'value':_0x50e199});});});}return _0x3b0360;};exports[_0xc673('0xf')]=function(_0x50e359,_0x55d353,_0xf4d918){var _0x8f325c={};if(_0x55d353==='DATE'){if(_0xf4d918[_0xc673('0x10')]==='$eq'){_0xf4d918[_0xc673('0x10')]='$between';_0xf4d918['value']+=','+_0xf4d918[_0xc673('0x11')];}else if(_[_0xc673('0x12')](['$gt',_0xc673('0x13')],_0xf4d918['operator'])){_0xf4d918['value']=moment(_0xf4d918[_0xc673('0x11')])['add'](0x1,_0xc673('0x14'))[_0xc673('0x15')](_0xc673('0x16'));}}if(_0xf4d918[_0xc673('0x17')]){_0x55d353=_0xf4d918[_0xc673('0x17')];_0x8f325c[_0xc673('0x18')]=_0xc673('0x19')+_0x50e359+'.'+_0xf4d918['field']+_0xc673('0x1a')+_0xf4d918[_0xc673('0x17')]+')\x20'+parseOperator(_0xf4d918[_0xc673('0x10')]);}else{_0x8f325c[_0xc673('0x18')]=_0x50e359+'.'+_0xf4d918['field']+'\x20'+parseOperator(_0xf4d918['operator']);}if(_[_0xc673('0x12')]([_0xc673('0x1b'),_0xc673('0x1c')],_0xf4d918['operator']))_0x8f325c[_0xc673('0x18')]='('+_0x8f325c[_0xc673('0x18')]+'\x20OR\x20'+_0x50e359+'.'+_0xf4d918[_0xc673('0x1d')]+_0xc673('0x1e');_0x8f325c[_0xc673('0x11')]=parseValue(_0x55d353,_0xf4d918[_0xc673('0x10')],_0xf4d918[_0xc673('0x11')]);return _0x8f325c;};function parseOperator(_0x118f07){var _0x956d49;switch(_0x118f07){case _0xc673('0x1f'):_0x956d49=_0xc673('0x20');break;case _0xc673('0x1c'):_0x956d49=_0xc673('0x21');break;case _0xc673('0x22'):_0x956d49=_0xc673('0x23');break;case'$ne':_0x956d49='<>\x20?';break;case'$substring':case _0xc673('0x24'):case'$endsWith':_0x956d49=_0xc673('0x25');break;case'$lt':_0x956d49='<\x20?';break;case _0xc673('0x26'):_0x956d49=_0xc673('0x27');break;case _0xc673('0x13'):_0x956d49=_0xc673('0x28');break;case _0xc673('0x29'):_0x956d49='>=\x20?';break;case'$between':_0x956d49=_0xc673('0x2a');break;}return _0x956d49;}function parseValue(_0x393fd4,_0x41c7b2,_0x4d4bb0){var _0x2c8d18={'start':undefined,'end':undefined};switch(_0x41c7b2){case _0xc673('0x1f'):case'$notIn':_0x2c8d18[_0xc673('0x2b')]=_0x4d4bb0[_0xc673('0x7')](',');break;case _0xc673('0x2c'):_0x2c8d18[_0xc673('0x2b')]='%'+_0x4d4bb0+'%';break;case _0xc673('0x24'):_0x2c8d18['start']=_0x4d4bb0+'%';break;case'$endsWith':_0x2c8d18[_0xc673('0x2b')]='%'+_0x4d4bb0;break;case _0xc673('0x2d'):var _0x1c438a=_0x4d4bb0[_0xc673('0x7')](',');var _0x4d4bb0=_0x1c438a[_0xc673('0x2e')]();var _0x3ac512=_0x1c438a[_0xc673('0x2f')]();if(_0x393fd4===_0xc673('0x30')){_0x4d4bb0=moment(_0x4d4bb0)[_0xc673('0x31')](0x0,!![])[_0xc673('0x15')]();_0x3ac512=moment(_0x3ac512)[_0xc673('0x31')](0x0,!![])[_0xc673('0x32')](0x17,_0xc673('0x33'))['add'](0x3b,_0xc673('0x34'))[_0xc673('0x32')](0x3b,_0xc673('0x35'))[_0xc673('0x15')]();}_0x2c8d18={'start':_0x4d4bb0,'end':_0x3ac512};break;default:_0x2c8d18[_0xc673('0x2b')]=_0x4d4bb0;break;}return _0x2c8d18;}