7f82b5b8b78c8739ce4fe3f5f22c2a80a2326f4e
[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 _0x8e61=['seconds','lodash','sqlOperator','startsWith','and','replace','[$and]','[$or]','split','length','forEach','match','filter','indexOf','map','conditions','push','buildExpression','DATE','operator','$eq','$between','value','$lte','add','days','YYYY-MM-DD','castTo','text','CAST(','\x20AS\x20','field','includes','$ne','\x20OR\x20','$in','IN\x20?','$notIn','NOT\x20IN\x20?','=\x20?','<>\x20?','$substring','$startsWith','$endsWith','$lt','<\x20?','$gt','>\x20?','>=\x20?','start','shift','pop','format','utcOffset','hours','minutes'];(function(_0x521b61,_0x47e2b4){var _0x476cdf=function(_0xbca2ca){while(--_0xbca2ca){_0x521b61['push'](_0x521b61['shift']());}};_0x476cdf(++_0x47e2b4);}(_0x8e61,0x189));var _0x18e6=function(_0x2e4aa2,_0x11956a){_0x2e4aa2=_0x2e4aa2-0x0;var _0x5e6092=_0x8e61[_0x2e4aa2];return _0x5e6092;};'use strict';var _=require(_0x18e6('0x0'));var moment=require('moment');exports['parseSearch']=function(_0x2320cc){var _0x198181={'conditions':[]};_0x198181[_0x18e6('0x1')]=_[_0x18e6('0x2')](_0x2320cc,'[$or]')?'or':_0x18e6('0x3');var _0x21d46b=_0x2320cc[_0x18e6('0x4')](_0x18e6('0x5'),'')[_0x18e6('0x4')](_0x18e6('0x6'),'')[_0x18e6('0x7')]('||');for(var _0x2a3812=0x0;_0x2a3812<_0x21d46b[_0x18e6('0x8')];_0x2a3812++){var _0xf9d409=_0x21d46b[_0x2a3812][_0x18e6('0x7')](':=');var _0x1ade4a=_0xf9d409[0x0];var _0x16800e=_0xf9d409['slice'](0x1);_0x16800e[_0x18e6('0x9')](function(_0x2277d7){var _0x5aeef2=_0x2277d7[_0x18e6('0x7')]('[')['shift']();var _0x2a6024=_0x2277d7[_0x18e6('0xa')](/\[(.*?)\]/g);_0x2a6024[_0x18e6('0x9')](function(_0x27a1c9){var _0x4a11ac=_0x27a1c9['split']('[')[_0x18e6('0xb')](function(_0x2f6553){return _0x2f6553[_0x18e6('0xc')](']')>-0x1;})[_0x18e6('0xd')](function(_0x4f041b){return _0x4f041b[_0x18e6('0x7')](']')[0x0];})[0x0];_0x198181[_0x18e6('0xe')][_0x18e6('0xf')]({'field':_0x1ade4a,'operator':_0x5aeef2,'value':_0x4a11ac});});});}return _0x198181;};exports[_0x18e6('0x10')]=function(_0x2d62f5,_0x54759c,_0x51a448){var _0x4a6696={};if(_0x54759c===_0x18e6('0x11')){if(_0x51a448[_0x18e6('0x12')]===_0x18e6('0x13')){_0x51a448[_0x18e6('0x12')]=_0x18e6('0x14');_0x51a448[_0x18e6('0x15')]+=','+_0x51a448[_0x18e6('0x15')];}else if(_['includes'](['$gt',_0x18e6('0x16')],_0x51a448[_0x18e6('0x12')])){_0x51a448[_0x18e6('0x15')]=moment(_0x51a448[_0x18e6('0x15')])[_0x18e6('0x17')](0x1,_0x18e6('0x18'))['format'](_0x18e6('0x19'));}}if(_0x51a448[_0x18e6('0x1a')]){_0x54759c=_0x51a448['castTo'];_0x4a6696[_0x18e6('0x1b')]=_0x18e6('0x1c')+_0x2d62f5+'.'+_0x51a448['field']+_0x18e6('0x1d')+_0x51a448['castTo']+')\x20'+parseOperator(_0x51a448[_0x18e6('0x12')]);}else{_0x4a6696[_0x18e6('0x1b')]=_0x2d62f5+'.'+_0x51a448[_0x18e6('0x1e')]+'\x20'+parseOperator(_0x51a448[_0x18e6('0x12')]);}if(_[_0x18e6('0x1f')]([_0x18e6('0x20'),'$notIn'],_0x51a448['operator']))_0x4a6696[_0x18e6('0x1b')]='('+_0x4a6696[_0x18e6('0x1b')]+_0x18e6('0x21')+_0x2d62f5+'.'+_0x51a448[_0x18e6('0x1e')]+'\x20IS\x20NULL)';_0x4a6696[_0x18e6('0x15')]=parseValue(_0x54759c,_0x51a448[_0x18e6('0x12')],_0x51a448[_0x18e6('0x15')]);return _0x4a6696;};function parseOperator(_0x5cfb20){var _0x1edc60;switch(_0x5cfb20){case _0x18e6('0x22'):_0x1edc60=_0x18e6('0x23');break;case _0x18e6('0x24'):_0x1edc60=_0x18e6('0x25');break;case _0x18e6('0x13'):_0x1edc60=_0x18e6('0x26');break;case _0x18e6('0x20'):_0x1edc60=_0x18e6('0x27');break;case _0x18e6('0x28'):case _0x18e6('0x29'):case _0x18e6('0x2a'):_0x1edc60='LIKE\x20?';break;case _0x18e6('0x2b'):_0x1edc60=_0x18e6('0x2c');break;case _0x18e6('0x2d'):_0x1edc60=_0x18e6('0x2e');break;case _0x18e6('0x16'):_0x1edc60='<=\x20?';break;case'$gte':_0x1edc60=_0x18e6('0x2f');break;case _0x18e6('0x14'):_0x1edc60='BETWEEN\x20?\x20AND\x20?';break;}return _0x1edc60;}function parseValue(_0x42ea12,_0x2aca4e,_0x4f996c){var _0x34594d={'start':undefined,'end':undefined};switch(_0x2aca4e){case _0x18e6('0x22'):case _0x18e6('0x24'):_0x34594d['start']=_0x4f996c[_0x18e6('0x7')](',');break;case _0x18e6('0x28'):_0x34594d[_0x18e6('0x30')]='%'+_0x4f996c+'%';break;case _0x18e6('0x29'):_0x34594d[_0x18e6('0x30')]=_0x4f996c+'%';break;case _0x18e6('0x2a'):_0x34594d[_0x18e6('0x30')]='%'+_0x4f996c;break;case _0x18e6('0x14'):var _0x545981=_0x4f996c[_0x18e6('0x7')](',');var _0x4f996c=_0x545981[_0x18e6('0x31')]();var _0x553e29=_0x545981[_0x18e6('0x32')]();if(_0x42ea12===_0x18e6('0x11')){_0x4f996c=moment(_0x4f996c)['utcOffset'](0x0,!![])[_0x18e6('0x33')]();_0x553e29=moment(_0x553e29)[_0x18e6('0x34')](0x0,!![])[_0x18e6('0x17')](0x17,_0x18e6('0x35'))[_0x18e6('0x17')](0x3b,_0x18e6('0x36'))[_0x18e6('0x17')](0x3b,_0x18e6('0x37'))['format']();}_0x34594d={'start':_0x4f996c,'end':_0x553e29};break;default:_0x34594d[_0x18e6('0x30')]=_0x4f996c;break;}return _0x34594d;}