Built motion from commit ffdca78c.|2.6.24
[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 _0xe5aa=['host','/reset/','reset','params','token','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','use','passport','passport-local','Strategy','lodash','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','findOne','allowedLoginAttempts','then','name','password','salt','role','blocked','blockedAt','loginAttempts','admin','user','agent','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','disabled','blockDuration','add','minutes','clearBlockUser','getLicense','catch','MailAccount','find','MailServerOut','CloudProvider','getSmtpOptions','format','\x22%s\x22\x20<%s>','email','request','SendMail','error','message','status','send','login','local-login','Something\x20went\x20wrong,\x20please\x20try\x20again.','signToken','json','online','forgot','body','Email\x20parameter\x20is\x20missing','generate','trim','toLowerCase','Setting','User','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordExpires','now','save','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'];(function(_0xfddcdf,_0x18b484){var _0x12b542=function(_0x12e423){while(--_0x12e423){_0xfddcdf['push'](_0xfddcdf['shift']());}};_0x12b542(++_0x18b484);}(_0xe5aa,0x19b));var _0xae5a=function(_0x402387,_0x1bd716){_0x402387=_0x402387-0x0;var _0x4191e4=_0xe5aa[_0x402387];return _0x4191e4;};'use strict';var util=require('util');var passport=require(_0xae5a('0x0'));var LocalStrategy=require(_0xae5a('0x1'))[_0xae5a('0x2')];var jayson=require('jayson/promise');var _=require(_0xae5a('0x3'));var rs=require(_0xae5a('0x4'));var moment=require(_0xae5a('0x5'));var db=require(_0xae5a('0x6'))['db'];var authService=require(_0xae5a('0x7'));var utils=require(_0xae5a('0x8'));var client=jayson[_0xae5a('0x9')][_0xae5a('0xa')]({'port':0x232b});function localAuthenticate(_0x1cd95e,_0x388849,_0x79fa1c,_0x103a5e){var _0x3b4d97,_0xebec0f;return db['Setting'][_0xae5a('0xb')]({'where':{'id':0x1},'attributes':[_0xae5a('0xc'),'blockDuration'],'raw':!![]})[_0xae5a('0xd')](function(_0x1f36f2){_0x3b4d97=_0x1f36f2;return _0x1cd95e[_0xae5a('0xb')]({'attributes':['id',_0xae5a('0xe'),_0xae5a('0xf'),_0xae5a('0x10'),_0xae5a('0x11'),'disabled',_0xae5a('0x12'),_0xae5a('0x13'),_0xae5a('0x14')],'where':{'name':_0x388849,'role':{'$or':[_0xae5a('0x15'),_0xae5a('0x16'),_0xae5a('0x17')]}}});})['then'](function(_0x2b7092){if(!_0x2b7092||_0x2b7092&&_0x2b7092[_0xae5a('0xe')]!==_0x388849){throw new Error(_0xae5a('0x18'));}else{_0xebec0f=_0x2b7092;return _0xebec0f;}})[_0xae5a('0xd')](function(){_0xebec0f[_0xae5a('0x19')](_0x79fa1c,function(_0x9254d,_0x891f21){var _0x5b44a5=_0xebec0f['loginAttempts']+0x1;if(_0x9254d){return _0x103a5e(_0x9254d);}else if(!_0x891f21){if(_0xebec0f[_0xae5a('0x1a')]){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}else if(_0x3b4d97[_0xae5a('0xc')]>0x0){if(_0xebec0f[_0xae5a('0x12')]){if(_0x3b4d97[_0xae5a('0x1b')]>0x0){if(moment(_0xebec0f[_0xae5a('0x13')])[_0xae5a('0x1c')](_0x3b4d97[_0xae5a('0x1b')],_0xae5a('0x1d'))>moment()){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}else{return utils[_0xae5a('0x1e')](_0xebec0f,_0x5b44a5,![],null)[_0xae5a('0xd')](function(){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});});}}else{return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}}else{if(_0x5b44a5>=_0x3b4d97['allowedLoginAttempts']){return utils[_0xae5a('0x1e')](_0xebec0f,0x0,!![],moment())[_0xae5a('0xd')](function(){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});});}else{return utils['clearBlockUser'](_0xebec0f,_0x5b44a5,![],null)[_0xae5a('0xd')](function(){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});});}}}else{return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}}else{if(_0xebec0f[_0xae5a('0x1a')]){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}else if(_0x3b4d97['allowedLoginAttempts']>0x0){if(_0xebec0f[_0xae5a('0x12')]){if(_0x3b4d97[_0xae5a('0x1b')]>0x0){if(moment(_0xebec0f[_0xae5a('0x13')])[_0xae5a('0x1c')](_0x3b4d97[_0xae5a('0x1b')],'minutes')>moment()){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}else{return utils[_0xae5a('0x1e')](_0xebec0f,0x0,![],null)['then'](function(){return utils[_0xae5a('0x1f')](_0xebec0f);})[_0xae5a('0xd')](function(){return _0x103a5e(null,_0xebec0f);});}}else{return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}}else{return utils[_0xae5a('0x1e')](_0xebec0f,0x0,![],null)[_0xae5a('0xd')](function(){return utils[_0xae5a('0x1f')](_0xebec0f);})[_0xae5a('0xd')](function(){return _0x103a5e(null,_0xebec0f);})[_0xae5a('0x20')](function(_0x4088ac){return _0x103a5e(null,![],_0x4088ac);});}}else{if(_0xebec0f[_0xae5a('0x12')]){return _0x103a5e(null,![],{'message':_0xae5a('0x18')});}else{return utils['getLicense'](_0xebec0f)[_0xae5a('0xd')](function(){return _0x103a5e(null,_0xebec0f);});}}}});})[_0xae5a('0x20')](function(_0x4a45de){return _0x103a5e(null,![],_0x4a45de);});}function sendServiceMail(_0x25b752){return db[_0xae5a('0x21')][_0xae5a('0x22')]({'where':{'service':!![]},'attributes':['id',_0xae5a('0xe'),'email'],'include':[{'model':db[_0xae5a('0x23')],'as':'Smtp','include':[{'model':db[_0xae5a('0x24')],'as':_0xae5a('0x24')}]}]})[_0xae5a('0xd')](function(_0x5239e0){if(!_0x5239e0){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x419247=_0x5239e0[_0xae5a('0x25')]();var _0x12dffb={'account':_0x419247,'message':_['merge']({'from':util[_0xae5a('0x26')](_0xae5a('0x27'),_0x5239e0[_0xae5a('0xe')],_0x5239e0[_0xae5a('0x28')]||_0x5239e0['Smtp']['user'])},_0x25b752)};return client[_0xae5a('0x29')](_0xae5a('0x2a'),_0x12dffb);})[_0xae5a('0xd')](function(_0x23600e){if(_0x23600e['error']){throw new Error(util['format']('SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!',_0x23600e[_0xae5a('0x2b')][_0xae5a('0x2c')]||JSON['stringify'](_0x23600e[_0xae5a('0x2b')])));}return!![];});}function handleError(_0x3d5c94,_0x1fcf84,_0x24349b){return _0x3d5c94[_0xae5a('0x2d')](_0x1fcf84||0x1f4)[_0xae5a('0x2e')]({'message':_0x24349b?_0x24349b['message']||_0x24349b:''});}exports[_0xae5a('0x2f')]=function(_0x3e2ad2,_0x4fce52,_0x4a6521){passport['authenticate'](_0xae5a('0x30'),function(_0x343181,_0x4e09d1,_0x24e75a){var _0x5db214=_0x343181||_0x24e75a;if(_0x5db214){return handleError(_0x4fce52,0x191,_0x5db214);}if(!_0x4e09d1){return handleError(_0x4fce52,0x194,{'message':_0xae5a('0x31')});}else{var _0x4b63fc={'payload':{'id':_0x4e09d1['id'],'role':_0x4e09d1[_0xae5a('0x11')]},'options':{'expiresIn':0x15180}};return authService[_0xae5a('0x32')](_0x4b63fc)[_0xae5a('0xd')](function(_0x52ad82){_0x4fce52[_0xae5a('0x33')]({'id':_0x4e09d1['id'],'token':_0x52ad82,'statusCall':'','isAlreadyLogged':_0x4e09d1[_0xae5a('0x34')]});});}})(_0x3e2ad2,_0x4fce52,_0x4a6521);};exports[_0xae5a('0x35')]=function(_0x49a050,_0x37082f){if(!_0x49a050[_0xae5a('0x36')][_0xae5a('0x28')]){return handleError(_0x37082f,0x1f4,{'message':_0xae5a('0x37')});}var _0x330122=rs[_0xae5a('0x38')]();_0x49a050[_0xae5a('0x36')][_0xae5a('0x28')]=_0x49a050[_0xae5a('0x36')]['email'][_0xae5a('0x39')]()[_0xae5a('0x3a')]();var _0x1c72f3;return db[_0xae5a('0x3b')][_0xae5a('0xb')]({'where':{'id':0x1},'attributes':[_0xae5a('0xc'),_0xae5a('0x1b')],'raw':!![]})[_0xae5a('0xd')](function(_0x5a4820){_0x1c72f3=_0x5a4820;return db[_0xae5a('0x3c')][_0xae5a('0x22')]({'where':{'email':_0x49a050[_0xae5a('0x36')][_0xae5a('0x28')]}});})[_0xae5a('0xd')](function(_0x5dbce0){if(!_0x5dbce0){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x5dbce0['disabled']){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x5dbce0[_0xae5a('0x12')]){if(moment(_0x5dbce0[_0xae5a('0x13')])[_0xae5a('0x1c')](_0x1c72f3[_0xae5a('0x1b')],'minutes')>moment()){throw new Error(_0xae5a('0x3d'));}else{_0x5dbce0[_0xae5a('0x12')]=![];_0x5dbce0[_0xae5a('0x13')]=null;}}_0x5dbce0['resetPasswordToken']=_0x330122;_0x5dbce0[_0xae5a('0x3e')]=Date[_0xae5a('0x3f')]()+0x36ee80;return _0x5dbce0[_0xae5a('0x40')]();})[_0xae5a('0xd')](function(){return sendServiceMail({'to':_0x49a050['body'][_0xae5a('0x28')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0xae5a('0x41')+_0xae5a('0x42')+_0xae5a('0x43')+_0x49a050[_0xae5a('0x44')][_0xae5a('0x45')]+_0xae5a('0x46')+_0x330122+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})[_0xae5a('0xd')](function(){_0x37082f[_0xae5a('0x2d')](0xc8)[_0xae5a('0x2e')]({'message':'Reset\x20Email\x20sent!'});})['catch'](function(_0x4146a3){return handleError(_0x37082f,0x1f4,_0x4146a3);});};exports[_0xae5a('0x47')]=function(_0x332938,_0x452e75){return db[_0xae5a('0x3c')]['find']({'where':{'resetPasswordToken':_0x332938[_0xae5a('0x48')][_0xae5a('0x49')],'resetPasswordExpires':{'$gt':Date[_0xae5a('0x3f')]()}}})[_0xae5a('0xd')](function(_0x2c1161){if(!_0x2c1161){throw new Error('Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.');}return db[_0xae5a('0x3b')][_0xae5a('0xb')]({'attributes':['id',_0xae5a('0x4a'),_0xae5a('0x4b'),_0xae5a('0x4c')]})[_0xae5a('0xd')](function(_0x209421){if(_0x209421[_0xae5a('0x4a')])authService[_0xae5a('0x4d')](_0x332938[_0xae5a('0x36')][_0xae5a('0xf')]);if(!_0x209421[_0xae5a('0x4b')]||!_0x2c1161[_0xae5a('0x4e')])return _0x2c1161;authService['validatePasswordHistory'](_0x332938['body']['password'],_0x2c1161[_0xae5a('0x4e')],_0x209421[_0xae5a('0x4c')]);return _0x2c1161;})['then'](function(){_0x2c1161[_0xae5a('0xf')]=_0x332938[_0xae5a('0x36')]['password'];_0x2c1161['resetPasswordToken']=null;_0x2c1161['resetPasswordExpires']=null;return _0x2c1161['save']();});})[_0xae5a('0xd')](function(){_0x452e75[_0xae5a('0x2d')](0xc8)['send']({'message':'Password\x20reset!'});})[_0xae5a('0x20')](function(_0x217b78){return handleError(_0x452e75,0x1f4,_0x217b78);});};passport[_0xae5a('0x4f')]('local-login',new LocalStrategy({'usernameField':'name','passwordField':_0xae5a('0xf')},function(_0xa4fcdd,_0x295fcd,_0x57d0dd){return localAuthenticate(db[_0xae5a('0x3c')],_0xa4fcdd,_0x295fcd,_0x57d0dd);}));