Built motion from commit 43538d75.|2.5.35
[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 _0x4eb3=['shift','pop','utcOffset','hours','minutes','lodash','moment','parseSearch','sqlOperator','startsWith','and','replace','[$and]','[$or]','length','split','slice','forEach','match','filter','indexOf','conditions','push','buildExpression','DATE','$eq','operator','$between','value','includes','$lte','add','days','format','YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','LIKE\x20?','$gt','>\x20?','<=\x20?','$gte','>=\x20?','$in','start'];(function(_0xd629f3,_0x2b4ce8){var _0x20f5bd=function(_0x379a24){while(--_0x379a24){_0xd629f3['push'](_0xd629f3['shift']());}};_0x20f5bd(++_0x2b4ce8);}(_0x4eb3,0x19b));var _0x34eb=function(_0x4e7551,_0x398ee5){_0x4e7551=_0x4e7551-0x0;var _0x2c2ae8=_0x4eb3[_0x4e7551];return _0x2c2ae8;};'use strict';var _=require(_0x34eb('0x0'));var moment=require(_0x34eb('0x1'));exports[_0x34eb('0x2')]=function(_0x1c6164){var _0x3d61f7={'conditions':[]};_0x3d61f7[_0x34eb('0x3')]=_[_0x34eb('0x4')](_0x1c6164,'[$or]')?'or':_0x34eb('0x5');var _0x575431=_0x1c6164[_0x34eb('0x6')](_0x34eb('0x7'),'')[_0x34eb('0x6')](_0x34eb('0x8'),'')['split']('||');for(var _0x49fef0=0x0;_0x49fef0<_0x575431[_0x34eb('0x9')];_0x49fef0++){var _0x562893=_0x575431[_0x49fef0][_0x34eb('0xa')](':=');var _0x18e3ca=_0x562893[0x0];var _0x471303=_0x562893[_0x34eb('0xb')](0x1);_0x471303[_0x34eb('0xc')](function(_0x292ff8){var _0x5eb924=_0x292ff8[_0x34eb('0xa')]('[')['shift']();var _0x565eb3=_0x292ff8[_0x34eb('0xd')](/\[(.*?)\]/g);_0x565eb3['forEach'](function(_0x263e89){var _0x32d17a=_0x263e89[_0x34eb('0xa')]('[')[_0x34eb('0xe')](function(_0xd20782){return _0xd20782[_0x34eb('0xf')](']')>-0x1;})['map'](function(_0x3cd92a){return _0x3cd92a[_0x34eb('0xa')](']')[0x0];})[0x0];_0x3d61f7[_0x34eb('0x10')][_0x34eb('0x11')]({'field':_0x18e3ca,'operator':_0x5eb924,'value':_0x32d17a});});});}return _0x3d61f7;};exports[_0x34eb('0x12')]=function(_0x3a9c97,_0x15ded2,_0x2c3da2){var _0x3f7a80={};if(_0x15ded2===_0x34eb('0x13')){if(_0x2c3da2['operator']===_0x34eb('0x14')){_0x2c3da2[_0x34eb('0x15')]=_0x34eb('0x16');_0x2c3da2[_0x34eb('0x17')]+=','+_0x2c3da2[_0x34eb('0x17')];}else if(_[_0x34eb('0x18')](['$gt',_0x34eb('0x19')],_0x2c3da2[_0x34eb('0x15')])){_0x2c3da2[_0x34eb('0x17')]=moment(_0x2c3da2[_0x34eb('0x17')])[_0x34eb('0x1a')](0x1,_0x34eb('0x1b'))[_0x34eb('0x1c')](_0x34eb('0x1d'));}}if(_0x2c3da2['castTo']){_0x15ded2=_0x2c3da2[_0x34eb('0x1e')];_0x3f7a80[_0x34eb('0x1f')]=_0x34eb('0x20')+_0x3a9c97+'.'+_0x2c3da2[_0x34eb('0x21')]+_0x34eb('0x22')+_0x2c3da2[_0x34eb('0x1e')]+')\x20'+parseOperator(_0x2c3da2['operator']);}else{_0x3f7a80[_0x34eb('0x1f')]=_0x3a9c97+'.'+_0x2c3da2['field']+'\x20'+parseOperator(_0x2c3da2['operator']);}if(_['includes']([_0x34eb('0x23'),_0x34eb('0x24')],_0x2c3da2['operator']))_0x3f7a80['text']='('+_0x3f7a80[_0x34eb('0x1f')]+_0x34eb('0x25')+_0x3a9c97+'.'+_0x2c3da2[_0x34eb('0x21')]+_0x34eb('0x26');_0x3f7a80[_0x34eb('0x17')]=parseValue(_0x15ded2,_0x2c3da2['operator'],_0x2c3da2[_0x34eb('0x17')]);return _0x3f7a80;};function parseOperator(_0x494076){var _0x2558de;switch(_0x494076){case'$in':_0x2558de=_0x34eb('0x27');break;case _0x34eb('0x24'):_0x2558de='NOT\x20IN\x20?';break;case'$eq':_0x2558de=_0x34eb('0x28');break;case _0x34eb('0x23'):_0x2558de=_0x34eb('0x29');break;case _0x34eb('0x2a'):case _0x34eb('0x2b'):case _0x34eb('0x2c'):_0x2558de=_0x34eb('0x2d');break;case'$lt':_0x2558de='<\x20?';break;case _0x34eb('0x2e'):_0x2558de=_0x34eb('0x2f');break;case _0x34eb('0x19'):_0x2558de=_0x34eb('0x30');break;case _0x34eb('0x31'):_0x2558de=_0x34eb('0x32');break;case _0x34eb('0x16'):_0x2558de='BETWEEN\x20?\x20AND\x20?';break;}return _0x2558de;}function parseValue(_0x16e5bd,_0x545392,_0x4e9d99){var _0x538a1f={'start':undefined,'end':undefined};switch(_0x545392){case _0x34eb('0x33'):case'$notIn':_0x538a1f[_0x34eb('0x34')]=_0x4e9d99[_0x34eb('0xa')](',');break;case'$substring':_0x538a1f['start']='%'+_0x4e9d99+'%';break;case _0x34eb('0x2b'):_0x538a1f['start']=_0x4e9d99+'%';break;case'$endsWith':_0x538a1f['start']='%'+_0x4e9d99;break;case _0x34eb('0x16'):var _0x6b85a0=_0x4e9d99[_0x34eb('0xa')](',');var _0x4e9d99=_0x6b85a0[_0x34eb('0x35')]();var _0x4e8265=_0x6b85a0[_0x34eb('0x36')]();if(_0x16e5bd===_0x34eb('0x13')){_0x4e9d99=moment(_0x4e9d99)['utcOffset'](0x0,!![])[_0x34eb('0x1c')]();_0x4e8265=moment(_0x4e8265)[_0x34eb('0x37')](0x0,!![])[_0x34eb('0x1a')](0x17,_0x34eb('0x38'))['add'](0x3b,_0x34eb('0x39'))[_0x34eb('0x1a')](0x3b,'seconds')[_0x34eb('0x1c')]();}_0x538a1f={'start':_0x4e9d99,'end':_0x4e8265};break;default:_0x538a1f['start']=_0x4e9d99;break;}return _0x538a1f;}