9fc590772c50392626627566243127379174e22e
[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 _0x7d44=['token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','passwordHistoryLimit','securePassword','validatePasswordPattern','enforcePasswordHistory','previousPasswords','validatePasswordHistory','util','passport','passport-local','Strategy','lodash','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','findOne','allowedLoginAttempts','name','password','salt','role','disabled','blocked','blockedAt','loginAttempts','admin','user','agent','then','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockDuration','add','minutes','clearBlockUser','getLicense','catch','MailAccount','find','email','MailServerOut','Smtp','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','service','host','port','secure','authentication','auth','pass','merge','format','\x22%s\x22\x20<%s>','request','SendMail','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','send','login','local-login','json','forgot','Email\x20parameter\x20is\x20missing','generate','trim','toLowerCase','body','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','now','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','https://','status','Reset\x20Email\x20sent!','reset','User','params'];(function(_0x3714f9,_0x5ecd97){var _0x5744e6=function(_0x255781){while(--_0x255781){_0x3714f9['push'](_0x3714f9['shift']());}};_0x5744e6(++_0x5ecd97);}(_0x7d44,0xb6));var _0x47d4=function(_0x248ff1,_0x30797f){_0x248ff1=_0x248ff1-0x0;var _0x5ae46e=_0x7d44[_0x248ff1];return _0x5ae46e;};'use strict';var util=require(_0x47d4('0x0'));var passport=require(_0x47d4('0x1'));var LocalStrategy=require(_0x47d4('0x2'))[_0x47d4('0x3')];var jayson=require('jayson/promise');var _=require(_0x47d4('0x4'));var rs=require('randomstring');var moment=require(_0x47d4('0x5'));var db=require(_0x47d4('0x6'))['db'];var authService=require(_0x47d4('0x7'));var utils=require(_0x47d4('0x8'));var client=jayson[_0x47d4('0x9')][_0x47d4('0xa')]({'port':0x232b});function localAuthenticate(_0xe652a6,_0x802af6,_0x43bec4,_0x14026d){var _0x31f042,_0x2946df;return db[_0x47d4('0xb')][_0x47d4('0xc')]({'where':{'id':0x1},'attributes':[_0x47d4('0xd'),'blockDuration'],'raw':!![]})['then'](function(_0x381255){_0x31f042=_0x381255;return _0xe652a6[_0x47d4('0xc')]({'attributes':['id',_0x47d4('0xe'),_0x47d4('0xf'),_0x47d4('0x10'),_0x47d4('0x11'),_0x47d4('0x12'),_0x47d4('0x13'),_0x47d4('0x14'),_0x47d4('0x15')],'where':{'name':_0x802af6,'role':{'$or':[_0x47d4('0x16'),_0x47d4('0x17'),_0x47d4('0x18')]}}});})[_0x47d4('0x19')](function(_0x39ba22){if(!_0x39ba22||_0x39ba22&&_0x39ba22['name']!==_0x802af6){throw new Error(_0x47d4('0x1a'));}else{_0x2946df=_0x39ba22;return _0x2946df;}})[_0x47d4('0x19')](function(){_0x2946df[_0x47d4('0x1b')](_0x43bec4,function(_0x25329f,_0x2857ee){var _0x527c64=_0x2946df[_0x47d4('0x15')]+0x1;if(_0x25329f){return _0x14026d(_0x25329f);}else if(!_0x2857ee){if(_0x2946df[_0x47d4('0x12')]){return _0x14026d(null,![],{'message':_0x47d4('0x1a')});}else if(_0x31f042['allowedLoginAttempts']>0x0){if(_0x2946df[_0x47d4('0x13')]){if(_0x31f042[_0x47d4('0x1c')]>0x0){if(moment(_0x2946df[_0x47d4('0x14')])[_0x47d4('0x1d')](_0x31f042[_0x47d4('0x1c')],_0x47d4('0x1e'))>moment()){return _0x14026d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x47d4('0x1f')](_0x2946df,_0x527c64,![],null)['then'](function(){return _0x14026d(null,![],{'message':_0x47d4('0x1a')});});}}else{return _0x14026d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x527c64>=_0x31f042[_0x47d4('0xd')]){return utils[_0x47d4('0x1f')](_0x2946df,0x0,!![],moment())['then'](function(){return _0x14026d(null,![],{'message':_0x47d4('0x1a')});});}else{return utils[_0x47d4('0x1f')](_0x2946df,_0x527c64,![],null)[_0x47d4('0x19')](function(){return _0x14026d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}}else{return _0x14026d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x2946df[_0x47d4('0x12')]){return _0x14026d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x31f042['allowedLoginAttempts']>0x0){if(_0x2946df['blocked']){if(_0x31f042[_0x47d4('0x1c')]>0x0){if(moment(_0x2946df[_0x47d4('0x14')])[_0x47d4('0x1d')](_0x31f042[_0x47d4('0x1c')],'minutes')>moment()){return _0x14026d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x47d4('0x1f')](_0x2946df,0x0,![],null)[_0x47d4('0x19')](function(){return utils[_0x47d4('0x20')](_0x2946df);})[_0x47d4('0x19')](function(){return _0x14026d(null,_0x2946df);});}}else{return _0x14026d(null,![],{'message':_0x47d4('0x1a')});}}else{return utils['clearBlockUser'](_0x2946df,0x0,![],null)[_0x47d4('0x19')](function(){return utils[_0x47d4('0x20')](_0x2946df);})[_0x47d4('0x19')](function(){return _0x14026d(null,_0x2946df);})[_0x47d4('0x21')](function(_0x47dcc4){return _0x14026d(null,![],_0x47dcc4);});}}else{if(_0x2946df['blocked']){return _0x14026d(null,![],{'message':_0x47d4('0x1a')});}else{return utils[_0x47d4('0x20')](_0x2946df)[_0x47d4('0x19')](function(){return _0x14026d(null,_0x2946df);});}}}});})[_0x47d4('0x21')](function(_0x16d36d){return _0x14026d(null,![],_0x16d36d);});}function sendServiceMail(_0x292fe5){return db[_0x47d4('0x22')][_0x47d4('0x23')]({'where':{'service':!![]},'attributes':['id',_0x47d4('0xe'),_0x47d4('0x24')],'include':[{'model':db[_0x47d4('0x25')],'as':_0x47d4('0x26')}]})[_0x47d4('0x19')](function(_0x45ae3c){if(!_0x45ae3c){throw new Error(_0x47d4('0x27'));}var _0x1ae620={'tls':{'rejectUnauthorized':![]}};if(_0x45ae3c[_0x47d4('0x26')][_0x47d4('0x28')]){_0x1ae620['service']=_0x45ae3c['Smtp']['service'];}else{_0x1ae620[_0x47d4('0x29')]=_0x45ae3c[_0x47d4('0x26')][_0x47d4('0x29')];_0x1ae620[_0x47d4('0x2a')]=_0x45ae3c[_0x47d4('0x26')][_0x47d4('0x2a')];_0x1ae620[_0x47d4('0x2b')]=_0x45ae3c[_0x47d4('0x26')][_0x47d4('0x2b')];}if(_0x45ae3c[_0x47d4('0x26')][_0x47d4('0x2c')]){_0x1ae620[_0x47d4('0x2d')]={'user':_0x45ae3c[_0x47d4('0x26')]['user'],'pass':_0x45ae3c[_0x47d4('0x26')][_0x47d4('0x2e')]};}var _0x183ed0={'account':_0x1ae620,'message':_[_0x47d4('0x2f')]({'from':util[_0x47d4('0x30')](_0x47d4('0x31'),_0x45ae3c['name'],_0x45ae3c[_0x47d4('0x24')]||_0x45ae3c[_0x47d4('0x26')]['user'])},_0x292fe5)};return client[_0x47d4('0x32')](_0x47d4('0x33'),_0x183ed0);})[_0x47d4('0x19')](function(_0x571c73){if(_0x571c73[_0x47d4('0x34')]){throw new Error(util[_0x47d4('0x30')](_0x47d4('0x35'),_0x571c73[_0x47d4('0x34')][_0x47d4('0x36')]||JSON[_0x47d4('0x37')](_0x571c73[_0x47d4('0x34')])));}return!![];});}function handleError(_0x1ca04a,_0x2cc5de,_0x2f02d0){return _0x1ca04a['status'](_0x2cc5de||0x1f4)[_0x47d4('0x38')]({'message':_0x2f02d0?_0x2f02d0['message']||_0x2f02d0:''});}exports[_0x47d4('0x39')]=function(_0x3ba413,_0x39e722,_0x117935){passport[_0x47d4('0x1b')](_0x47d4('0x3a'),function(_0x2e53a6,_0x3773c9,_0x4057de){var _0x93d4a0=_0x2e53a6||_0x4057de;if(_0x93d4a0){return handleError(_0x39e722,0x191,_0x93d4a0);}if(!_0x3773c9){return handleError(_0x39e722,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x36b9a3={'payload':{'id':_0x3773c9['id'],'role':_0x3773c9[_0x47d4('0x11')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x36b9a3)[_0x47d4('0x19')](function(_0x5af37d){_0x39e722[_0x47d4('0x3b')]({'id':_0x3773c9['id'],'token':_0x5af37d,'statusCall':'','isAlreadyLogged':_0x3773c9['online']});});}})(_0x3ba413,_0x39e722,_0x117935);};exports[_0x47d4('0x3c')]=function(_0x5d0c2c,_0x49c22e,_0x4cf0f3){if(!_0x5d0c2c['body'][_0x47d4('0x24')]){return handleError(_0x49c22e,0x1f4,{'message':_0x47d4('0x3d')});}var _0x537de7=rs[_0x47d4('0x3e')]();_0x5d0c2c['body'][_0x47d4('0x24')]=_0x5d0c2c['body'][_0x47d4('0x24')][_0x47d4('0x3f')]()[_0x47d4('0x40')]();var _0x46828a;return db[_0x47d4('0xb')][_0x47d4('0xc')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts',_0x47d4('0x1c')],'raw':!![]})[_0x47d4('0x19')](function(_0x4a524){_0x46828a=_0x4a524;return db['User'][_0x47d4('0x23')]({'where':{'email':_0x5d0c2c[_0x47d4('0x41')]['email']}});})[_0x47d4('0x19')](function(_0x24371f){if(!_0x24371f){throw new Error(_0x47d4('0x42'));}if(_0x24371f[_0x47d4('0x12')]){throw new Error(_0x47d4('0x43'));}if(_0x24371f[_0x47d4('0x13')]){if(moment(_0x24371f[_0x47d4('0x14')])[_0x47d4('0x1d')](_0x46828a[_0x47d4('0x1c')],_0x47d4('0x1e'))>moment()){throw new Error(_0x47d4('0x44'));}else{_0x24371f[_0x47d4('0x13')]=![];_0x24371f[_0x47d4('0x14')]=null;}}_0x24371f[_0x47d4('0x45')]=_0x537de7;_0x24371f['resetPasswordExpires']=Date[_0x47d4('0x46')]()+0x36ee80;return _0x24371f['save']();})[_0x47d4('0x19')](function(){return sendServiceMail({'to':_0x5d0c2c[_0x47d4('0x41')][_0x47d4('0x24')],'subject':_0x47d4('0x47'),'text':_0x47d4('0x48')+'Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a'+_0x47d4('0x49')+_0x5d0c2c['headers'][_0x47d4('0x29')]+'/reset/'+_0x537de7+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})['then'](function(){_0x49c22e[_0x47d4('0x4a')](0xc8)['send']({'message':_0x47d4('0x4b')});})[_0x47d4('0x21')](function(_0x3fd113){return handleError(_0x49c22e,0x1f4,_0x3fd113);});};exports[_0x47d4('0x4c')]=function(_0x121e21,_0x38da1f,_0x5bcb94){return db[_0x47d4('0x4d')]['find']({'where':{'resetPasswordToken':_0x121e21[_0x47d4('0x4e')][_0x47d4('0x4f')],'resetPasswordExpires':{'$gt':Date[_0x47d4('0x46')]()}}})['then'](function(_0x168fed){if(!_0x168fed){throw new Error(_0x47d4('0x50'));}return db[_0x47d4('0xb')][_0x47d4('0xc')]({'attributes':['id','securePassword','enforcePasswordHistory',_0x47d4('0x51')]})[_0x47d4('0x19')](function(_0x5a46e6){if(_0x5a46e6[_0x47d4('0x52')])authService[_0x47d4('0x53')](_0x121e21[_0x47d4('0x41')][_0x47d4('0xf')]);if(!_0x5a46e6[_0x47d4('0x54')]||!_0x168fed[_0x47d4('0x55')])return _0x168fed;authService[_0x47d4('0x56')](_0x121e21[_0x47d4('0x41')][_0x47d4('0xf')],_0x168fed['previousPasswords'],_0x5a46e6[_0x47d4('0x51')]);return _0x168fed;})[_0x47d4('0x19')](function(){_0x168fed['password']=_0x121e21[_0x47d4('0x41')]['password'];_0x168fed['resetPasswordToken']=null;_0x168fed['resetPasswordExpires']=null;return _0x168fed['save']();});})[_0x47d4('0x19')](function(){_0x38da1f[_0x47d4('0x4a')](0xc8)[_0x47d4('0x38')]({'message':'Password\x20reset!'});})[_0x47d4('0x21')](function(_0x28ab3a){return handleError(_0x38da1f,0x1f4,_0x28ab3a);});};passport['use'](_0x47d4('0x3a'),new LocalStrategy({'usernameField':'name','passwordField':'password'},function(_0x56924d,_0x3707f9,_0x5a5271){return localAuthenticate(db[_0x47d4('0x4d')],_0x56924d,_0x3707f9,_0x5a5271);}));