Built motion from commit (unavailable).|2.5.6
[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 _0x289f=['LIKE\x20?','$lt','<\x20?','<=\x20?','$gte','>=\x20?','start','shift','pop','hours','lodash','moment','parseSearch','sqlOperator','startsWith','replace','[$and]','[$or]','split','length','match','forEach','indexOf','map','conditions','buildExpression','DATE','operator','$between','value','includes','$lte','add','days','format','YYYY-MM-DD','castTo','CAST(','text','field','$ne','$notIn','\x20OR\x20','\x20IS\x20NULL)','$in','IN\x20?','NOT\x20IN\x20?','$eq','$substring','$startsWith','$endsWith'];(function(_0x52cbc6,_0x3a9e07){var _0x5b7ee5=function(_0x5caebb){while(--_0x5caebb){_0x52cbc6['push'](_0x52cbc6['shift']());}};_0x5b7ee5(++_0x3a9e07);}(_0x289f,0x1d5));var _0xf289=function(_0x40220a,_0x22feb1){_0x40220a=_0x40220a-0x0;var _0x3903cc=_0x289f[_0x40220a];return _0x3903cc;};'use strict';var _=require(_0xf289('0x0'));var moment=require(_0xf289('0x1'));exports[_0xf289('0x2')]=function(_0x18c6aa){var _0x4c722c={'conditions':[]};_0x4c722c[_0xf289('0x3')]=_[_0xf289('0x4')](_0x18c6aa,'[$or]')?'or':'and';var _0x4410c0=_0x18c6aa[_0xf289('0x5')](_0xf289('0x6'),'')[_0xf289('0x5')](_0xf289('0x7'),'')[_0xf289('0x8')]('||');for(var _0x48c500=0x0;_0x48c500<_0x4410c0[_0xf289('0x9')];_0x48c500++){var _0x1fdb00=_0x4410c0[_0x48c500]['split'](':=');var _0xec8124=_0x1fdb00[0x0];var _0x4cd307=_0x1fdb00['slice'](0x1);_0x4cd307['forEach'](function(_0x208bdc){var _0x3f8911=_0x208bdc['split']('[')['shift']();var _0x58c684=_0x208bdc[_0xf289('0xa')](/\[(.*?)\]/g);_0x58c684[_0xf289('0xb')](function(_0x1d5649){var _0x2664aa=_0x1d5649[_0xf289('0x8')]('[')['filter'](function(_0x45631c){return _0x45631c[_0xf289('0xc')](']')>-0x1;})[_0xf289('0xd')](function(_0x2832d6){return _0x2832d6[_0xf289('0x8')](']')[0x0];})[0x0];_0x4c722c[_0xf289('0xe')]['push']({'field':_0xec8124,'operator':_0x3f8911,'value':_0x2664aa});});});}return _0x4c722c;};exports[_0xf289('0xf')]=function(_0x2cff8d,_0x2ee8a3,_0x58b2ea){var _0x3a3462={};if(_0x2ee8a3===_0xf289('0x10')){if(_0x58b2ea[_0xf289('0x11')]==='$eq'){_0x58b2ea['operator']=_0xf289('0x12');_0x58b2ea[_0xf289('0x13')]+=','+_0x58b2ea[_0xf289('0x13')];}else if(_[_0xf289('0x14')](['$gt',_0xf289('0x15')],_0x58b2ea[_0xf289('0x11')])){_0x58b2ea[_0xf289('0x13')]=moment(_0x58b2ea[_0xf289('0x13')])[_0xf289('0x16')](0x1,_0xf289('0x17'))[_0xf289('0x18')](_0xf289('0x19'));}}if(_0x58b2ea[_0xf289('0x1a')]){_0x2ee8a3=_0x58b2ea[_0xf289('0x1a')];_0x3a3462['text']=_0xf289('0x1b')+_0x2cff8d+'.'+_0x58b2ea['field']+'\x20AS\x20'+_0x58b2ea[_0xf289('0x1a')]+')\x20'+parseOperator(_0x58b2ea[_0xf289('0x11')]);}else{_0x3a3462[_0xf289('0x1c')]=_0x2cff8d+'.'+_0x58b2ea[_0xf289('0x1d')]+'\x20'+parseOperator(_0x58b2ea['operator']);}if(_[_0xf289('0x14')]([_0xf289('0x1e'),_0xf289('0x1f')],_0x58b2ea[_0xf289('0x11')]))_0x3a3462[_0xf289('0x1c')]='('+_0x3a3462['text']+_0xf289('0x20')+_0x2cff8d+'.'+_0x58b2ea[_0xf289('0x1d')]+_0xf289('0x21');_0x3a3462[_0xf289('0x13')]=parseValue(_0x2ee8a3,_0x58b2ea[_0xf289('0x11')],_0x58b2ea[_0xf289('0x13')]);return _0x3a3462;};function parseOperator(_0x3b1b4b){var _0xbb39ba;switch(_0x3b1b4b){case _0xf289('0x22'):_0xbb39ba=_0xf289('0x23');break;case _0xf289('0x1f'):_0xbb39ba=_0xf289('0x24');break;case _0xf289('0x25'):_0xbb39ba='=\x20?';break;case'$ne':_0xbb39ba='<>\x20?';break;case _0xf289('0x26'):case _0xf289('0x27'):case _0xf289('0x28'):_0xbb39ba=_0xf289('0x29');break;case _0xf289('0x2a'):_0xbb39ba=_0xf289('0x2b');break;case'$gt':_0xbb39ba='>\x20?';break;case _0xf289('0x15'):_0xbb39ba=_0xf289('0x2c');break;case _0xf289('0x2d'):_0xbb39ba=_0xf289('0x2e');break;case'$between':_0xbb39ba='BETWEEN\x20?\x20AND\x20?';break;}return _0xbb39ba;}function parseValue(_0x2fd8ca,_0x3d93d6,_0x5a736c){var _0x806eb={'start':undefined,'end':undefined};switch(_0x3d93d6){case _0xf289('0x22'):case _0xf289('0x1f'):_0x806eb[_0xf289('0x2f')]=_0x5a736c['split'](',');break;case'$substring':_0x806eb[_0xf289('0x2f')]='%'+_0x5a736c+'%';break;case _0xf289('0x27'):_0x806eb[_0xf289('0x2f')]=_0x5a736c+'%';break;case _0xf289('0x28'):_0x806eb[_0xf289('0x2f')]='%'+_0x5a736c;break;case _0xf289('0x12'):var _0x401ea8=_0x5a736c[_0xf289('0x8')](',');var _0x5a736c=_0x401ea8[_0xf289('0x30')]();var _0x3bf84a=_0x401ea8[_0xf289('0x31')]();if(_0x2fd8ca==='DATE'){_0x5a736c=moment(_0x5a736c)['utcOffset'](0x0,!![])[_0xf289('0x18')]();_0x3bf84a=moment(_0x3bf84a)['utcOffset'](0x0,!![])['add'](0x17,_0xf289('0x32'))['add'](0x3b,'minutes')[_0xf289('0x16')](0x3b,'seconds')[_0xf289('0x18')]();}_0x806eb={'start':_0x5a736c,'end':_0x3bf84a};break;default:_0x806eb[_0xf289('0x2f')]=_0x5a736c;break;}return _0x806eb;}