Built motion from commit (unavailable).|2.5.6
[motion2.git] / server / api / authLocal / authLocal.controller.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 _0xfdbc=['agent','then','name','authenticate','disabled','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','blocked','clearBlockUser','minutes','getLicense','catch','MailAccount','email','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','service','host','secure','Smtp','merge','format','request','SendMail','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','error','status','send','message','local','Something\x20went\x20wrong,\x20please\x20try\x20again.','signToken','json','forgot','body','Email\x20parameter\x20is\x20missing','trim','toLowerCase','User','find','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','add','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','xCally\x20Motion\x20Password\x20Reset','You\x20are\x20receiving\x20this\x20because\x20you\x20(or\x20someone\x20else)\x20have\x20requested\x20the\x20reset\x20of\x20the\x20password\x20for\x20your\x20account.\x0a\x0a','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','headers','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','reset','params','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','enforcePasswordHistory','securePassword','previousPasswords','validatePasswordHistory','save','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','findOne','allowedLoginAttempts','blockDuration','password','salt','role','blockedAt','loginAttempts','user'];(function(_0x20ce2c,_0x5bcfa4){var _0x43c4db=function(_0x15a557){while(--_0x15a557){_0x20ce2c['push'](_0x20ce2c['shift']());}};_0x43c4db(++_0x5bcfa4);}(_0xfdbc,0x184));var _0xcfdb=function(_0x200238,_0x2fbdf8){_0x200238=_0x200238-0x0;var _0x3b6d52=_0xfdbc[_0x200238];return _0x3b6d52;};'use strict';var util=require(_0xcfdb('0x0'));var passport=require(_0xcfdb('0x1'));var LocalStrategy=require(_0xcfdb('0x2'))[_0xcfdb('0x3')];var jayson=require(_0xcfdb('0x4'));var _=require('lodash');var rs=require(_0xcfdb('0x5'));var moment=require(_0xcfdb('0x6'));var db=require(_0xcfdb('0x7'))['db'];var authService=require(_0xcfdb('0x8'));var utils=require(_0xcfdb('0x9'));var client=jayson[_0xcfdb('0xa')][_0xcfdb('0xb')]({'port':0x232b});function localAuthenticate(_0x1fe81e,_0x359b5e,_0x570f95,_0xd7ddba){var _0x57f5d2,_0x5e0666;return db[_0xcfdb('0xc')][_0xcfdb('0xd')]({'where':{'id':0x1},'attributes':[_0xcfdb('0xe'),_0xcfdb('0xf')],'raw':!![]})['then'](function(_0x254eca){_0x57f5d2=_0x254eca;return _0x1fe81e[_0xcfdb('0xd')]({'attributes':['id','name',_0xcfdb('0x10'),_0xcfdb('0x11'),_0xcfdb('0x12'),'disabled','blocked',_0xcfdb('0x13'),_0xcfdb('0x14')],'where':{'name':_0x359b5e,'role':{'$or':['admin',_0xcfdb('0x15'),_0xcfdb('0x16')]}}});})[_0xcfdb('0x17')](function(_0x32ddc3){if(!_0x32ddc3||_0x32ddc3&&_0x32ddc3[_0xcfdb('0x18')]!==_0x359b5e){throw new Error('Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.');}else{_0x5e0666=_0x32ddc3;return _0x5e0666;}})[_0xcfdb('0x17')](function(){_0x5e0666[_0xcfdb('0x19')](_0x570f95,function(_0x1dddc1,_0x1e5383){var _0xb43da7=_0x5e0666[_0xcfdb('0x14')]+0x1;if(_0x1dddc1){return _0xd7ddba(_0x1dddc1);}else if(!_0x1e5383){if(_0x5e0666[_0xcfdb('0x1a')]){return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});}else if(_0x57f5d2[_0xcfdb('0xe')]>0x0){if(_0x5e0666[_0xcfdb('0x1c')]){if(_0x57f5d2[_0xcfdb('0xf')]>0x0){if(moment(_0x5e0666['blockedAt'])['add'](_0x57f5d2[_0xcfdb('0xf')],'minutes')>moment()){return _0xd7ddba(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xcfdb('0x1d')](_0x5e0666,_0xb43da7,![],null)[_0xcfdb('0x17')](function(){return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});});}}else{return _0xd7ddba(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0xb43da7>=_0x57f5d2['allowedLoginAttempts']){return utils['clearBlockUser'](_0x5e0666,0x0,!![],moment())[_0xcfdb('0x17')](function(){return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});});}else{return utils[_0xcfdb('0x1d')](_0x5e0666,_0xb43da7,![],null)[_0xcfdb('0x17')](function(){return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});});}}}else{return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});}}else{if(_0x5e0666['disabled']){return _0xd7ddba(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x57f5d2[_0xcfdb('0xe')]>0x0){if(_0x5e0666[_0xcfdb('0x1c')]){if(_0x57f5d2[_0xcfdb('0xf')]>0x0){if(moment(_0x5e0666[_0xcfdb('0x13')])['add'](_0x57f5d2[_0xcfdb('0xf')],_0xcfdb('0x1e'))>moment()){return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});}else{return utils['clearBlockUser'](_0x5e0666,0x0,![],null)[_0xcfdb('0x17')](function(){return utils[_0xcfdb('0x1f')](_0x5e0666);})[_0xcfdb('0x17')](function(){return _0xd7ddba(null,_0x5e0666);});}}else{return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});}}else{return utils[_0xcfdb('0x1d')](_0x5e0666,0x0,![],null)[_0xcfdb('0x17')](function(){return utils['getLicense'](_0x5e0666);})[_0xcfdb('0x17')](function(){return _0xd7ddba(null,_0x5e0666);})[_0xcfdb('0x20')](function(_0x2da008){return _0xd7ddba(null,![],_0x2da008);});}}else{if(_0x5e0666[_0xcfdb('0x1c')]){return _0xd7ddba(null,![],{'message':_0xcfdb('0x1b')});}else{return utils[_0xcfdb('0x1f')](_0x5e0666)[_0xcfdb('0x17')](function(){return _0xd7ddba(null,_0x5e0666);});}}}});})[_0xcfdb('0x20')](function(_0x12eaa8){return _0xd7ddba(null,![],_0x12eaa8);});}function sendServiceMail(_0x54105a){return db[_0xcfdb('0x21')]['find']({'where':{'service':!![]},'attributes':['id',_0xcfdb('0x18'),_0xcfdb('0x22')],'include':[{'model':db['MailServerOut'],'as':'Smtp'}]})['then'](function(_0xde26cc){if(!_0xde26cc){throw new Error(_0xcfdb('0x23'));}var _0x1bddac={'tls':{'rejectUnauthorized':![]}};if(_0xde26cc['Smtp'][_0xcfdb('0x24')]){_0x1bddac[_0xcfdb('0x24')]=_0xde26cc['Smtp']['service'];}else{_0x1bddac[_0xcfdb('0x25')]=_0xde26cc['Smtp'][_0xcfdb('0x25')];_0x1bddac['port']=_0xde26cc['Smtp']['port'];_0x1bddac[_0xcfdb('0x26')]=_0xde26cc[_0xcfdb('0x27')][_0xcfdb('0x26')];}if(_0xde26cc[_0xcfdb('0x27')]['authentication']){_0x1bddac['auth']={'user':_0xde26cc[_0xcfdb('0x27')][_0xcfdb('0x15')],'pass':_0xde26cc[_0xcfdb('0x27')]['pass']};}var _0x21ad41={'account':_0x1bddac,'message':_[_0xcfdb('0x28')]({'from':util[_0xcfdb('0x29')]('\x22%s\x22\x20<%s>',_0xde26cc[_0xcfdb('0x18')],_0xde26cc[_0xcfdb('0x22')]||_0xde26cc[_0xcfdb('0x27')]['user'])},_0x54105a)};return client[_0xcfdb('0x2a')](_0xcfdb('0x2b'),_0x21ad41);})[_0xcfdb('0x17')](function(_0x676ff2){if(_0x676ff2['error']){throw new Error(util[_0xcfdb('0x29')](_0xcfdb('0x2c'),_0x676ff2[_0xcfdb('0x2d')]['message']||JSON['stringify'](_0x676ff2[_0xcfdb('0x2d')])));}return!![];});}function handleError(_0x2ec7b4,_0x571d9a,_0x3fe364){return _0x2ec7b4[_0xcfdb('0x2e')](_0x571d9a||0x1f4)[_0xcfdb('0x2f')]({'message':_0x3fe364?_0x3fe364[_0xcfdb('0x30')]||_0x3fe364:''});}exports['login']=function(_0x62fada,_0x1618df,_0x3ca2da){passport[_0xcfdb('0x19')](_0xcfdb('0x31'),function(_0x49dc10,_0x14caff,_0x4023ae){var _0x1abca3=_0x49dc10||_0x4023ae;if(_0x1abca3){return handleError(_0x1618df,0x191,_0x1abca3);}if(!_0x14caff){return handleError(_0x1618df,0x194,{'message':_0xcfdb('0x32')});}else{var _0x47d8c0={'payload':{'id':_0x14caff['id'],'role':_0x14caff[_0xcfdb('0x12')]},'options':{'expiresIn':0x15180}};return authService[_0xcfdb('0x33')](_0x47d8c0)['then'](function(_0xa733c7){_0x1618df[_0xcfdb('0x34')]({'id':_0x14caff['id'],'token':_0xa733c7,'statusCall':'','isAlreadyLogged':_0x14caff['online']});});}})(_0x62fada,_0x1618df,_0x3ca2da);};exports[_0xcfdb('0x35')]=function(_0x52a2b4,_0x556202,_0x2ecde5){if(!_0x52a2b4[_0xcfdb('0x36')][_0xcfdb('0x22')]){return handleError(_0x556202,0x1f4,{'message':_0xcfdb('0x37')});}var _0x41118f=rs['generate']();_0x52a2b4['body'][_0xcfdb('0x22')]=_0x52a2b4['body']['email'][_0xcfdb('0x38')]()[_0xcfdb('0x39')]();var _0x1cf99d;return db[_0xcfdb('0xc')]['findOne']({'where':{'id':0x1},'attributes':[_0xcfdb('0xe'),_0xcfdb('0xf')],'raw':!![]})[_0xcfdb('0x17')](function(_0x8367be){_0x1cf99d=_0x8367be;return db[_0xcfdb('0x3a')][_0xcfdb('0x3b')]({'where':{'email':_0x52a2b4['body'][_0xcfdb('0x22')]}});})[_0xcfdb('0x17')](function(_0x11bd50){if(!_0x11bd50){throw new Error(_0xcfdb('0x3c'));}if(_0x11bd50[_0xcfdb('0x1a')]){throw new Error(_0xcfdb('0x3d'));}if(_0x11bd50[_0xcfdb('0x1c')]){if(moment(_0x11bd50[_0xcfdb('0x13')])[_0xcfdb('0x3e')](_0x1cf99d[_0xcfdb('0xf')],_0xcfdb('0x1e'))>moment()){throw new Error(_0xcfdb('0x3f'));}else{_0x11bd50[_0xcfdb('0x1c')]=![];_0x11bd50[_0xcfdb('0x13')]=null;}}_0x11bd50[_0xcfdb('0x40')]=_0x41118f;_0x11bd50[_0xcfdb('0x41')]=Date['now']()+0x36ee80;return _0x11bd50['save']();})[_0xcfdb('0x17')](function(){return sendServiceMail({'to':_0x52a2b4[_0xcfdb('0x36')][_0xcfdb('0x22')],'subject':_0xcfdb('0x42'),'text':_0xcfdb('0x43')+_0xcfdb('0x44')+'http://'+_0x52a2b4[_0xcfdb('0x45')][_0xcfdb('0x25')]+_0xcfdb('0x46')+_0x41118f+'\x0a\x0a'+_0xcfdb('0x47')});})[_0xcfdb('0x17')](function(){_0x556202[_0xcfdb('0x2e')](0xc8)[_0xcfdb('0x2f')]({'message':'Reset\x20Email\x20sent!'});})['catch'](function(_0x15d2a2){return handleError(_0x556202,0x1f4,_0x15d2a2);});};exports[_0xcfdb('0x48')]=function(_0x7dada7,_0x3a732a,_0x173bca){return db[_0xcfdb('0x3a')][_0xcfdb('0x3b')]({'where':{'resetPasswordToken':_0x7dada7[_0xcfdb('0x49')]['token'],'resetPasswordExpires':{'$gt':Date['now']()}}})[_0xcfdb('0x17')](function(_0x431a12){if(!_0x431a12){throw new Error(_0xcfdb('0x4a'));}return db[_0xcfdb('0xc')][_0xcfdb('0xd')]({'attributes':['id','securePassword',_0xcfdb('0x4b'),'passwordHistoryLimit']})[_0xcfdb('0x17')](function(_0x236260){if(_0x236260[_0xcfdb('0x4c')])authService['validatePasswordPattern'](_0x7dada7['body'][_0xcfdb('0x10')]);if(!_0x236260[_0xcfdb('0x4b')]||!_0x431a12[_0xcfdb('0x4d')])return _0x431a12;authService[_0xcfdb('0x4e')](_0x7dada7[_0xcfdb('0x36')]['password'],_0x431a12[_0xcfdb('0x4d')],_0x236260['passwordHistoryLimit']);return _0x431a12;})[_0xcfdb('0x17')](function(){_0x431a12[_0xcfdb('0x10')]=_0x7dada7[_0xcfdb('0x36')][_0xcfdb('0x10')];_0x431a12[_0xcfdb('0x40')]=null;_0x431a12[_0xcfdb('0x41')]=null;return _0x431a12[_0xcfdb('0x4f')]();});})['then'](function(){_0x3a732a[_0xcfdb('0x2e')](0xc8)[_0xcfdb('0x2f')]({'message':_0xcfdb('0x50')});})[_0xcfdb('0x20')](function(_0x120153){return handleError(_0x3a732a,0x1f4,_0x120153);});};passport[_0xcfdb('0x51')](new LocalStrategy({'usernameField':_0xcfdb('0x18'),'passwordField':_0xcfdb('0x10')},function(_0x21fc3b,_0x114f3a,_0x1d2745){return localAuthenticate(db[_0xcfdb('0x3a')],_0x21fc3b,_0x114f3a,_0x1d2745);}));