Built motion from commit (unavailable).|2.4.20
[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 _0x65a8=['$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','NOT\x20IN\x20?','=\x20?','$startsWith','$endsWith','LIKE\x20?','$lt','<\x20?','>\x20?','$between','BETWEEN\x20?\x20AND\x20?','start','$substring','shift','pop','DATE','utcOffset','minutes','seconds','lodash','parseSearch','startsWith','[$or]','replace','[$and]','split','slice','forEach','indexOf','map','conditions','operator','$eq','value','includes','$gt','$lte','add','days','format','YYYY-MM-DD','castTo','text','CAST(','field','$ne'];(function(_0x28fcdc,_0x17e930){var _0x80bd4c=function(_0x2c490d){while(--_0x2c490d){_0x28fcdc['push'](_0x28fcdc['shift']());}};_0x80bd4c(++_0x17e930);}(_0x65a8,0x1cf));var _0x865a=function(_0x57b54c,_0x54ce0d){_0x57b54c=_0x57b54c-0x0;var _0x59cc19=_0x65a8[_0x57b54c];return _0x59cc19;};'use strict';var _=require(_0x865a('0x0'));var moment=require('moment');exports[_0x865a('0x1')]=function(_0x38b04d){var _0x5c51e4={'conditions':[]};_0x5c51e4['sqlOperator']=_[_0x865a('0x2')](_0x38b04d,_0x865a('0x3'))?'or':'and';var _0x42b006=_0x38b04d[_0x865a('0x4')](_0x865a('0x5'),'')[_0x865a('0x4')](_0x865a('0x3'),'')[_0x865a('0x6')]('||');for(var _0x4cf4e8=0x0;_0x4cf4e8<_0x42b006['length'];_0x4cf4e8++){var _0x487b52=_0x42b006[_0x4cf4e8][_0x865a('0x6')](':=');var _0x25a6e0=_0x487b52[0x0];var _0x3935e0=_0x487b52[_0x865a('0x7')](0x1);_0x3935e0[_0x865a('0x8')](function(_0x427cfd){var _0x4b86fa=_0x427cfd[_0x865a('0x6')]('[')['shift']();var _0x4d07ad=_0x427cfd['match'](/\[(.*?)\]/g);_0x4d07ad['forEach'](function(_0x49958a){var _0x926454=_0x49958a['split']('[')['filter'](function(_0x522f04){return _0x522f04[_0x865a('0x9')](']')>-0x1;})[_0x865a('0xa')](function(_0x366a32){return _0x366a32[_0x865a('0x6')](']')[0x0];})[0x0];_0x5c51e4[_0x865a('0xb')]['push']({'field':_0x25a6e0,'operator':_0x4b86fa,'value':_0x926454});});});}return _0x5c51e4;};exports['buildExpression']=function(_0x122773,_0x1f1efa,_0x1977a6){var _0x332b5b={};if(_0x1f1efa==='DATE'){if(_0x1977a6[_0x865a('0xc')]===_0x865a('0xd')){_0x1977a6['operator']='$between';_0x1977a6[_0x865a('0xe')]+=','+_0x1977a6[_0x865a('0xe')];}else if(_[_0x865a('0xf')]([_0x865a('0x10'),_0x865a('0x11')],_0x1977a6[_0x865a('0xc')])){_0x1977a6[_0x865a('0xe')]=moment(_0x1977a6[_0x865a('0xe')])[_0x865a('0x12')](0x1,_0x865a('0x13'))[_0x865a('0x14')](_0x865a('0x15'));}}if(_0x1977a6[_0x865a('0x16')]){_0x1f1efa=_0x1977a6['castTo'];_0x332b5b[_0x865a('0x17')]=_0x865a('0x18')+_0x122773+'.'+_0x1977a6[_0x865a('0x19')]+'\x20AS\x20'+_0x1977a6[_0x865a('0x16')]+')\x20'+parseOperator(_0x1977a6['operator']);}else{_0x332b5b['text']=_0x122773+'.'+_0x1977a6[_0x865a('0x19')]+'\x20'+parseOperator(_0x1977a6[_0x865a('0xc')]);}if(_['includes']([_0x865a('0x1a'),_0x865a('0x1b')],_0x1977a6['operator']))_0x332b5b[_0x865a('0x17')]='('+_0x332b5b[_0x865a('0x17')]+_0x865a('0x1c')+_0x122773+'.'+_0x1977a6['field']+_0x865a('0x1d');_0x332b5b['value']=parseValue(_0x1f1efa,_0x1977a6[_0x865a('0xc')],_0x1977a6[_0x865a('0xe')]);return _0x332b5b;};function parseOperator(_0x464580){var _0x1b8f58;switch(_0x464580){case _0x865a('0x1e'):_0x1b8f58='IN\x20?';break;case'$notIn':_0x1b8f58=_0x865a('0x1f');break;case _0x865a('0xd'):_0x1b8f58=_0x865a('0x20');break;case _0x865a('0x1a'):_0x1b8f58='<>\x20?';break;case'$substring':case _0x865a('0x21'):case _0x865a('0x22'):_0x1b8f58=_0x865a('0x23');break;case _0x865a('0x24'):_0x1b8f58=_0x865a('0x25');break;case _0x865a('0x10'):_0x1b8f58=_0x865a('0x26');break;case _0x865a('0x11'):_0x1b8f58='<=\x20?';break;case'$gte':_0x1b8f58='>=\x20?';break;case _0x865a('0x27'):_0x1b8f58=_0x865a('0x28');break;}return _0x1b8f58;}function parseValue(_0x1bc71a,_0x43eb8b,_0x3ef8dd){var _0x5f3119={'start':undefined,'end':undefined};switch(_0x43eb8b){case _0x865a('0x1e'):case _0x865a('0x1b'):_0x5f3119[_0x865a('0x29')]=_0x3ef8dd['split'](',');break;case _0x865a('0x2a'):_0x5f3119[_0x865a('0x29')]='%'+_0x3ef8dd+'%';break;case _0x865a('0x21'):_0x5f3119['start']=_0x3ef8dd+'%';break;case'$endsWith':_0x5f3119[_0x865a('0x29')]='%'+_0x3ef8dd;break;case'$between':var _0x343b10=_0x3ef8dd[_0x865a('0x6')](',');var _0x3ef8dd=_0x343b10[_0x865a('0x2b')]();var _0x1bad16=_0x343b10[_0x865a('0x2c')]();if(_0x1bc71a===_0x865a('0x2d')){_0x3ef8dd=moment(_0x3ef8dd)[_0x865a('0x2e')](0x0,!![])['format']();_0x1bad16=moment(_0x1bad16)[_0x865a('0x2e')](0x0,!![])[_0x865a('0x12')](0x17,'hours')['add'](0x3b,_0x865a('0x2f'))['add'](0x3b,_0x865a('0x30'))[_0x865a('0x14')]();}_0x5f3119={'start':_0x3ef8dd,'end':_0x1bad16};break;default:_0x5f3119[_0x865a('0x29')]=_0x3ef8dd;break;}return _0x5f3119;}