Built motion from commit 0900f080.|2.5.45
[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 _0x6960=['moment','parseSearch','sqlOperator','startsWith','[$or]','and','replace','length','split','slice','forEach','shift','match','filter','indexOf','map','conditions','operator','$between','value','includes','$lte','YYYY-MM-DD','text','CAST(','\x20AS\x20','castTo','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','$eq','<>\x20?','$startsWith','$endsWith','LIKE\x20?','$gt','>\x20?','$gte','>=\x20?','BETWEEN\x20?\x20AND\x20?','$substring','start','DATE','utcOffset','format','add','hours','lodash'];(function(_0x16bb1c,_0x58f468){var _0xace56c=function(_0x216f59){while(--_0x216f59){_0x16bb1c['push'](_0x16bb1c['shift']());}};_0xace56c(++_0x58f468);}(_0x6960,0xcf));var _0x0696=function(_0x21a9d9,_0x4d5ac8){_0x21a9d9=_0x21a9d9-0x0;var _0x46adce=_0x6960[_0x21a9d9];return _0x46adce;};'use strict';var _=require(_0x0696('0x0'));var moment=require(_0x0696('0x1'));exports[_0x0696('0x2')]=function(_0x1e022e){var _0x3f48a5={'conditions':[]};_0x3f48a5[_0x0696('0x3')]=_[_0x0696('0x4')](_0x1e022e,_0x0696('0x5'))?'or':_0x0696('0x6');var _0x5baf70=_0x1e022e['replace']('[$and]','')[_0x0696('0x7')](_0x0696('0x5'),'')['split']('||');for(var _0x1093d3=0x0;_0x1093d3<_0x5baf70[_0x0696('0x8')];_0x1093d3++){var _0x28eae4=_0x5baf70[_0x1093d3][_0x0696('0x9')](':=');var _0x1b8e4c=_0x28eae4[0x0];var _0x38622d=_0x28eae4[_0x0696('0xa')](0x1);_0x38622d[_0x0696('0xb')](function(_0x2ea9b4){var _0x4c52e0=_0x2ea9b4[_0x0696('0x9')]('[')[_0x0696('0xc')]();var _0x32753d=_0x2ea9b4[_0x0696('0xd')](/\[(.*?)\]/g);_0x32753d[_0x0696('0xb')](function(_0x451fd4){var _0x533835=_0x451fd4[_0x0696('0x9')]('[')[_0x0696('0xe')](function(_0x45d02d){return _0x45d02d[_0x0696('0xf')](']')>-0x1;})[_0x0696('0x10')](function(_0x304091){return _0x304091[_0x0696('0x9')](']')[0x0];})[0x0];_0x3f48a5[_0x0696('0x11')]['push']({'field':_0x1b8e4c,'operator':_0x4c52e0,'value':_0x533835});});});}return _0x3f48a5;};exports['buildExpression']=function(_0x2f38cb,_0x540299,_0x5b5455){var _0x504993={};if(_0x540299==='DATE'){if(_0x5b5455[_0x0696('0x12')]==='$eq'){_0x5b5455[_0x0696('0x12')]=_0x0696('0x13');_0x5b5455[_0x0696('0x14')]+=','+_0x5b5455[_0x0696('0x14')];}else if(_[_0x0696('0x15')](['$gt',_0x0696('0x16')],_0x5b5455['operator'])){_0x5b5455[_0x0696('0x14')]=moment(_0x5b5455[_0x0696('0x14')])['add'](0x1,'days')['format'](_0x0696('0x17'));}}if(_0x5b5455['castTo']){_0x540299=_0x5b5455['castTo'];_0x504993[_0x0696('0x18')]=_0x0696('0x19')+_0x2f38cb+'.'+_0x5b5455['field']+_0x0696('0x1a')+_0x5b5455[_0x0696('0x1b')]+')\x20'+parseOperator(_0x5b5455[_0x0696('0x12')]);}else{_0x504993['text']=_0x2f38cb+'.'+_0x5b5455[_0x0696('0x1c')]+'\x20'+parseOperator(_0x5b5455[_0x0696('0x12')]);}if(_[_0x0696('0x15')]([_0x0696('0x1d'),_0x0696('0x1e')],_0x5b5455[_0x0696('0x12')]))_0x504993[_0x0696('0x18')]='('+_0x504993[_0x0696('0x18')]+_0x0696('0x1f')+_0x2f38cb+'.'+_0x5b5455['field']+_0x0696('0x20');_0x504993['value']=parseValue(_0x540299,_0x5b5455[_0x0696('0x12')],_0x5b5455[_0x0696('0x14')]);return _0x504993;};function parseOperator(_0x28f3f5){var _0x432240;switch(_0x28f3f5){case _0x0696('0x21'):_0x432240=_0x0696('0x22');break;case _0x0696('0x1e'):_0x432240='NOT\x20IN\x20?';break;case _0x0696('0x23'):_0x432240='=\x20?';break;case _0x0696('0x1d'):_0x432240=_0x0696('0x24');break;case'$substring':case _0x0696('0x25'):case _0x0696('0x26'):_0x432240=_0x0696('0x27');break;case'$lt':_0x432240='<\x20?';break;case _0x0696('0x28'):_0x432240=_0x0696('0x29');break;case'$lte':_0x432240='<=\x20?';break;case _0x0696('0x2a'):_0x432240=_0x0696('0x2b');break;case _0x0696('0x13'):_0x432240=_0x0696('0x2c');break;}return _0x432240;}function parseValue(_0x1c57d2,_0x57417e,_0x750b2d){var _0x32003d={'start':undefined,'end':undefined};switch(_0x57417e){case'$in':case _0x0696('0x1e'):_0x32003d['start']=_0x750b2d['split'](',');break;case _0x0696('0x2d'):_0x32003d[_0x0696('0x2e')]='%'+_0x750b2d+'%';break;case _0x0696('0x25'):_0x32003d[_0x0696('0x2e')]=_0x750b2d+'%';break;case'$endsWith':_0x32003d[_0x0696('0x2e')]='%'+_0x750b2d;break;case _0x0696('0x13'):var _0x3b3ead=_0x750b2d['split'](',');var _0x750b2d=_0x3b3ead[_0x0696('0xc')]();var _0x4447fe=_0x3b3ead['pop']();if(_0x1c57d2===_0x0696('0x2f')){_0x750b2d=moment(_0x750b2d)[_0x0696('0x30')](0x0,!![])[_0x0696('0x31')]();_0x4447fe=moment(_0x4447fe)[_0x0696('0x30')](0x0,!![])[_0x0696('0x32')](0x17,_0x0696('0x33'))[_0x0696('0x32')](0x3b,'minutes')[_0x0696('0x32')](0x3b,'seconds')[_0x0696('0x31')]();}_0x32003d={'start':_0x750b2d,'end':_0x4447fe};break;default:_0x32003d[_0x0696('0x2e')]=_0x750b2d;break;}return _0x32003d;}