Built motion from commit 9d0783e6.|2.6.13
[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 _0xdcfd=['name','password','salt','role','disabled','blocked','blockedAt','loginAttempts','user','then','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','minutes','clearBlockUser','add','getLicense','catch','MailAccount','find','email','MailServerOut','CloudProvider','getSmtpOptions','merge','format','Smtp','request','SendMail','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','send','login','signToken','json','online','forgot','body','Email\x20parameter\x20is\x20missing','generate','trim','User','This\x20email\x20is\x20not\x20registered.','now','save','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','https://','headers','host','/reset/','Reset\x20Email\x20sent!','reset','params','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','passwordHistoryLimit','validatePasswordPattern','enforcePasswordHistory','previousPasswords','validatePasswordHistory','resetPasswordToken','resetPasswordExpires','use','local-login','passport','Strategy','jayson/promise','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','Setting','findOne','allowedLoginAttempts','blockDuration'];(function(_0x3ff085,_0x27c92e){var _0x2b68c3=function(_0x37811e){while(--_0x37811e){_0x3ff085['push'](_0x3ff085['shift']());}};_0x2b68c3(++_0x27c92e);}(_0xdcfd,0x1ce));var _0xddcf=function(_0x34b87f,_0x28aef2){_0x34b87f=_0x34b87f-0x0;var _0x449805=_0xdcfd[_0x34b87f];return _0x449805;};'use strict';var util=require('util');var passport=require(_0xddcf('0x0'));var LocalStrategy=require('passport-local')[_0xddcf('0x1')];var jayson=require(_0xddcf('0x2'));var _=require('lodash');var rs=require(_0xddcf('0x3'));var moment=require(_0xddcf('0x4'));var db=require(_0xddcf('0x5'))['db'];var authService=require(_0xddcf('0x6'));var utils=require(_0xddcf('0x7'));var client=jayson['client']['http']({'port':0x232b});function localAuthenticate(_0x2b4324,_0x54b285,_0x5bdd1c,_0x54d408){var _0x5a3129,_0x33c460;return db[_0xddcf('0x8')][_0xddcf('0x9')]({'where':{'id':0x1},'attributes':[_0xddcf('0xa'),_0xddcf('0xb')],'raw':!![]})['then'](function(_0x2500b5){_0x5a3129=_0x2500b5;return _0x2b4324['findOne']({'attributes':['id',_0xddcf('0xc'),_0xddcf('0xd'),_0xddcf('0xe'),_0xddcf('0xf'),_0xddcf('0x10'),_0xddcf('0x11'),_0xddcf('0x12'),_0xddcf('0x13')],'where':{'name':_0x54b285,'role':{'$or':['admin',_0xddcf('0x14'),'agent']}}});})[_0xddcf('0x15')](function(_0x170eba){if(!_0x170eba||_0x170eba&&_0x170eba[_0xddcf('0xc')]!==_0x54b285){throw new Error(_0xddcf('0x16'));}else{_0x33c460=_0x170eba;return _0x33c460;}})[_0xddcf('0x15')](function(){_0x33c460['authenticate'](_0x5bdd1c,function(_0x1ef5fc,_0x4f5d01){var _0x31cf5e=_0x33c460['loginAttempts']+0x1;if(_0x1ef5fc){return _0x54d408(_0x1ef5fc);}else if(!_0x4f5d01){if(_0x33c460[_0xddcf('0x10')]){return _0x54d408(null,![],{'message':_0xddcf('0x16')});}else if(_0x5a3129['allowedLoginAttempts']>0x0){if(_0x33c460[_0xddcf('0x11')]){if(_0x5a3129[_0xddcf('0xb')]>0x0){if(moment(_0x33c460[_0xddcf('0x12')])['add'](_0x5a3129[_0xddcf('0xb')],_0xddcf('0x17'))>moment()){return _0x54d408(null,![],{'message':_0xddcf('0x16')});}else{return utils[_0xddcf('0x18')](_0x33c460,_0x31cf5e,![],null)[_0xddcf('0x15')](function(){return _0x54d408(null,![],{'message':_0xddcf('0x16')});});}}else{return _0x54d408(null,![],{'message':_0xddcf('0x16')});}}else{if(_0x31cf5e>=_0x5a3129[_0xddcf('0xa')]){return utils[_0xddcf('0x18')](_0x33c460,0x0,!![],moment())[_0xddcf('0x15')](function(){return _0x54d408(null,![],{'message':_0xddcf('0x16')});});}else{return utils[_0xddcf('0x18')](_0x33c460,_0x31cf5e,![],null)[_0xddcf('0x15')](function(){return _0x54d408(null,![],{'message':_0xddcf('0x16')});});}}}else{return _0x54d408(null,![],{'message':_0xddcf('0x16')});}}else{if(_0x33c460[_0xddcf('0x10')]){return _0x54d408(null,![],{'message':_0xddcf('0x16')});}else if(_0x5a3129[_0xddcf('0xa')]>0x0){if(_0x33c460[_0xddcf('0x11')]){if(_0x5a3129['blockDuration']>0x0){if(moment(_0x33c460[_0xddcf('0x12')])[_0xddcf('0x19')](_0x5a3129[_0xddcf('0xb')],_0xddcf('0x17'))>moment()){return _0x54d408(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xddcf('0x18')](_0x33c460,0x0,![],null)['then'](function(){return utils[_0xddcf('0x1a')](_0x33c460);})[_0xddcf('0x15')](function(){return _0x54d408(null,_0x33c460);});}}else{return _0x54d408(null,![],{'message':_0xddcf('0x16')});}}else{return utils[_0xddcf('0x18')](_0x33c460,0x0,![],null)['then'](function(){return utils[_0xddcf('0x1a')](_0x33c460);})['then'](function(){return _0x54d408(null,_0x33c460);})[_0xddcf('0x1b')](function(_0x386960){return _0x54d408(null,![],_0x386960);});}}else{if(_0x33c460[_0xddcf('0x11')]){return _0x54d408(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xddcf('0x1a')](_0x33c460)[_0xddcf('0x15')](function(){return _0x54d408(null,_0x33c460);});}}}});})[_0xddcf('0x1b')](function(_0x3a04e3){return _0x54d408(null,![],_0x3a04e3);});}function sendServiceMail(_0x2c2cfe){return db[_0xddcf('0x1c')][_0xddcf('0x1d')]({'where':{'service':!![]},'attributes':['id','name',_0xddcf('0x1e')],'include':[{'model':db[_0xddcf('0x1f')],'as':'Smtp','include':[{'model':db['CloudProvider'],'as':_0xddcf('0x20')}]}]})[_0xddcf('0x15')](function(_0x49e9e6){if(!_0x49e9e6){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x3d68fb=_0x49e9e6[_0xddcf('0x21')]();var _0x311304={'account':_0x3d68fb,'message':_[_0xddcf('0x22')]({'from':util[_0xddcf('0x23')]('\x22%s\x22\x20<%s>',_0x49e9e6[_0xddcf('0xc')],_0x49e9e6['email']||_0x49e9e6[_0xddcf('0x24')]['user'])},_0x2c2cfe)};return client[_0xddcf('0x25')](_0xddcf('0x26'),_0x311304);})[_0xddcf('0x15')](function(_0xa9c7be){if(_0xa9c7be[_0xddcf('0x27')]){throw new Error(util[_0xddcf('0x23')](_0xddcf('0x28'),_0xa9c7be[_0xddcf('0x27')][_0xddcf('0x29')]||JSON[_0xddcf('0x2a')](_0xa9c7be[_0xddcf('0x27')])));}return!![];});}function handleError(_0x54d3e2,_0x35de1a,_0x19f52a){return _0x54d3e2[_0xddcf('0x2b')](_0x35de1a||0x1f4)[_0xddcf('0x2c')]({'message':_0x19f52a?_0x19f52a[_0xddcf('0x29')]||_0x19f52a:''});}exports[_0xddcf('0x2d')]=function(_0x33a487,_0x1eff80,_0x4d8fa4){passport['authenticate']('local-login',function(_0x5d3119,_0x22be19,_0x13f140){var _0x32a599=_0x5d3119||_0x13f140;if(_0x32a599){return handleError(_0x1eff80,0x191,_0x32a599);}if(!_0x22be19){return handleError(_0x1eff80,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x2d0501={'payload':{'id':_0x22be19['id'],'role':_0x22be19[_0xddcf('0xf')]},'options':{'expiresIn':0x15180}};return authService[_0xddcf('0x2e')](_0x2d0501)['then'](function(_0x4b1b92){_0x1eff80[_0xddcf('0x2f')]({'id':_0x22be19['id'],'token':_0x4b1b92,'statusCall':'','isAlreadyLogged':_0x22be19[_0xddcf('0x30')]});});}})(_0x33a487,_0x1eff80,_0x4d8fa4);};exports[_0xddcf('0x31')]=function(_0x1fc746,_0x40bfc7){if(!_0x1fc746[_0xddcf('0x32')][_0xddcf('0x1e')]){return handleError(_0x40bfc7,0x1f4,{'message':_0xddcf('0x33')});}var _0x1d89e6=rs[_0xddcf('0x34')]();_0x1fc746[_0xddcf('0x32')][_0xddcf('0x1e')]=_0x1fc746[_0xddcf('0x32')]['email'][_0xddcf('0x35')]()['toLowerCase']();var _0x1466c5;return db[_0xddcf('0x8')]['findOne']({'where':{'id':0x1},'attributes':['allowedLoginAttempts','blockDuration'],'raw':!![]})[_0xddcf('0x15')](function(_0x243b65){_0x1466c5=_0x243b65;return db[_0xddcf('0x36')][_0xddcf('0x1d')]({'where':{'email':_0x1fc746['body'][_0xddcf('0x1e')]}});})[_0xddcf('0x15')](function(_0x2dfc46){if(!_0x2dfc46){throw new Error(_0xddcf('0x37'));}if(_0x2dfc46['disabled']){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x2dfc46[_0xddcf('0x11')]){if(moment(_0x2dfc46['blockedAt'])[_0xddcf('0x19')](_0x1466c5[_0xddcf('0xb')],'minutes')>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x2dfc46[_0xddcf('0x11')]=![];_0x2dfc46[_0xddcf('0x12')]=null;}}_0x2dfc46['resetPasswordToken']=_0x1d89e6;_0x2dfc46['resetPasswordExpires']=Date[_0xddcf('0x38')]()+0x36ee80;return _0x2dfc46[_0xddcf('0x39')]();})['then'](function(){return sendServiceMail({'to':_0x1fc746['body'][_0xddcf('0x1e')],'subject':_0xddcf('0x3a'),'text':_0xddcf('0x3b')+_0xddcf('0x3c')+_0xddcf('0x3d')+_0x1fc746[_0xddcf('0x3e')][_0xddcf('0x3f')]+_0xddcf('0x40')+_0x1d89e6+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})[_0xddcf('0x15')](function(){_0x40bfc7[_0xddcf('0x2b')](0xc8)['send']({'message':_0xddcf('0x41')});})[_0xddcf('0x1b')](function(_0x372616){return handleError(_0x40bfc7,0x1f4,_0x372616);});};exports[_0xddcf('0x42')]=function(_0x363ac8,_0x5afb49){return db[_0xddcf('0x36')][_0xddcf('0x1d')]({'where':{'resetPasswordToken':_0x363ac8[_0xddcf('0x43')]['token'],'resetPasswordExpires':{'$gt':Date[_0xddcf('0x38')]()}}})['then'](function(_0x1c9499){if(!_0x1c9499){throw new Error(_0xddcf('0x44'));}return db[_0xddcf('0x8')][_0xddcf('0x9')]({'attributes':['id',_0xddcf('0x45'),'enforcePasswordHistory',_0xddcf('0x46')]})[_0xddcf('0x15')](function(_0x42af7d){if(_0x42af7d[_0xddcf('0x45')])authService[_0xddcf('0x47')](_0x363ac8['body'][_0xddcf('0xd')]);if(!_0x42af7d[_0xddcf('0x48')]||!_0x1c9499[_0xddcf('0x49')])return _0x1c9499;authService[_0xddcf('0x4a')](_0x363ac8[_0xddcf('0x32')][_0xddcf('0xd')],_0x1c9499['previousPasswords'],_0x42af7d[_0xddcf('0x46')]);return _0x1c9499;})[_0xddcf('0x15')](function(){_0x1c9499[_0xddcf('0xd')]=_0x363ac8[_0xddcf('0x32')][_0xddcf('0xd')];_0x1c9499[_0xddcf('0x4b')]=null;_0x1c9499[_0xddcf('0x4c')]=null;return _0x1c9499[_0xddcf('0x39')]();});})[_0xddcf('0x15')](function(){_0x5afb49['status'](0xc8)[_0xddcf('0x2c')]({'message':'Password\x20reset!'});})[_0xddcf('0x1b')](function(_0x4e60e8){return handleError(_0x5afb49,0x1f4,_0x4e60e8);});};passport[_0xddcf('0x4d')](_0xddcf('0x4e'),new LocalStrategy({'usernameField':_0xddcf('0xc'),'passwordField':_0xddcf('0xd')},function(_0x4f7649,_0x38e808,_0xc135c7){return localAuthenticate(db[_0xddcf('0x36')],_0x4f7649,_0x38e808,_0xc135c7);}));