Built motion from commit (unavailable).|2.5.30
[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 _0x2623=['shift','pop','utcOffset','add','hours','seconds','lodash','sqlOperator','startsWith','[$or]','[$and]','replace','split','length','match','conditions','push','buildExpression','DATE','operator','$eq','$between','value','$gt','$lte','days','format','YYYY-MM-DD','castTo','text','CAST(','field','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','=\x20?','<>\x20?','$startsWith','$endsWith','$lt','<\x20?','>\x20?','<=\x20?','>=\x20?','BETWEEN\x20?\x20AND\x20?','start','$substring'];(function(_0xdbe2de,_0x3bdc5a){var _0x2facd7=function(_0x50df58){while(--_0x50df58){_0xdbe2de['push'](_0xdbe2de['shift']());}};_0x2facd7(++_0x3bdc5a);}(_0x2623,0x164));var _0x3262=function(_0x1196bd,_0xba4aea){_0x1196bd=_0x1196bd-0x0;var _0x26014f=_0x2623[_0x1196bd];return _0x26014f;};'use strict';var _=require(_0x3262('0x0'));var moment=require('moment');exports['parseSearch']=function(_0x5154f2){var _0x36808a={'conditions':[]};_0x36808a[_0x3262('0x1')]=_[_0x3262('0x2')](_0x5154f2,_0x3262('0x3'))?'or':'and';var _0x567eee=_0x5154f2['replace'](_0x3262('0x4'),'')[_0x3262('0x5')]('[$or]','')[_0x3262('0x6')]('||');for(var _0x3adac2=0x0;_0x3adac2<_0x567eee[_0x3262('0x7')];_0x3adac2++){var _0x4efd4b=_0x567eee[_0x3adac2][_0x3262('0x6')](':=');var _0x565bc4=_0x4efd4b[0x0];var _0x5d5a85=_0x4efd4b['slice'](0x1);_0x5d5a85['forEach'](function(_0x3a1833){var _0x5c1aff=_0x3a1833[_0x3262('0x6')]('[')['shift']();var _0x203c6e=_0x3a1833[_0x3262('0x8')](/\[(.*?)\]/g);_0x203c6e['forEach'](function(_0x283913){var _0x5d2873=_0x283913['split']('[')['filter'](function(_0x5c536b){return _0x5c536b['indexOf'](']')>-0x1;})['map'](function(_0x4853e2){return _0x4853e2[_0x3262('0x6')](']')[0x0];})[0x0];_0x36808a[_0x3262('0x9')][_0x3262('0xa')]({'field':_0x565bc4,'operator':_0x5c1aff,'value':_0x5d2873});});});}return _0x36808a;};exports[_0x3262('0xb')]=function(_0x2ca7eb,_0x1e5c71,_0x2d9d07){var _0x585e30={};if(_0x1e5c71===_0x3262('0xc')){if(_0x2d9d07[_0x3262('0xd')]===_0x3262('0xe')){_0x2d9d07[_0x3262('0xd')]=_0x3262('0xf');_0x2d9d07[_0x3262('0x10')]+=','+_0x2d9d07[_0x3262('0x10')];}else if(_['includes']([_0x3262('0x11'),_0x3262('0x12')],_0x2d9d07['operator'])){_0x2d9d07[_0x3262('0x10')]=moment(_0x2d9d07[_0x3262('0x10')])['add'](0x1,_0x3262('0x13'))[_0x3262('0x14')](_0x3262('0x15'));}}if(_0x2d9d07[_0x3262('0x16')]){_0x1e5c71=_0x2d9d07[_0x3262('0x16')];_0x585e30[_0x3262('0x17')]=_0x3262('0x18')+_0x2ca7eb+'.'+_0x2d9d07['field']+'\x20AS\x20'+_0x2d9d07['castTo']+')\x20'+parseOperator(_0x2d9d07[_0x3262('0xd')]);}else{_0x585e30['text']=_0x2ca7eb+'.'+_0x2d9d07[_0x3262('0x19')]+'\x20'+parseOperator(_0x2d9d07[_0x3262('0xd')]);}if(_['includes'](['$ne',_0x3262('0x1a')],_0x2d9d07[_0x3262('0xd')]))_0x585e30[_0x3262('0x17')]='('+_0x585e30['text']+_0x3262('0x1b')+_0x2ca7eb+'.'+_0x2d9d07['field']+_0x3262('0x1c');_0x585e30[_0x3262('0x10')]=parseValue(_0x1e5c71,_0x2d9d07['operator'],_0x2d9d07['value']);return _0x585e30;};function parseOperator(_0x5b6dfd){var _0x1ce818;switch(_0x5b6dfd){case _0x3262('0x1d'):_0x1ce818=_0x3262('0x1e');break;case _0x3262('0x1a'):_0x1ce818=_0x3262('0x1f');break;case _0x3262('0xe'):_0x1ce818=_0x3262('0x20');break;case'$ne':_0x1ce818=_0x3262('0x21');break;case'$substring':case _0x3262('0x22'):case _0x3262('0x23'):_0x1ce818='LIKE\x20?';break;case _0x3262('0x24'):_0x1ce818=_0x3262('0x25');break;case _0x3262('0x11'):_0x1ce818=_0x3262('0x26');break;case _0x3262('0x12'):_0x1ce818=_0x3262('0x27');break;case'$gte':_0x1ce818=_0x3262('0x28');break;case _0x3262('0xf'):_0x1ce818=_0x3262('0x29');break;}return _0x1ce818;}function parseValue(_0x5ec5a0,_0x706015,_0x58cb34){var _0x37ce13={'start':undefined,'end':undefined};switch(_0x706015){case'$in':case'$notIn':_0x37ce13[_0x3262('0x2a')]=_0x58cb34['split'](',');break;case _0x3262('0x2b'):_0x37ce13[_0x3262('0x2a')]='%'+_0x58cb34+'%';break;case _0x3262('0x22'):_0x37ce13[_0x3262('0x2a')]=_0x58cb34+'%';break;case'$endsWith':_0x37ce13[_0x3262('0x2a')]='%'+_0x58cb34;break;case'$between':var _0x26cac6=_0x58cb34['split'](',');var _0x58cb34=_0x26cac6[_0x3262('0x2c')]();var _0x1f7037=_0x26cac6[_0x3262('0x2d')]();if(_0x5ec5a0===_0x3262('0xc')){_0x58cb34=moment(_0x58cb34)[_0x3262('0x2e')](0x0,!![])[_0x3262('0x14')]();_0x1f7037=moment(_0x1f7037)['utcOffset'](0x0,!![])[_0x3262('0x2f')](0x17,_0x3262('0x30'))[_0x3262('0x2f')](0x3b,'minutes')[_0x3262('0x2f')](0x3b,_0x3262('0x31'))[_0x3262('0x14')]();}_0x37ce13={'start':_0x58cb34,'end':_0x1f7037};break;default:_0x37ce13[_0x3262('0x2a')]=_0x58cb34;break;}return _0x37ce13;}