2e6d45117c32afbde2d73fbf0339614d8ffdb06b
[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 _0xa456=['clearBlockUser','allowedLoginAttempts','getLicense','blocked','MailAccount','find','email','MailServerOut','Smtp','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','service','host','secure','authentication','auth','pass','merge','format','\x22%s\x22\x20<%s>','request','SendMail','error','message','stringify','status','send','login','Something\x20went\x20wrong,\x20please\x20try\x20again.','json','online','forgot','body','generate','Setting','User','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','now','xCally\x20Motion\x20Password\x20Reset','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','https://','headers','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','catch','reset','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','validatePasswordHistory','password','save','Password\x20reset!','use','util','passport','passport-local','Strategy','lodash','randomstring','moment','../../components/auth/service','../../config/utils','client','http','findOne','blockDuration','then','name','role','disabled','admin','user','agent','authenticate','loginAttempts','blockedAt','add','minutes','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'];(function(_0x32bfa3,_0x155884){var _0x1e1712=function(_0x3ac5e0){while(--_0x3ac5e0){_0x32bfa3['push'](_0x32bfa3['shift']());}};_0x1e1712(++_0x155884);}(_0xa456,0x142));var _0x6a45=function(_0x411017,_0x4a8117){_0x411017=_0x411017-0x0;var _0x2adeea=_0xa456[_0x411017];return _0x2adeea;};'use strict';var util=require(_0x6a45('0x0'));var passport=require(_0x6a45('0x1'));var LocalStrategy=require(_0x6a45('0x2'))[_0x6a45('0x3')];var jayson=require('jayson/promise');var _=require(_0x6a45('0x4'));var rs=require(_0x6a45('0x5'));var moment=require(_0x6a45('0x6'));var db=require('../../mysqldb')['db'];var authService=require(_0x6a45('0x7'));var utils=require(_0x6a45('0x8'));var client=jayson[_0x6a45('0x9')][_0x6a45('0xa')]({'port':0x232b});function localAuthenticate(_0x4dfbfa,_0x25cf8d,_0x26bfc0,_0x214514){var _0x19e67c,_0x3deb09;return db['Setting'][_0x6a45('0xb')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts',_0x6a45('0xc')],'raw':!![]})[_0x6a45('0xd')](function(_0x35ed96){_0x19e67c=_0x35ed96;return _0x4dfbfa[_0x6a45('0xb')]({'attributes':['id',_0x6a45('0xe'),'password','salt',_0x6a45('0xf'),_0x6a45('0x10'),'blocked','blockedAt','loginAttempts'],'where':{'name':_0x25cf8d,'role':{'$or':[_0x6a45('0x11'),_0x6a45('0x12'),_0x6a45('0x13')]}}});})[_0x6a45('0xd')](function(_0xd43eb0){if(!_0xd43eb0||_0xd43eb0&&_0xd43eb0['name']!==_0x25cf8d){throw new Error('Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.');}else{_0x3deb09=_0xd43eb0;return _0x3deb09;}})[_0x6a45('0xd')](function(){_0x3deb09[_0x6a45('0x14')](_0x26bfc0,function(_0x48fe0c,_0x2c20db){var _0x171176=_0x3deb09[_0x6a45('0x15')]+0x1;if(_0x48fe0c){return _0x214514(_0x48fe0c);}else if(!_0x2c20db){if(_0x3deb09[_0x6a45('0x10')]){return _0x214514(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x19e67c['allowedLoginAttempts']>0x0){if(_0x3deb09['blocked']){if(_0x19e67c[_0x6a45('0xc')]>0x0){if(moment(_0x3deb09[_0x6a45('0x16')])[_0x6a45('0x17')](_0x19e67c['blockDuration'],_0x6a45('0x18'))>moment()){return _0x214514(null,![],{'message':_0x6a45('0x19')});}else{return utils[_0x6a45('0x1a')](_0x3deb09,_0x171176,![],null)['then'](function(){return _0x214514(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x214514(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x171176>=_0x19e67c[_0x6a45('0x1b')]){return utils[_0x6a45('0x1a')](_0x3deb09,0x0,!![],moment())['then'](function(){return _0x214514(null,![],{'message':_0x6a45('0x19')});});}else{return utils[_0x6a45('0x1a')](_0x3deb09,_0x171176,![],null)['then'](function(){return _0x214514(null,![],{'message':_0x6a45('0x19')});});}}}else{return _0x214514(null,![],{'message':_0x6a45('0x19')});}}else{if(_0x3deb09[_0x6a45('0x10')]){return _0x214514(null,![],{'message':_0x6a45('0x19')});}else if(_0x19e67c[_0x6a45('0x1b')]>0x0){if(_0x3deb09['blocked']){if(_0x19e67c['blockDuration']>0x0){if(moment(_0x3deb09[_0x6a45('0x16')])[_0x6a45('0x17')](_0x19e67c[_0x6a45('0xc')],_0x6a45('0x18'))>moment()){return _0x214514(null,![],{'message':_0x6a45('0x19')});}else{return utils[_0x6a45('0x1a')](_0x3deb09,0x0,![],null)[_0x6a45('0xd')](function(){return utils[_0x6a45('0x1c')](_0x3deb09);})[_0x6a45('0xd')](function(){return _0x214514(null,_0x3deb09);});}}else{return _0x214514(null,![],{'message':_0x6a45('0x19')});}}else{return utils[_0x6a45('0x1a')](_0x3deb09,0x0,![],null)[_0x6a45('0xd')](function(){return utils['getLicense'](_0x3deb09);})[_0x6a45('0xd')](function(){return _0x214514(null,_0x3deb09);})['catch'](function(_0x1b83fa){return _0x214514(null,![],_0x1b83fa);});}}else{if(_0x3deb09[_0x6a45('0x1d')]){return _0x214514(null,![],{'message':_0x6a45('0x19')});}else{return utils[_0x6a45('0x1c')](_0x3deb09)[_0x6a45('0xd')](function(){return _0x214514(null,_0x3deb09);});}}}});})['catch'](function(_0x2b8cc8){return _0x214514(null,![],_0x2b8cc8);});}function sendServiceMail(_0x308003){return db[_0x6a45('0x1e')][_0x6a45('0x1f')]({'where':{'service':!![]},'attributes':['id',_0x6a45('0xe'),_0x6a45('0x20')],'include':[{'model':db[_0x6a45('0x21')],'as':_0x6a45('0x22')}]})['then'](function(_0x14adb5){if(!_0x14adb5){throw new Error(_0x6a45('0x23'));}var _0x22b320={'tls':{'rejectUnauthorized':![]}};if(_0x14adb5[_0x6a45('0x22')][_0x6a45('0x24')]){_0x22b320['service']=_0x14adb5[_0x6a45('0x22')][_0x6a45('0x24')];}else{_0x22b320[_0x6a45('0x25')]=_0x14adb5[_0x6a45('0x22')]['host'];_0x22b320['port']=_0x14adb5[_0x6a45('0x22')]['port'];_0x22b320[_0x6a45('0x26')]=_0x14adb5['Smtp'][_0x6a45('0x26')];}if(_0x14adb5[_0x6a45('0x22')][_0x6a45('0x27')]){_0x22b320[_0x6a45('0x28')]={'user':_0x14adb5[_0x6a45('0x22')][_0x6a45('0x12')],'pass':_0x14adb5[_0x6a45('0x22')][_0x6a45('0x29')]};}var _0x8c8cc3={'account':_0x22b320,'message':_[_0x6a45('0x2a')]({'from':util[_0x6a45('0x2b')](_0x6a45('0x2c'),_0x14adb5[_0x6a45('0xe')],_0x14adb5['email']||_0x14adb5[_0x6a45('0x22')]['user'])},_0x308003)};return client[_0x6a45('0x2d')](_0x6a45('0x2e'),_0x8c8cc3);})[_0x6a45('0xd')](function(_0x2b052e){if(_0x2b052e[_0x6a45('0x2f')]){throw new Error(util[_0x6a45('0x2b')]('SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!',_0x2b052e[_0x6a45('0x2f')][_0x6a45('0x30')]||JSON[_0x6a45('0x31')](_0x2b052e[_0x6a45('0x2f')])));}return!![];});}function handleError(_0x9e6869,_0x1996c6,_0x52661f){return _0x9e6869[_0x6a45('0x32')](_0x1996c6||0x1f4)[_0x6a45('0x33')]({'message':_0x52661f?_0x52661f['message']||_0x52661f:''});}exports[_0x6a45('0x34')]=function(_0x32f014,_0x10cb71,_0x303d2e){passport[_0x6a45('0x14')]('local',function(_0x3f2d09,_0xca32dd,_0x205afd){var _0x405093=_0x3f2d09||_0x205afd;if(_0x405093){return handleError(_0x10cb71,0x191,_0x405093);}if(!_0xca32dd){return handleError(_0x10cb71,0x194,{'message':_0x6a45('0x35')});}else{var _0x35c9dc={'payload':{'id':_0xca32dd['id'],'role':_0xca32dd[_0x6a45('0xf')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x35c9dc)[_0x6a45('0xd')](function(_0x51adbb){_0x10cb71[_0x6a45('0x36')]({'id':_0xca32dd['id'],'token':_0x51adbb,'statusCall':'','isAlreadyLogged':_0xca32dd[_0x6a45('0x37')]});});}})(_0x32f014,_0x10cb71,_0x303d2e);};exports[_0x6a45('0x38')]=function(_0x2715dc,_0x4d7ab5,_0x4805dd){if(!_0x2715dc[_0x6a45('0x39')][_0x6a45('0x20')]){return handleError(_0x4d7ab5,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x39331b=rs[_0x6a45('0x3a')]();_0x2715dc[_0x6a45('0x39')][_0x6a45('0x20')]=_0x2715dc['body']['email']['trim']()['toLowerCase']();var _0xe90201;return db[_0x6a45('0x3b')][_0x6a45('0xb')]({'where':{'id':0x1},'attributes':[_0x6a45('0x1b'),_0x6a45('0xc')],'raw':!![]})[_0x6a45('0xd')](function(_0x1114eb){_0xe90201=_0x1114eb;return db[_0x6a45('0x3c')]['find']({'where':{'email':_0x2715dc[_0x6a45('0x39')]['email']}});})['then'](function(_0x4aeb81){if(!_0x4aeb81){throw new Error(_0x6a45('0x3d'));}if(_0x4aeb81['disabled']){throw new Error(_0x6a45('0x3e'));}if(_0x4aeb81['blocked']){if(moment(_0x4aeb81[_0x6a45('0x16')])[_0x6a45('0x17')](_0xe90201[_0x6a45('0xc')],_0x6a45('0x18'))>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x4aeb81[_0x6a45('0x1d')]=![];_0x4aeb81[_0x6a45('0x16')]=null;}}_0x4aeb81[_0x6a45('0x3f')]=_0x39331b;_0x4aeb81[_0x6a45('0x40')]=Date[_0x6a45('0x41')]()+0x36ee80;return _0x4aeb81['save']();})[_0x6a45('0xd')](function(){return sendServiceMail({'to':_0x2715dc['body'][_0x6a45('0x20')],'subject':_0x6a45('0x42'),'text':'You\x20are\x20receiving\x20this\x20because\x20you\x20(or\x20someone\x20else)\x20have\x20requested\x20the\x20reset\x20of\x20the\x20password\x20for\x20your\x20account.\x0a\x0a'+_0x6a45('0x43')+_0x6a45('0x44')+_0x2715dc[_0x6a45('0x45')][_0x6a45('0x25')]+'/reset/'+_0x39331b+'\x0a\x0a'+_0x6a45('0x46')});})['then'](function(){_0x4d7ab5[_0x6a45('0x32')](0xc8)['send']({'message':_0x6a45('0x47')});})[_0x6a45('0x48')](function(_0x1e98a5){return handleError(_0x4d7ab5,0x1f4,_0x1e98a5);});};exports[_0x6a45('0x49')]=function(_0x5d9f52,_0x23d733,_0x2c9465){return db[_0x6a45('0x3c')][_0x6a45('0x1f')]({'where':{'resetPasswordToken':_0x5d9f52[_0x6a45('0x4a')][_0x6a45('0x4b')],'resetPasswordExpires':{'$gt':Date[_0x6a45('0x41')]()}}})[_0x6a45('0xd')](function(_0x134ace){if(!_0x134ace){throw new Error(_0x6a45('0x4c'));}return db['Setting'][_0x6a45('0xb')]({'attributes':['id',_0x6a45('0x4d'),_0x6a45('0x4e'),_0x6a45('0x4f')]})['then'](function(_0x6c40b6){if(_0x6c40b6[_0x6a45('0x4d')])authService[_0x6a45('0x50')](_0x5d9f52['body']['password']);if(!_0x6c40b6['enforcePasswordHistory']||!_0x134ace[_0x6a45('0x51')])return _0x134ace;authService[_0x6a45('0x52')](_0x5d9f52[_0x6a45('0x39')][_0x6a45('0x53')],_0x134ace['previousPasswords'],_0x6c40b6[_0x6a45('0x4f')]);return _0x134ace;})[_0x6a45('0xd')](function(){_0x134ace[_0x6a45('0x53')]=_0x5d9f52[_0x6a45('0x39')]['password'];_0x134ace[_0x6a45('0x3f')]=null;_0x134ace[_0x6a45('0x40')]=null;return _0x134ace[_0x6a45('0x54')]();});})['then'](function(){_0x23d733['status'](0xc8)[_0x6a45('0x33')]({'message':_0x6a45('0x55')});})['catch'](function(_0xe51767){return handleError(_0x23d733,0x1f4,_0xe51767);});};passport[_0x6a45('0x56')](new LocalStrategy({'usernameField':_0x6a45('0xe'),'passwordField':_0x6a45('0x53')},function(_0x3c30cc,_0x4b469b,_0x58ec02){return localAuthenticate(db[_0x6a45('0x3c')],_0x3c30cc,_0x4b469b,_0x58ec02);}));