d31af2a63d083b4fd9760d83624a02a91fba88c2
[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 _0xa0d1=['then','name','password','salt','disabled','blocked','loginAttempts','admin','user','agent','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockedAt','blockDuration','minutes','clearBlockUser','add','getLicense','catch','MailAccount','find','email','MailServerOut','Smtp','service','host','port','secure','authentication','auth','pass','merge','\x22%s\x22\x20<%s>','request','error','format','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','stringify','status','send','message','login','local-login','signToken','online','Email\x20parameter\x20is\x20missing','generate','body','trim','toLowerCase','User','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','now','save','xCally\x20Motion\x20Password\x20Reset','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','headers','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','reset','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','validatePasswordHistory','Password\x20reset!','passport-local','jayson/promise','lodash','randomstring','moment','../../mysqldb','../../config/utils','client','http','Setting','findOne','allowedLoginAttempts'];(function(_0x792a9a,_0x188af6){var _0x5620ce=function(_0xe31865){while(--_0xe31865){_0x792a9a['push'](_0x792a9a['shift']());}};_0x5620ce(++_0x188af6);}(_0xa0d1,0x144));var _0x1a0d=function(_0x178e48,_0x3c9509){_0x178e48=_0x178e48-0x0;var _0x440d7e=_0xa0d1[_0x178e48];return _0x440d7e;};'use strict';var util=require('util');var passport=require('passport');var LocalStrategy=require(_0x1a0d('0x0'))['Strategy'];var jayson=require(_0x1a0d('0x1'));var _=require(_0x1a0d('0x2'));var rs=require(_0x1a0d('0x3'));var moment=require(_0x1a0d('0x4'));var db=require(_0x1a0d('0x5'))['db'];var authService=require('../../components/auth/service');var utils=require(_0x1a0d('0x6'));var client=jayson[_0x1a0d('0x7')][_0x1a0d('0x8')]({'port':0x232b});function localAuthenticate(_0xcb35a0,_0x439ca0,_0x3d8271,_0x345757){var _0x4aa163,_0x5c2a60;return db[_0x1a0d('0x9')][_0x1a0d('0xa')]({'where':{'id':0x1},'attributes':[_0x1a0d('0xb'),'blockDuration'],'raw':!![]})[_0x1a0d('0xc')](function(_0x593d42){_0x4aa163=_0x593d42;return _0xcb35a0[_0x1a0d('0xa')]({'attributes':['id',_0x1a0d('0xd'),_0x1a0d('0xe'),_0x1a0d('0xf'),'role',_0x1a0d('0x10'),_0x1a0d('0x11'),'blockedAt',_0x1a0d('0x12')],'where':{'name':_0x439ca0,'role':{'$or':[_0x1a0d('0x13'),_0x1a0d('0x14'),_0x1a0d('0x15')]}}});})[_0x1a0d('0xc')](function(_0x4721cb){if(!_0x4721cb||_0x4721cb&&_0x4721cb['name']!==_0x439ca0){throw new Error(_0x1a0d('0x16'));}else{_0x5c2a60=_0x4721cb;return _0x5c2a60;}})[_0x1a0d('0xc')](function(){_0x5c2a60[_0x1a0d('0x17')](_0x3d8271,function(_0xdcd6b9,_0x1b228f){var _0x4acabd=_0x5c2a60[_0x1a0d('0x12')]+0x1;if(_0xdcd6b9){return _0x345757(_0xdcd6b9);}else if(!_0x1b228f){if(_0x5c2a60[_0x1a0d('0x10')]){return _0x345757(null,![],{'message':_0x1a0d('0x16')});}else if(_0x4aa163['allowedLoginAttempts']>0x0){if(_0x5c2a60[_0x1a0d('0x11')]){if(_0x4aa163['blockDuration']>0x0){if(moment(_0x5c2a60[_0x1a0d('0x18')])['add'](_0x4aa163[_0x1a0d('0x19')],_0x1a0d('0x1a'))>moment()){return _0x345757(null,![],{'message':_0x1a0d('0x16')});}else{return utils[_0x1a0d('0x1b')](_0x5c2a60,_0x4acabd,![],null)[_0x1a0d('0xc')](function(){return _0x345757(null,![],{'message':_0x1a0d('0x16')});});}}else{return _0x345757(null,![],{'message':_0x1a0d('0x16')});}}else{if(_0x4acabd>=_0x4aa163[_0x1a0d('0xb')]){return utils[_0x1a0d('0x1b')](_0x5c2a60,0x0,!![],moment())[_0x1a0d('0xc')](function(){return _0x345757(null,![],{'message':_0x1a0d('0x16')});});}else{return utils['clearBlockUser'](_0x5c2a60,_0x4acabd,![],null)[_0x1a0d('0xc')](function(){return _0x345757(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}}else{return _0x345757(null,![],{'message':_0x1a0d('0x16')});}}else{if(_0x5c2a60[_0x1a0d('0x10')]){return _0x345757(null,![],{'message':_0x1a0d('0x16')});}else if(_0x4aa163[_0x1a0d('0xb')]>0x0){if(_0x5c2a60[_0x1a0d('0x11')]){if(_0x4aa163[_0x1a0d('0x19')]>0x0){if(moment(_0x5c2a60[_0x1a0d('0x18')])[_0x1a0d('0x1c')](_0x4aa163[_0x1a0d('0x19')],_0x1a0d('0x1a'))>moment()){return _0x345757(null,![],{'message':_0x1a0d('0x16')});}else{return utils['clearBlockUser'](_0x5c2a60,0x0,![],null)[_0x1a0d('0xc')](function(){return utils[_0x1a0d('0x1d')](_0x5c2a60);})[_0x1a0d('0xc')](function(){return _0x345757(null,_0x5c2a60);});}}else{return _0x345757(null,![],{'message':_0x1a0d('0x16')});}}else{return utils[_0x1a0d('0x1b')](_0x5c2a60,0x0,![],null)[_0x1a0d('0xc')](function(){return utils[_0x1a0d('0x1d')](_0x5c2a60);})['then'](function(){return _0x345757(null,_0x5c2a60);})[_0x1a0d('0x1e')](function(_0x5746fe){return _0x345757(null,![],_0x5746fe);});}}else{if(_0x5c2a60['blocked']){return _0x345757(null,![],{'message':_0x1a0d('0x16')});}else{return utils['getLicense'](_0x5c2a60)[_0x1a0d('0xc')](function(){return _0x345757(null,_0x5c2a60);});}}}});})['catch'](function(_0x429aae){return _0x345757(null,![],_0x429aae);});}function sendServiceMail(_0x18aca4){return db[_0x1a0d('0x1f')][_0x1a0d('0x20')]({'where':{'service':!![]},'attributes':['id','name',_0x1a0d('0x21')],'include':[{'model':db[_0x1a0d('0x22')],'as':'Smtp'}]})[_0x1a0d('0xc')](function(_0xa03915){if(!_0xa03915){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x35f7e7={'tls':{'rejectUnauthorized':![]}};if(_0xa03915[_0x1a0d('0x23')][_0x1a0d('0x24')]){_0x35f7e7[_0x1a0d('0x24')]=_0xa03915[_0x1a0d('0x23')]['service'];}else{_0x35f7e7[_0x1a0d('0x25')]=_0xa03915['Smtp'][_0x1a0d('0x25')];_0x35f7e7['port']=_0xa03915[_0x1a0d('0x23')][_0x1a0d('0x26')];_0x35f7e7[_0x1a0d('0x27')]=_0xa03915['Smtp'][_0x1a0d('0x27')];}if(_0xa03915['Smtp'][_0x1a0d('0x28')]){_0x35f7e7[_0x1a0d('0x29')]={'user':_0xa03915[_0x1a0d('0x23')][_0x1a0d('0x14')],'pass':_0xa03915['Smtp'][_0x1a0d('0x2a')]};}var _0x5b303d={'account':_0x35f7e7,'message':_[_0x1a0d('0x2b')]({'from':util['format'](_0x1a0d('0x2c'),_0xa03915[_0x1a0d('0xd')],_0xa03915[_0x1a0d('0x21')]||_0xa03915[_0x1a0d('0x23')][_0x1a0d('0x14')])},_0x18aca4)};return client[_0x1a0d('0x2d')]('SendMail',_0x5b303d);})[_0x1a0d('0xc')](function(_0x24d76a){if(_0x24d76a[_0x1a0d('0x2e')]){throw new Error(util[_0x1a0d('0x2f')](_0x1a0d('0x30'),_0x24d76a[_0x1a0d('0x2e')]['message']||JSON[_0x1a0d('0x31')](_0x24d76a['error'])));}return!![];});}function handleError(_0x45abec,_0x24599f,_0x3012b4){return _0x45abec[_0x1a0d('0x32')](_0x24599f||0x1f4)[_0x1a0d('0x33')]({'message':_0x3012b4?_0x3012b4[_0x1a0d('0x34')]||_0x3012b4:''});}exports[_0x1a0d('0x35')]=function(_0x39c5cd,_0xfb2778,_0xeeeb57){passport[_0x1a0d('0x17')](_0x1a0d('0x36'),function(_0x49ed2a,_0x151ba8,_0xf9df1b){var _0x31b47e=_0x49ed2a||_0xf9df1b;if(_0x31b47e){return handleError(_0xfb2778,0x191,_0x31b47e);}if(!_0x151ba8){return handleError(_0xfb2778,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x21a9c0={'payload':{'id':_0x151ba8['id'],'role':_0x151ba8['role']},'options':{'expiresIn':0x15180}};return authService[_0x1a0d('0x37')](_0x21a9c0)[_0x1a0d('0xc')](function(_0x1c62e2){_0xfb2778['json']({'id':_0x151ba8['id'],'token':_0x1c62e2,'statusCall':'','isAlreadyLogged':_0x151ba8[_0x1a0d('0x38')]});});}})(_0x39c5cd,_0xfb2778,_0xeeeb57);};exports['forgot']=function(_0x4ab8de,_0x598c16,_0x4c0555){if(!_0x4ab8de['body'][_0x1a0d('0x21')]){return handleError(_0x598c16,0x1f4,{'message':_0x1a0d('0x39')});}var _0x23a0ad=rs[_0x1a0d('0x3a')]();_0x4ab8de[_0x1a0d('0x3b')][_0x1a0d('0x21')]=_0x4ab8de['body']['email'][_0x1a0d('0x3c')]()[_0x1a0d('0x3d')]();var _0x26f690;return db[_0x1a0d('0x9')][_0x1a0d('0xa')]({'where':{'id':0x1},'attributes':[_0x1a0d('0xb'),'blockDuration'],'raw':!![]})['then'](function(_0x5c4ff1){_0x26f690=_0x5c4ff1;return db[_0x1a0d('0x3e')][_0x1a0d('0x20')]({'where':{'email':_0x4ab8de['body'][_0x1a0d('0x21')]}});})[_0x1a0d('0xc')](function(_0x5aca9b){if(!_0x5aca9b){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x5aca9b[_0x1a0d('0x10')]){throw new Error(_0x1a0d('0x3f'));}if(_0x5aca9b[_0x1a0d('0x11')]){if(moment(_0x5aca9b['blockedAt'])[_0x1a0d('0x1c')](_0x26f690['blockDuration'],_0x1a0d('0x1a'))>moment()){throw new Error(_0x1a0d('0x40'));}else{_0x5aca9b[_0x1a0d('0x11')]=![];_0x5aca9b[_0x1a0d('0x18')]=null;}}_0x5aca9b[_0x1a0d('0x41')]=_0x23a0ad;_0x5aca9b[_0x1a0d('0x42')]=Date[_0x1a0d('0x43')]()+0x36ee80;return _0x5aca9b[_0x1a0d('0x44')]();})[_0x1a0d('0xc')](function(){return sendServiceMail({'to':_0x4ab8de[_0x1a0d('0x3b')]['email'],'subject':_0x1a0d('0x45'),'text':'You\x20are\x20receiving\x20this\x20because\x20you\x20(or\x20someone\x20else)\x20have\x20requested\x20the\x20reset\x20of\x20the\x20password\x20for\x20your\x20account.\x0a\x0a'+_0x1a0d('0x46')+'https://'+_0x4ab8de[_0x1a0d('0x47')]['host']+_0x1a0d('0x48')+_0x23a0ad+'\x0a\x0a'+_0x1a0d('0x49')});})[_0x1a0d('0xc')](function(){_0x598c16[_0x1a0d('0x32')](0xc8)[_0x1a0d('0x33')]({'message':_0x1a0d('0x4a')});})[_0x1a0d('0x1e')](function(_0x36e5af){return handleError(_0x598c16,0x1f4,_0x36e5af);});};exports[_0x1a0d('0x4b')]=function(_0x17ffdb,_0x42f549,_0x55ac19){return db[_0x1a0d('0x3e')][_0x1a0d('0x20')]({'where':{'resetPasswordToken':_0x17ffdb['params']['token'],'resetPasswordExpires':{'$gt':Date[_0x1a0d('0x43')]()}}})[_0x1a0d('0xc')](function(_0x1db2cd){if(!_0x1db2cd){throw new Error(_0x1a0d('0x4c'));}return db['Setting']['findOne']({'attributes':['id',_0x1a0d('0x4d'),_0x1a0d('0x4e'),_0x1a0d('0x4f')]})[_0x1a0d('0xc')](function(_0x16afdf){if(_0x16afdf['securePassword'])authService[_0x1a0d('0x50')](_0x17ffdb['body'][_0x1a0d('0xe')]);if(!_0x16afdf[_0x1a0d('0x4e')]||!_0x1db2cd[_0x1a0d('0x51')])return _0x1db2cd;authService[_0x1a0d('0x52')](_0x17ffdb['body'][_0x1a0d('0xe')],_0x1db2cd[_0x1a0d('0x51')],_0x16afdf[_0x1a0d('0x4f')]);return _0x1db2cd;})['then'](function(){_0x1db2cd['password']=_0x17ffdb['body']['password'];_0x1db2cd[_0x1a0d('0x41')]=null;_0x1db2cd[_0x1a0d('0x42')]=null;return _0x1db2cd['save']();});})[_0x1a0d('0xc')](function(){_0x42f549['status'](0xc8)[_0x1a0d('0x33')]({'message':_0x1a0d('0x53')});})[_0x1a0d('0x1e')](function(_0x4328b8){return handleError(_0x42f549,0x1f4,_0x4328b8);});};passport['use'](_0x1a0d('0x36'),new LocalStrategy({'usernameField':'name','passwordField':_0x1a0d('0xe')},function(_0x24e587,_0x349b5d,_0x312e8c){return localAuthenticate(db['User'],_0x24e587,_0x349b5d,_0x312e8c);}));