Built motion from commit 9d7072cc.|2.5.39
[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 _0x223e=['parseSearch','sqlOperator','startsWith','[$or]','and','replace','split','length','slice','shift','match','forEach','indexOf','conditions','push','DATE','operator','value','includes','$gt','$lte','add','format','YYYY-MM-DD','castTo','text','field','\x20AS\x20','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','=\x20?','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','<=\x20?','$gte','>=\x20?','$between','BETWEEN\x20?\x20AND\x20?','start','$substring','pop','utcOffset','hours','minutes','lodash','moment'];(function(_0x4054a4,_0x1f5fc8){var _0x42fc0a=function(_0x12aa66){while(--_0x12aa66){_0x4054a4['push'](_0x4054a4['shift']());}};_0x42fc0a(++_0x1f5fc8);}(_0x223e,0x16a));var _0xe223=function(_0x574617,_0x42eccc){_0x574617=_0x574617-0x0;var _0x29de90=_0x223e[_0x574617];return _0x29de90;};'use strict';var _=require(_0xe223('0x0'));var moment=require(_0xe223('0x1'));exports[_0xe223('0x2')]=function(_0x2d5c6d){var _0x342f36={'conditions':[]};_0x342f36[_0xe223('0x3')]=_[_0xe223('0x4')](_0x2d5c6d,_0xe223('0x5'))?'or':_0xe223('0x6');var _0x534779=_0x2d5c6d[_0xe223('0x7')]('[$and]','')[_0xe223('0x7')](_0xe223('0x5'),'')[_0xe223('0x8')]('||');for(var _0x51d6bf=0x0;_0x51d6bf<_0x534779[_0xe223('0x9')];_0x51d6bf++){var _0x499071=_0x534779[_0x51d6bf]['split'](':=');var _0x5833a7=_0x499071[0x0];var _0x2475f9=_0x499071[_0xe223('0xa')](0x1);_0x2475f9['forEach'](function(_0x39d872){var _0x5f1a1e=_0x39d872['split']('[')[_0xe223('0xb')]();var _0x42c8db=_0x39d872[_0xe223('0xc')](/\[(.*?)\]/g);_0x42c8db[_0xe223('0xd')](function(_0x3755df){var _0x3928e5=_0x3755df[_0xe223('0x8')]('[')['filter'](function(_0x34e981){return _0x34e981[_0xe223('0xe')](']')>-0x1;})['map'](function(_0x2e3803){return _0x2e3803['split'](']')[0x0];})[0x0];_0x342f36[_0xe223('0xf')][_0xe223('0x10')]({'field':_0x5833a7,'operator':_0x5f1a1e,'value':_0x3928e5});});});}return _0x342f36;};exports['buildExpression']=function(_0x1dad12,_0xaa2537,_0x31b028){var _0x4046e9={};if(_0xaa2537===_0xe223('0x11')){if(_0x31b028[_0xe223('0x12')]==='$eq'){_0x31b028['operator']='$between';_0x31b028[_0xe223('0x13')]+=','+_0x31b028['value'];}else if(_[_0xe223('0x14')]([_0xe223('0x15'),_0xe223('0x16')],_0x31b028[_0xe223('0x12')])){_0x31b028['value']=moment(_0x31b028['value'])[_0xe223('0x17')](0x1,'days')[_0xe223('0x18')](_0xe223('0x19'));}}if(_0x31b028[_0xe223('0x1a')]){_0xaa2537=_0x31b028[_0xe223('0x1a')];_0x4046e9[_0xe223('0x1b')]='CAST('+_0x1dad12+'.'+_0x31b028[_0xe223('0x1c')]+_0xe223('0x1d')+_0x31b028[_0xe223('0x1a')]+')\x20'+parseOperator(_0x31b028[_0xe223('0x12')]);}else{_0x4046e9[_0xe223('0x1b')]=_0x1dad12+'.'+_0x31b028[_0xe223('0x1c')]+'\x20'+parseOperator(_0x31b028[_0xe223('0x12')]);}if(_['includes']([_0xe223('0x1e'),_0xe223('0x1f')],_0x31b028['operator']))_0x4046e9[_0xe223('0x1b')]='('+_0x4046e9[_0xe223('0x1b')]+_0xe223('0x20')+_0x1dad12+'.'+_0x31b028[_0xe223('0x1c')]+_0xe223('0x21');_0x4046e9[_0xe223('0x13')]=parseValue(_0xaa2537,_0x31b028[_0xe223('0x12')],_0x31b028[_0xe223('0x13')]);return _0x4046e9;};function parseOperator(_0x49c51f){var _0x1a7460;switch(_0x49c51f){case _0xe223('0x22'):_0x1a7460='IN\x20?';break;case _0xe223('0x1f'):_0x1a7460='NOT\x20IN\x20?';break;case'$eq':_0x1a7460=_0xe223('0x23');break;case _0xe223('0x1e'):_0x1a7460='<>\x20?';break;case'$substring':case _0xe223('0x24'):case _0xe223('0x25'):_0x1a7460=_0xe223('0x26');break;case _0xe223('0x27'):_0x1a7460=_0xe223('0x28');break;case _0xe223('0x15'):_0x1a7460='>\x20?';break;case _0xe223('0x16'):_0x1a7460=_0xe223('0x29');break;case _0xe223('0x2a'):_0x1a7460=_0xe223('0x2b');break;case _0xe223('0x2c'):_0x1a7460=_0xe223('0x2d');break;}return _0x1a7460;}function parseValue(_0x357964,_0x5d95a3,_0x4decee){var _0xd0ce9d={'start':undefined,'end':undefined};switch(_0x5d95a3){case _0xe223('0x22'):case _0xe223('0x1f'):_0xd0ce9d[_0xe223('0x2e')]=_0x4decee[_0xe223('0x8')](',');break;case _0xe223('0x2f'):_0xd0ce9d['start']='%'+_0x4decee+'%';break;case _0xe223('0x24'):_0xd0ce9d[_0xe223('0x2e')]=_0x4decee+'%';break;case _0xe223('0x25'):_0xd0ce9d['start']='%'+_0x4decee;break;case'$between':var _0x46ee1c=_0x4decee[_0xe223('0x8')](',');var _0x4decee=_0x46ee1c[_0xe223('0xb')]();var _0x140bc1=_0x46ee1c[_0xe223('0x30')]();if(_0x357964===_0xe223('0x11')){_0x4decee=moment(_0x4decee)[_0xe223('0x31')](0x0,!![])[_0xe223('0x18')]();_0x140bc1=moment(_0x140bc1)[_0xe223('0x31')](0x0,!![])[_0xe223('0x17')](0x17,_0xe223('0x32'))['add'](0x3b,_0xe223('0x33'))['add'](0x3b,'seconds')[_0xe223('0x18')]();}_0xd0ce9d={'start':_0x4decee,'end':_0x140bc1};break;default:_0xd0ce9d['start']=_0x4decee;break;}return _0xd0ce9d;}