Built motion from commit 14588770.|2.5.38
[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 _0xe057=['YYYY-MM-DD','castTo','text','CAST(','field','\x20AS\x20','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','=\x20?','$ne','<>\x20?','$substring','$startsWith','$endsWith','$lt','<\x20?','$lte','<=\x20?','>=\x20?','$between','BETWEEN\x20?\x20AND\x20?','start','pop','DATE','utcOffset','hours','minutes','seconds','lodash','sqlOperator','[$or]','and','replace','[$and]','split','length','slice','forEach','shift','match','filter','map','buildExpression','$eq','operator','value','includes','add','days','format'];(function(_0x4d82ea,_0x4d459f){var _0x257f4a=function(_0x424c4f){while(--_0x424c4f){_0x4d82ea['push'](_0x4d82ea['shift']());}};_0x257f4a(++_0x4d459f);}(_0xe057,0x156));var _0x7e05=function(_0x678720,_0x5d1b39){_0x678720=_0x678720-0x0;var _0x17a4e5=_0xe057[_0x678720];return _0x17a4e5;};'use strict';var _=require(_0x7e05('0x0'));var moment=require('moment');exports['parseSearch']=function(_0x59ca74){var _0x33c9ab={'conditions':[]};_0x33c9ab[_0x7e05('0x1')]=_['startsWith'](_0x59ca74,_0x7e05('0x2'))?'or':_0x7e05('0x3');var _0x5d1fa2=_0x59ca74[_0x7e05('0x4')](_0x7e05('0x5'),'')[_0x7e05('0x4')](_0x7e05('0x2'),'')[_0x7e05('0x6')]('||');for(var _0x435a83=0x0;_0x435a83<_0x5d1fa2[_0x7e05('0x7')];_0x435a83++){var _0x59f4c0=_0x5d1fa2[_0x435a83][_0x7e05('0x6')](':=');var _0x30b7d6=_0x59f4c0[0x0];var _0x1e18c9=_0x59f4c0[_0x7e05('0x8')](0x1);_0x1e18c9[_0x7e05('0x9')](function(_0x599464){var _0x8d7d21=_0x599464[_0x7e05('0x6')]('[')[_0x7e05('0xa')]();var _0x342212=_0x599464[_0x7e05('0xb')](/\[(.*?)\]/g);_0x342212[_0x7e05('0x9')](function(_0x265032){var _0x528c02=_0x265032[_0x7e05('0x6')]('[')[_0x7e05('0xc')](function(_0x2d7e6d){return _0x2d7e6d['indexOf'](']')>-0x1;})[_0x7e05('0xd')](function(_0x11e59c){return _0x11e59c['split'](']')[0x0];})[0x0];_0x33c9ab['conditions']['push']({'field':_0x30b7d6,'operator':_0x8d7d21,'value':_0x528c02});});});}return _0x33c9ab;};exports[_0x7e05('0xe')]=function(_0x225969,_0x1aff13,_0x2a01ec){var _0x1b3ae9={};if(_0x1aff13==='DATE'){if(_0x2a01ec['operator']===_0x7e05('0xf')){_0x2a01ec[_0x7e05('0x10')]='$between';_0x2a01ec[_0x7e05('0x11')]+=','+_0x2a01ec[_0x7e05('0x11')];}else if(_[_0x7e05('0x12')](['$gt','$lte'],_0x2a01ec[_0x7e05('0x10')])){_0x2a01ec[_0x7e05('0x11')]=moment(_0x2a01ec[_0x7e05('0x11')])[_0x7e05('0x13')](0x1,_0x7e05('0x14'))[_0x7e05('0x15')](_0x7e05('0x16'));}}if(_0x2a01ec[_0x7e05('0x17')]){_0x1aff13=_0x2a01ec[_0x7e05('0x17')];_0x1b3ae9[_0x7e05('0x18')]=_0x7e05('0x19')+_0x225969+'.'+_0x2a01ec[_0x7e05('0x1a')]+_0x7e05('0x1b')+_0x2a01ec[_0x7e05('0x17')]+')\x20'+parseOperator(_0x2a01ec[_0x7e05('0x10')]);}else{_0x1b3ae9['text']=_0x225969+'.'+_0x2a01ec[_0x7e05('0x1a')]+'\x20'+parseOperator(_0x2a01ec[_0x7e05('0x10')]);}if(_[_0x7e05('0x12')](['$ne',_0x7e05('0x1c')],_0x2a01ec[_0x7e05('0x10')]))_0x1b3ae9[_0x7e05('0x18')]='('+_0x1b3ae9[_0x7e05('0x18')]+_0x7e05('0x1d')+_0x225969+'.'+_0x2a01ec[_0x7e05('0x1a')]+_0x7e05('0x1e');_0x1b3ae9[_0x7e05('0x11')]=parseValue(_0x1aff13,_0x2a01ec['operator'],_0x2a01ec[_0x7e05('0x11')]);return _0x1b3ae9;};function parseOperator(_0x526d30){var _0x12f1b8;switch(_0x526d30){case _0x7e05('0x1f'):_0x12f1b8='IN\x20?';break;case _0x7e05('0x1c'):_0x12f1b8='NOT\x20IN\x20?';break;case _0x7e05('0xf'):_0x12f1b8=_0x7e05('0x20');break;case _0x7e05('0x21'):_0x12f1b8=_0x7e05('0x22');break;case _0x7e05('0x23'):case _0x7e05('0x24'):case _0x7e05('0x25'):_0x12f1b8='LIKE\x20?';break;case _0x7e05('0x26'):_0x12f1b8=_0x7e05('0x27');break;case'$gt':_0x12f1b8='>\x20?';break;case _0x7e05('0x28'):_0x12f1b8=_0x7e05('0x29');break;case'$gte':_0x12f1b8=_0x7e05('0x2a');break;case _0x7e05('0x2b'):_0x12f1b8=_0x7e05('0x2c');break;}return _0x12f1b8;}function parseValue(_0x4c87ba,_0x487136,_0x4e359a){var _0x4f12af={'start':undefined,'end':undefined};switch(_0x487136){case _0x7e05('0x1f'):case _0x7e05('0x1c'):_0x4f12af['start']=_0x4e359a['split'](',');break;case _0x7e05('0x23'):_0x4f12af[_0x7e05('0x2d')]='%'+_0x4e359a+'%';break;case _0x7e05('0x24'):_0x4f12af[_0x7e05('0x2d')]=_0x4e359a+'%';break;case _0x7e05('0x25'):_0x4f12af['start']='%'+_0x4e359a;break;case _0x7e05('0x2b'):var _0x262653=_0x4e359a['split'](',');var _0x4e359a=_0x262653[_0x7e05('0xa')]();var _0x263ad9=_0x262653[_0x7e05('0x2e')]();if(_0x4c87ba===_0x7e05('0x2f')){_0x4e359a=moment(_0x4e359a)['utcOffset'](0x0,!![])[_0x7e05('0x15')]();_0x263ad9=moment(_0x263ad9)[_0x7e05('0x30')](0x0,!![])[_0x7e05('0x13')](0x17,_0x7e05('0x31'))[_0x7e05('0x13')](0x3b,_0x7e05('0x32'))[_0x7e05('0x13')](0x3b,_0x7e05('0x33'))['format']();}_0x4f12af={'start':_0x4e359a,'end':_0x263ad9};break;default:_0x4f12af[_0x7e05('0x2d')]=_0x4e359a;break;}return _0x4f12af;}