Built motion from commit d1eab355.|2.6.28
[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 _0xc508=['salt','disabled','blocked','loginAttempts','admin','user','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockDuration','blockedAt','add','clearBlockUser','allowedLoginAttempts','getLicense','catch','MailAccount','Smtp','CloudProvider','merge','request','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','send','Something\x20went\x20wrong,\x20please\x20try\x20again.','role','json','body','email','toLowerCase','Setting','find','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','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','/reset/','Reset\x20Email\x20sent!','reset','User','params','token','now','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','validatePasswordHistory','use','util','passport','Strategy','jayson/promise','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','findOne','then','name','password'];(function(_0x14c184,_0x5859a3){var _0x12ddad=function(_0x2f0e70){while(--_0x2f0e70){_0x14c184['push'](_0x14c184['shift']());}};_0x12ddad(++_0x5859a3);}(_0xc508,0x1ea));var _0x8c50=function(_0x324f0b,_0x149bbd){_0x324f0b=_0x324f0b-0x0;var _0x5c5c4f=_0xc508[_0x324f0b];return _0x5c5c4f;};'use strict';var util=require(_0x8c50('0x0'));var passport=require(_0x8c50('0x1'));var LocalStrategy=require('passport-local')[_0x8c50('0x2')];var jayson=require(_0x8c50('0x3'));var _=require('lodash');var rs=require('randomstring');var moment=require(_0x8c50('0x4'));var db=require(_0x8c50('0x5'))['db'];var authService=require(_0x8c50('0x6'));var utils=require(_0x8c50('0x7'));var client=jayson[_0x8c50('0x8')][_0x8c50('0x9')]({'port':0x232b});function localAuthenticate(_0x479f85,_0x49813a,_0x335a4b,_0x3a6b99){var _0x39fdfb,_0x571935;return db['Setting'][_0x8c50('0xa')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts','blockDuration'],'raw':!![]})[_0x8c50('0xb')](function(_0x158afe){_0x39fdfb=_0x158afe;return _0x479f85[_0x8c50('0xa')]({'attributes':['id',_0x8c50('0xc'),_0x8c50('0xd'),_0x8c50('0xe'),'role',_0x8c50('0xf'),_0x8c50('0x10'),'blockedAt',_0x8c50('0x11')],'where':{'name':_0x49813a,'role':{'$or':[_0x8c50('0x12'),_0x8c50('0x13'),'agent']}}});})[_0x8c50('0xb')](function(_0x58170f){if(!_0x58170f||_0x58170f&&_0x58170f[_0x8c50('0xc')]!==_0x49813a){throw new Error(_0x8c50('0x14'));}else{_0x571935=_0x58170f;return _0x571935;}})[_0x8c50('0xb')](function(){_0x571935[_0x8c50('0x15')](_0x335a4b,function(_0x3bbd79,_0x25ff5){var _0x29705e=_0x571935[_0x8c50('0x11')]+0x1;if(_0x3bbd79){return _0x3a6b99(_0x3bbd79);}else if(!_0x25ff5){if(_0x571935[_0x8c50('0xf')]){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}else if(_0x39fdfb['allowedLoginAttempts']>0x0){if(_0x571935[_0x8c50('0x10')]){if(_0x39fdfb[_0x8c50('0x16')]>0x0){if(moment(_0x571935[_0x8c50('0x17')])[_0x8c50('0x18')](_0x39fdfb[_0x8c50('0x16')],'minutes')>moment()){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}else{return utils[_0x8c50('0x19')](_0x571935,_0x29705e,![],null)[_0x8c50('0xb')](function(){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});});}}else{return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x29705e>=_0x39fdfb['allowedLoginAttempts']){return utils[_0x8c50('0x19')](_0x571935,0x0,!![],moment())[_0x8c50('0xb')](function(){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});});}else{return utils[_0x8c50('0x19')](_0x571935,_0x29705e,![],null)[_0x8c50('0xb')](function(){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});});}}}else{return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}}else{if(_0x571935[_0x8c50('0xf')]){return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x39fdfb[_0x8c50('0x1a')]>0x0){if(_0x571935[_0x8c50('0x10')]){if(_0x39fdfb[_0x8c50('0x16')]>0x0){if(moment(_0x571935[_0x8c50('0x17')])['add'](_0x39fdfb[_0x8c50('0x16')],'minutes')>moment()){return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils['clearBlockUser'](_0x571935,0x0,![],null)['then'](function(){return utils[_0x8c50('0x1b')](_0x571935);})[_0x8c50('0xb')](function(){return _0x3a6b99(null,_0x571935);});}}else{return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}}else{return utils[_0x8c50('0x19')](_0x571935,0x0,![],null)['then'](function(){return utils['getLicense'](_0x571935);})['then'](function(){return _0x3a6b99(null,_0x571935);})[_0x8c50('0x1c')](function(_0x2d52c6){return _0x3a6b99(null,![],_0x2d52c6);});}}else{if(_0x571935[_0x8c50('0x10')]){return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x8c50('0x1b')](_0x571935)[_0x8c50('0xb')](function(){return _0x3a6b99(null,_0x571935);});}}}});})[_0x8c50('0x1c')](function(_0x1430da){return _0x3a6b99(null,![],_0x1430da);});}function sendServiceMail(_0x309974){return db[_0x8c50('0x1d')]['find']({'where':{'service':!![]},'attributes':['id',_0x8c50('0xc'),'email'],'include':[{'model':db['MailServerOut'],'as':_0x8c50('0x1e'),'include':[{'model':db[_0x8c50('0x1f')],'as':_0x8c50('0x1f')}]}]})[_0x8c50('0xb')](function(_0x4fe1d1){if(!_0x4fe1d1){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0xdbf541=_0x4fe1d1['getSmtpOptions']();var _0x14121f={'account':_0xdbf541,'message':_[_0x8c50('0x20')]({'from':util['format']('\x22%s\x22\x20<%s>',_0x4fe1d1[_0x8c50('0xc')],_0x4fe1d1['email']||_0x4fe1d1[_0x8c50('0x1e')][_0x8c50('0x13')])},_0x309974)};return client[_0x8c50('0x21')]('SendMail',_0x14121f);})[_0x8c50('0xb')](function(_0x2c83e6){if(_0x2c83e6[_0x8c50('0x22')]){throw new Error(util['format'](_0x8c50('0x23'),_0x2c83e6[_0x8c50('0x22')][_0x8c50('0x24')]||JSON[_0x8c50('0x25')](_0x2c83e6[_0x8c50('0x22')])));}return!![];});}function handleError(_0x22cdfb,_0x30e090,_0x414e64){return _0x22cdfb[_0x8c50('0x26')](_0x30e090||0x1f4)[_0x8c50('0x27')]({'message':_0x414e64?_0x414e64[_0x8c50('0x24')]||_0x414e64:''});}exports['login']=function(_0xe26566,_0x237fe5,_0x5a095c){passport['authenticate']('local-login',function(_0x260983,_0x386ab0,_0x4ec302){var _0x5e9263=_0x260983||_0x4ec302;if(_0x5e9263){return handleError(_0x237fe5,0x191,_0x5e9263);}if(!_0x386ab0){return handleError(_0x237fe5,0x194,{'message':_0x8c50('0x28')});}else{var _0x33d09a={'payload':{'id':_0x386ab0['id'],'role':_0x386ab0[_0x8c50('0x29')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x33d09a)[_0x8c50('0xb')](function(_0x35f2ad){_0x237fe5[_0x8c50('0x2a')]({'id':_0x386ab0['id'],'token':_0x35f2ad,'statusCall':'','isAlreadyLogged':_0x386ab0['online']});});}})(_0xe26566,_0x237fe5,_0x5a095c);};exports['forgot']=function(_0x402b88,_0x2cd4a8){if(!_0x402b88[_0x8c50('0x2b')]['email']){return handleError(_0x2cd4a8,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x522556=rs['generate']();_0x402b88[_0x8c50('0x2b')][_0x8c50('0x2c')]=_0x402b88[_0x8c50('0x2b')]['email']['trim']()[_0x8c50('0x2d')]();var _0x5f1551;return db[_0x8c50('0x2e')][_0x8c50('0xa')]({'where':{'id':0x1},'attributes':[_0x8c50('0x1a'),'blockDuration'],'raw':!![]})[_0x8c50('0xb')](function(_0x54ad32){_0x5f1551=_0x54ad32;return db['User'][_0x8c50('0x2f')]({'where':{'email':_0x402b88[_0x8c50('0x2b')][_0x8c50('0x2c')]}});})['then'](function(_0x4e6ab0){if(!_0x4e6ab0){throw new Error(_0x8c50('0x30'));}if(_0x4e6ab0[_0x8c50('0xf')]){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x4e6ab0['blocked']){if(moment(_0x4e6ab0[_0x8c50('0x17')])[_0x8c50('0x18')](_0x5f1551[_0x8c50('0x16')],'minutes')>moment()){throw new Error(_0x8c50('0x31'));}else{_0x4e6ab0[_0x8c50('0x10')]=![];_0x4e6ab0[_0x8c50('0x17')]=null;}}_0x4e6ab0[_0x8c50('0x32')]=_0x522556;_0x4e6ab0[_0x8c50('0x33')]=Date['now']()+0x36ee80;return _0x4e6ab0[_0x8c50('0x34')]();})[_0x8c50('0xb')](function(){return sendServiceMail({'to':_0x402b88[_0x8c50('0x2b')][_0x8c50('0x2c')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0x8c50('0x35')+_0x8c50('0x36')+_0x8c50('0x37')+_0x402b88[_0x8c50('0x38')]['host']+_0x8c50('0x39')+_0x522556+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})[_0x8c50('0xb')](function(){_0x2cd4a8['status'](0xc8)[_0x8c50('0x27')]({'message':_0x8c50('0x3a')});})['catch'](function(_0x41fb66){return handleError(_0x2cd4a8,0x1f4,_0x41fb66);});};exports[_0x8c50('0x3b')]=function(_0x446369,_0x1d2078){return db[_0x8c50('0x3c')][_0x8c50('0x2f')]({'where':{'resetPasswordToken':_0x446369[_0x8c50('0x3d')][_0x8c50('0x3e')],'resetPasswordExpires':{'$gt':Date[_0x8c50('0x3f')]()}}})[_0x8c50('0xb')](function(_0x58d982){if(!_0x58d982){throw new Error(_0x8c50('0x40'));}return db['Setting'][_0x8c50('0xa')]({'attributes':['id',_0x8c50('0x41'),_0x8c50('0x42'),_0x8c50('0x43')]})[_0x8c50('0xb')](function(_0x32b792){if(_0x32b792[_0x8c50('0x41')])authService[_0x8c50('0x44')](_0x446369['body'][_0x8c50('0xd')]);if(!_0x32b792['enforcePasswordHistory']||!_0x58d982[_0x8c50('0x45')])return _0x58d982;authService[_0x8c50('0x46')](_0x446369['body']['password'],_0x58d982['previousPasswords'],_0x32b792['passwordHistoryLimit']);return _0x58d982;})[_0x8c50('0xb')](function(){_0x58d982[_0x8c50('0xd')]=_0x446369['body'][_0x8c50('0xd')];_0x58d982['resetPasswordToken']=null;_0x58d982[_0x8c50('0x33')]=null;return _0x58d982[_0x8c50('0x34')]();});})[_0x8c50('0xb')](function(){_0x1d2078['status'](0xc8)[_0x8c50('0x27')]({'message':'Password\x20reset!'});})[_0x8c50('0x1c')](function(_0x73851a){return handleError(_0x1d2078,0x1f4,_0x73851a);});};passport[_0x8c50('0x47')]('local-login',new LocalStrategy({'usernameField':_0x8c50('0xc'),'passwordField':_0x8c50('0xd')},function(_0x1690da,_0x109d2b,_0x47f5d6){return localAuthenticate(db['User'],_0x1690da,_0x109d2b,_0x47f5d6);}));