Built motion from commit (unavailable).|2.5.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 _0x5430=['token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','validatePasswordPattern','previousPasswords','validatePasswordHistory','passwordHistoryLimit','resetPasswordToken','resetPasswordExpires','save','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','lodash','../../mysqldb','client','http','Setting','findOne','allowedLoginAttempts','blockDuration','password','salt','role','disabled','blocked','blockedAt','loginAttempts','admin','user','agent','then','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','add','minutes','clearBlockUser','getLicense','catch','MailAccount','find','name','MailServerOut','Smtp','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','service','host','secure','authentication','pass','merge','\x22%s\x22\x20<%s>','email','request','SendMail','error','format','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','login','authenticate','Something\x20went\x20wrong,\x20please\x20try\x20again.','json','online','body','Email\x20parameter\x20is\x20missing','trim','toLowerCase','User','This\x20email\x20is\x20not\x20registered.','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','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','send','reset'];(function(_0x3813c9,_0x2f3bb3){var _0x561a96=function(_0x45539e){while(--_0x45539e){_0x3813c9['push'](_0x3813c9['shift']());}};_0x561a96(++_0x2f3bb3);}(_0x5430,0x10c));var _0x0543=function(_0x330b11,_0x34bcf3){_0x330b11=_0x330b11-0x0;var _0x267055=_0x5430[_0x330b11];return _0x267055;};'use strict';var util=require(_0x0543('0x0'));var passport=require(_0x0543('0x1'));var LocalStrategy=require(_0x0543('0x2'))[_0x0543('0x3')];var jayson=require(_0x0543('0x4'));var _=require(_0x0543('0x5'));var rs=require('randomstring');var moment=require('moment');var db=require(_0x0543('0x6'))['db'];var authService=require('../../components/auth/service');var utils=require('../../config/utils');var client=jayson[_0x0543('0x7')][_0x0543('0x8')]({'port':0x232b});function localAuthenticate(_0x9754ba,_0x319568,_0x46bca7,_0x5ac352){var _0x372974,_0x7b8280;return db[_0x0543('0x9')][_0x0543('0xa')]({'where':{'id':0x1},'attributes':[_0x0543('0xb'),_0x0543('0xc')],'raw':!![]})['then'](function(_0x1ed7cc){_0x372974=_0x1ed7cc;return _0x9754ba[_0x0543('0xa')]({'attributes':['id','name',_0x0543('0xd'),_0x0543('0xe'),_0x0543('0xf'),_0x0543('0x10'),_0x0543('0x11'),_0x0543('0x12'),_0x0543('0x13')],'where':{'name':_0x319568,'role':{'$or':[_0x0543('0x14'),_0x0543('0x15'),_0x0543('0x16')]}}});})[_0x0543('0x17')](function(_0x509afa){if(!_0x509afa||_0x509afa&&_0x509afa['name']!==_0x319568){throw new Error(_0x0543('0x18'));}else{_0x7b8280=_0x509afa;return _0x7b8280;}})[_0x0543('0x17')](function(){_0x7b8280['authenticate'](_0x46bca7,function(_0x4c4763,_0xcb09df){var _0x40fb03=_0x7b8280[_0x0543('0x13')]+0x1;if(_0x4c4763){return _0x5ac352(_0x4c4763);}else if(!_0xcb09df){if(_0x7b8280[_0x0543('0x10')]){return _0x5ac352(null,![],{'message':_0x0543('0x18')});}else if(_0x372974['allowedLoginAttempts']>0x0){if(_0x7b8280[_0x0543('0x11')]){if(_0x372974[_0x0543('0xc')]>0x0){if(moment(_0x7b8280[_0x0543('0x12')])[_0x0543('0x19')](_0x372974[_0x0543('0xc')],_0x0543('0x1a'))>moment()){return _0x5ac352(null,![],{'message':_0x0543('0x18')});}else{return utils['clearBlockUser'](_0x7b8280,_0x40fb03,![],null)[_0x0543('0x17')](function(){return _0x5ac352(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x5ac352(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x40fb03>=_0x372974[_0x0543('0xb')]){return utils[_0x0543('0x1b')](_0x7b8280,0x0,!![],moment())[_0x0543('0x17')](function(){return _0x5ac352(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}else{return utils[_0x0543('0x1b')](_0x7b8280,_0x40fb03,![],null)['then'](function(){return _0x5ac352(null,![],{'message':_0x0543('0x18')});});}}}else{return _0x5ac352(null,![],{'message':_0x0543('0x18')});}}else{if(_0x7b8280['disabled']){return _0x5ac352(null,![],{'message':_0x0543('0x18')});}else if(_0x372974[_0x0543('0xb')]>0x0){if(_0x7b8280[_0x0543('0x11')]){if(_0x372974[_0x0543('0xc')]>0x0){if(moment(_0x7b8280[_0x0543('0x12')])[_0x0543('0x19')](_0x372974['blockDuration'],'minutes')>moment()){return _0x5ac352(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x0543('0x1b')](_0x7b8280,0x0,![],null)[_0x0543('0x17')](function(){return utils[_0x0543('0x1c')](_0x7b8280);})[_0x0543('0x17')](function(){return _0x5ac352(null,_0x7b8280);});}}else{return _0x5ac352(null,![],{'message':_0x0543('0x18')});}}else{return utils[_0x0543('0x1b')](_0x7b8280,0x0,![],null)[_0x0543('0x17')](function(){return utils[_0x0543('0x1c')](_0x7b8280);})[_0x0543('0x17')](function(){return _0x5ac352(null,_0x7b8280);})[_0x0543('0x1d')](function(_0x40a261){return _0x5ac352(null,![],_0x40a261);});}}else{if(_0x7b8280[_0x0543('0x11')]){return _0x5ac352(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x0543('0x1c')](_0x7b8280)[_0x0543('0x17')](function(){return _0x5ac352(null,_0x7b8280);});}}}});})[_0x0543('0x1d')](function(_0x4f2592){return _0x5ac352(null,![],_0x4f2592);});}function sendServiceMail(_0x9c7e34){return db[_0x0543('0x1e')][_0x0543('0x1f')]({'where':{'service':!![]},'attributes':['id',_0x0543('0x20'),'email'],'include':[{'model':db[_0x0543('0x21')],'as':_0x0543('0x22')}]})['then'](function(_0x576084){if(!_0x576084){throw new Error(_0x0543('0x23'));}var _0x16165c={'tls':{'rejectUnauthorized':![]}};if(_0x576084['Smtp'][_0x0543('0x24')]){_0x16165c[_0x0543('0x24')]=_0x576084[_0x0543('0x22')][_0x0543('0x24')];}else{_0x16165c[_0x0543('0x25')]=_0x576084[_0x0543('0x22')][_0x0543('0x25')];_0x16165c['port']=_0x576084[_0x0543('0x22')]['port'];_0x16165c[_0x0543('0x26')]=_0x576084[_0x0543('0x22')][_0x0543('0x26')];}if(_0x576084[_0x0543('0x22')][_0x0543('0x27')]){_0x16165c['auth']={'user':_0x576084[_0x0543('0x22')]['user'],'pass':_0x576084[_0x0543('0x22')][_0x0543('0x28')]};}var _0x39e96c={'account':_0x16165c,'message':_[_0x0543('0x29')]({'from':util['format'](_0x0543('0x2a'),_0x576084['name'],_0x576084[_0x0543('0x2b')]||_0x576084[_0x0543('0x22')][_0x0543('0x15')])},_0x9c7e34)};return client[_0x0543('0x2c')](_0x0543('0x2d'),_0x39e96c);})[_0x0543('0x17')](function(_0x2a1e4f){if(_0x2a1e4f[_0x0543('0x2e')]){throw new Error(util[_0x0543('0x2f')](_0x0543('0x30'),_0x2a1e4f['error'][_0x0543('0x31')]||JSON[_0x0543('0x32')](_0x2a1e4f['error'])));}return!![];});}function handleError(_0x96745b,_0x4b9c1f,_0x133295){return _0x96745b[_0x0543('0x33')](_0x4b9c1f||0x1f4)['send']({'message':_0x133295?_0x133295['message']||_0x133295:''});}exports[_0x0543('0x34')]=function(_0xd153df,_0x4ca572,_0x2282ea){passport[_0x0543('0x35')]('local',function(_0x44db30,_0x2896b9,_0x3ecd70){var _0x117982=_0x44db30||_0x3ecd70;if(_0x117982){return handleError(_0x4ca572,0x191,_0x117982);}if(!_0x2896b9){return handleError(_0x4ca572,0x194,{'message':_0x0543('0x36')});}else{var _0x4b78c3={'payload':{'id':_0x2896b9['id'],'role':_0x2896b9['role']},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x4b78c3)[_0x0543('0x17')](function(_0x335821){_0x4ca572[_0x0543('0x37')]({'id':_0x2896b9['id'],'token':_0x335821,'statusCall':'','isAlreadyLogged':_0x2896b9[_0x0543('0x38')]});});}})(_0xd153df,_0x4ca572,_0x2282ea);};exports['forgot']=function(_0xc66396,_0xa10c19,_0xe3936f){if(!_0xc66396[_0x0543('0x39')][_0x0543('0x2b')]){return handleError(_0xa10c19,0x1f4,{'message':_0x0543('0x3a')});}var _0x40f941=rs['generate']();_0xc66396[_0x0543('0x39')][_0x0543('0x2b')]=_0xc66396[_0x0543('0x39')][_0x0543('0x2b')][_0x0543('0x3b')]()[_0x0543('0x3c')]();var _0x5bf53d;return db['Setting'][_0x0543('0xa')]({'where':{'id':0x1},'attributes':[_0x0543('0xb'),_0x0543('0xc')],'raw':!![]})[_0x0543('0x17')](function(_0x29aada){_0x5bf53d=_0x29aada;return db[_0x0543('0x3d')][_0x0543('0x1f')]({'where':{'email':_0xc66396[_0x0543('0x39')][_0x0543('0x2b')]}});})['then'](function(_0x4c99f0){if(!_0x4c99f0){throw new Error(_0x0543('0x3e'));}if(_0x4c99f0[_0x0543('0x10')]){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x4c99f0['blocked']){if(moment(_0x4c99f0[_0x0543('0x12')])[_0x0543('0x19')](_0x5bf53d['blockDuration'],_0x0543('0x1a'))>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x4c99f0[_0x0543('0x11')]=![];_0x4c99f0[_0x0543('0x12')]=null;}}_0x4c99f0['resetPasswordToken']=_0x40f941;_0x4c99f0['resetPasswordExpires']=Date[_0x0543('0x3f')]()+0x36ee80;return _0x4c99f0['save']();})[_0x0543('0x17')](function(){return sendServiceMail({'to':_0xc66396[_0x0543('0x39')][_0x0543('0x2b')],'subject':_0x0543('0x40'),'text':_0x0543('0x41')+_0x0543('0x42')+'https://'+_0xc66396[_0x0543('0x43')][_0x0543('0x25')]+_0x0543('0x44')+_0x40f941+'\x0a\x0a'+_0x0543('0x45')});})[_0x0543('0x17')](function(){_0xa10c19['status'](0xc8)[_0x0543('0x46')]({'message':'Reset\x20Email\x20sent!'});})[_0x0543('0x1d')](function(_0x3e8c64){return handleError(_0xa10c19,0x1f4,_0x3e8c64);});};exports[_0x0543('0x47')]=function(_0x46d398,_0x32e4e6,_0x406ad3){return db['User']['find']({'where':{'resetPasswordToken':_0x46d398['params'][_0x0543('0x48')],'resetPasswordExpires':{'$gt':Date[_0x0543('0x3f')]()}}})['then'](function(_0x188bfd){if(!_0x188bfd){throw new Error(_0x0543('0x49'));}return db[_0x0543('0x9')][_0x0543('0xa')]({'attributes':['id',_0x0543('0x4a'),_0x0543('0x4b'),'passwordHistoryLimit']})[_0x0543('0x17')](function(_0x35a3bf){if(_0x35a3bf[_0x0543('0x4a')])authService[_0x0543('0x4c')](_0x46d398[_0x0543('0x39')][_0x0543('0xd')]);if(!_0x35a3bf[_0x0543('0x4b')]||!_0x188bfd[_0x0543('0x4d')])return _0x188bfd;authService[_0x0543('0x4e')](_0x46d398[_0x0543('0x39')][_0x0543('0xd')],_0x188bfd[_0x0543('0x4d')],_0x35a3bf[_0x0543('0x4f')]);return _0x188bfd;})[_0x0543('0x17')](function(){_0x188bfd['password']=_0x46d398[_0x0543('0x39')][_0x0543('0xd')];_0x188bfd[_0x0543('0x50')]=null;_0x188bfd[_0x0543('0x51')]=null;return _0x188bfd[_0x0543('0x52')]();});})[_0x0543('0x17')](function(){_0x32e4e6[_0x0543('0x33')](0xc8)[_0x0543('0x46')]({'message':_0x0543('0x53')});})[_0x0543('0x1d')](function(_0x44723c){return handleError(_0x32e4e6,0x1f4,_0x44723c);});};passport[_0x0543('0x54')](new LocalStrategy({'usernameField':_0x0543('0x20'),'passwordField':_0x0543('0xd')},function(_0x1dd874,_0x5cbf98,_0x402196){return localAuthenticate(db[_0x0543('0x3d')],_0x1dd874,_0x5cbf98,_0x402196);}));