8b227c35837442c918e8d830e67170347b62f578
[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 _0x0b26=['pass','format','email','request','SendMail','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','send','login','local-login','json','online','forgot','body','Email\x20parameter\x20is\x20missing','toLowerCase','Setting','User','This\x20email\x20is\x20not\x20registered.','resetPasswordExpires','now','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','headers','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','reset','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','randomstring','moment','../../components/auth/service','client','http','findOne','allowedLoginAttempts','blockDuration','then','name','password','role','disabled','blocked','loginAttempts','admin','user','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockedAt','add','minutes','clearBlockUser','getLicense','catch','MailAccount','find','MailServerOut','Smtp','host','port','secure','authentication','auth'];(function(_0x513aa5,_0x1fba79){var _0x1a1a7c=function(_0x240e3f){while(--_0x240e3f){_0x513aa5['push'](_0x513aa5['shift']());}};_0x1a1a7c(++_0x1fba79);}(_0x0b26,0x1bf));var _0x60b2=function(_0x507ac5,_0x33aaee){_0x507ac5=_0x507ac5-0x0;var _0x12c1bc=_0x0b26[_0x507ac5];return _0x12c1bc;};'use strict';var util=require(_0x60b2('0x0'));var passport=require(_0x60b2('0x1'));var LocalStrategy=require(_0x60b2('0x2'))[_0x60b2('0x3')];var jayson=require(_0x60b2('0x4'));var _=require('lodash');var rs=require(_0x60b2('0x5'));var moment=require(_0x60b2('0x6'));var db=require('../../mysqldb')['db'];var authService=require(_0x60b2('0x7'));var utils=require('../../config/utils');var client=jayson[_0x60b2('0x8')][_0x60b2('0x9')]({'port':0x232b});function localAuthenticate(_0x4ef40b,_0x4744aa,_0x44c245,_0x59826c){var _0x27e327,_0xb726a9;return db['Setting'][_0x60b2('0xa')]({'where':{'id':0x1},'attributes':[_0x60b2('0xb'),_0x60b2('0xc')],'raw':!![]})[_0x60b2('0xd')](function(_0x239371){_0x27e327=_0x239371;return _0x4ef40b[_0x60b2('0xa')]({'attributes':['id',_0x60b2('0xe'),_0x60b2('0xf'),'salt',_0x60b2('0x10'),_0x60b2('0x11'),_0x60b2('0x12'),'blockedAt',_0x60b2('0x13')],'where':{'name':_0x4744aa,'role':{'$or':[_0x60b2('0x14'),_0x60b2('0x15'),'agent']}}});})['then'](function(_0x30c0d9){if(!_0x30c0d9||_0x30c0d9&&_0x30c0d9['name']!==_0x4744aa){throw new Error(_0x60b2('0x16'));}else{_0xb726a9=_0x30c0d9;return _0xb726a9;}})[_0x60b2('0xd')](function(){_0xb726a9[_0x60b2('0x17')](_0x44c245,function(_0x954334,_0x111972){var _0x40b674=_0xb726a9[_0x60b2('0x13')]+0x1;if(_0x954334){return _0x59826c(_0x954334);}else if(!_0x111972){if(_0xb726a9[_0x60b2('0x11')]){return _0x59826c(null,![],{'message':_0x60b2('0x16')});}else if(_0x27e327[_0x60b2('0xb')]>0x0){if(_0xb726a9[_0x60b2('0x12')]){if(_0x27e327[_0x60b2('0xc')]>0x0){if(moment(_0xb726a9[_0x60b2('0x18')])[_0x60b2('0x19')](_0x27e327['blockDuration'],_0x60b2('0x1a'))>moment()){return _0x59826c(null,![],{'message':_0x60b2('0x16')});}else{return utils[_0x60b2('0x1b')](_0xb726a9,_0x40b674,![],null)[_0x60b2('0xd')](function(){return _0x59826c(null,![],{'message':_0x60b2('0x16')});});}}else{return _0x59826c(null,![],{'message':_0x60b2('0x16')});}}else{if(_0x40b674>=_0x27e327[_0x60b2('0xb')]){return utils[_0x60b2('0x1b')](_0xb726a9,0x0,!![],moment())[_0x60b2('0xd')](function(){return _0x59826c(null,![],{'message':_0x60b2('0x16')});});}else{return utils[_0x60b2('0x1b')](_0xb726a9,_0x40b674,![],null)[_0x60b2('0xd')](function(){return _0x59826c(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}}else{return _0x59826c(null,![],{'message':_0x60b2('0x16')});}}else{if(_0xb726a9[_0x60b2('0x11')]){return _0x59826c(null,![],{'message':_0x60b2('0x16')});}else if(_0x27e327[_0x60b2('0xb')]>0x0){if(_0xb726a9[_0x60b2('0x12')]){if(_0x27e327[_0x60b2('0xc')]>0x0){if(moment(_0xb726a9[_0x60b2('0x18')])[_0x60b2('0x19')](_0x27e327['blockDuration'],_0x60b2('0x1a'))>moment()){return _0x59826c(null,![],{'message':_0x60b2('0x16')});}else{return utils[_0x60b2('0x1b')](_0xb726a9,0x0,![],null)[_0x60b2('0xd')](function(){return utils[_0x60b2('0x1c')](_0xb726a9);})[_0x60b2('0xd')](function(){return _0x59826c(null,_0xb726a9);});}}else{return _0x59826c(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{return utils['clearBlockUser'](_0xb726a9,0x0,![],null)[_0x60b2('0xd')](function(){return utils[_0x60b2('0x1c')](_0xb726a9);})['then'](function(){return _0x59826c(null,_0xb726a9);})[_0x60b2('0x1d')](function(_0x7c81a1){return _0x59826c(null,![],_0x7c81a1);});}}else{if(_0xb726a9[_0x60b2('0x12')]){return _0x59826c(null,![],{'message':_0x60b2('0x16')});}else{return utils['getLicense'](_0xb726a9)[_0x60b2('0xd')](function(){return _0x59826c(null,_0xb726a9);});}}}});})['catch'](function(_0x2f9c93){return _0x59826c(null,![],_0x2f9c93);});}function sendServiceMail(_0x35bf54){return db[_0x60b2('0x1e')][_0x60b2('0x1f')]({'where':{'service':!![]},'attributes':['id',_0x60b2('0xe'),'email'],'include':[{'model':db[_0x60b2('0x20')],'as':'Smtp'}]})[_0x60b2('0xd')](function(_0x25749e){if(!_0x25749e){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x1ffe24={'tls':{'rejectUnauthorized':![]}};if(_0x25749e[_0x60b2('0x21')]['service']){_0x1ffe24['service']=_0x25749e[_0x60b2('0x21')]['service'];}else{_0x1ffe24[_0x60b2('0x22')]=_0x25749e['Smtp'][_0x60b2('0x22')];_0x1ffe24[_0x60b2('0x23')]=_0x25749e[_0x60b2('0x21')]['port'];_0x1ffe24[_0x60b2('0x24')]=_0x25749e[_0x60b2('0x21')]['secure'];}if(_0x25749e[_0x60b2('0x21')][_0x60b2('0x25')]){_0x1ffe24[_0x60b2('0x26')]={'user':_0x25749e[_0x60b2('0x21')][_0x60b2('0x15')],'pass':_0x25749e['Smtp'][_0x60b2('0x27')]};}var _0x4cc11b={'account':_0x1ffe24,'message':_['merge']({'from':util[_0x60b2('0x28')]('\x22%s\x22\x20<%s>',_0x25749e[_0x60b2('0xe')],_0x25749e[_0x60b2('0x29')]||_0x25749e[_0x60b2('0x21')][_0x60b2('0x15')])},_0x35bf54)};return client[_0x60b2('0x2a')](_0x60b2('0x2b'),_0x4cc11b);})['then'](function(_0x285bd1){if(_0x285bd1[_0x60b2('0x2c')]){throw new Error(util['format'](_0x60b2('0x2d'),_0x285bd1[_0x60b2('0x2c')][_0x60b2('0x2e')]||JSON[_0x60b2('0x2f')](_0x285bd1[_0x60b2('0x2c')])));}return!![];});}function handleError(_0x26c145,_0x4f3452,_0x52f38b){return _0x26c145[_0x60b2('0x30')](_0x4f3452||0x1f4)[_0x60b2('0x31')]({'message':_0x52f38b?_0x52f38b[_0x60b2('0x2e')]||_0x52f38b:''});}exports[_0x60b2('0x32')]=function(_0x2d5277,_0x225eff,_0x548d47){passport[_0x60b2('0x17')](_0x60b2('0x33'),function(_0x50a5eb,_0x596e44,_0x704c37){var _0xbba05c=_0x50a5eb||_0x704c37;if(_0xbba05c){return handleError(_0x225eff,0x191,_0xbba05c);}if(!_0x596e44){return handleError(_0x225eff,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x594f1b={'payload':{'id':_0x596e44['id'],'role':_0x596e44[_0x60b2('0x10')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x594f1b)[_0x60b2('0xd')](function(_0x1b4705){_0x225eff[_0x60b2('0x34')]({'id':_0x596e44['id'],'token':_0x1b4705,'statusCall':'','isAlreadyLogged':_0x596e44[_0x60b2('0x35')]});});}})(_0x2d5277,_0x225eff,_0x548d47);};exports[_0x60b2('0x36')]=function(_0x26f450,_0x57961c,_0xde65fb){if(!_0x26f450[_0x60b2('0x37')][_0x60b2('0x29')]){return handleError(_0x57961c,0x1f4,{'message':_0x60b2('0x38')});}var _0x518069=rs['generate']();_0x26f450['body'][_0x60b2('0x29')]=_0x26f450[_0x60b2('0x37')]['email']['trim']()[_0x60b2('0x39')]();var _0x528785;return db[_0x60b2('0x3a')][_0x60b2('0xa')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts','blockDuration'],'raw':!![]})[_0x60b2('0xd')](function(_0x10a2cb){_0x528785=_0x10a2cb;return db[_0x60b2('0x3b')]['find']({'where':{'email':_0x26f450[_0x60b2('0x37')][_0x60b2('0x29')]}});})['then'](function(_0x3ea55d){if(!_0x3ea55d){throw new Error(_0x60b2('0x3c'));}if(_0x3ea55d['disabled']){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x3ea55d[_0x60b2('0x12')]){if(moment(_0x3ea55d['blockedAt'])[_0x60b2('0x19')](_0x528785[_0x60b2('0xc')],'minutes')>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x3ea55d[_0x60b2('0x12')]=![];_0x3ea55d[_0x60b2('0x18')]=null;}}_0x3ea55d['resetPasswordToken']=_0x518069;_0x3ea55d[_0x60b2('0x3d')]=Date[_0x60b2('0x3e')]()+0x36ee80;return _0x3ea55d[_0x60b2('0x3f')]();})[_0x60b2('0xd')](function(){return sendServiceMail({'to':_0x26f450[_0x60b2('0x37')][_0x60b2('0x29')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0x60b2('0x40')+_0x60b2('0x41')+'https://'+_0x26f450[_0x60b2('0x42')][_0x60b2('0x22')]+_0x60b2('0x43')+_0x518069+'\x0a\x0a'+_0x60b2('0x44')});})['then'](function(){_0x57961c[_0x60b2('0x30')](0xc8)['send']({'message':_0x60b2('0x45')});})[_0x60b2('0x1d')](function(_0x7d0e65){return handleError(_0x57961c,0x1f4,_0x7d0e65);});};exports[_0x60b2('0x46')]=function(_0x4a3fb9,_0x41ddf6,_0x1dbe37){return db[_0x60b2('0x3b')][_0x60b2('0x1f')]({'where':{'resetPasswordToken':_0x4a3fb9[_0x60b2('0x47')][_0x60b2('0x48')],'resetPasswordExpires':{'$gt':Date[_0x60b2('0x3e')]()}}})['then'](function(_0x828583){if(!_0x828583){throw new Error(_0x60b2('0x49'));}return db['Setting'][_0x60b2('0xa')]({'attributes':['id',_0x60b2('0x4a'),_0x60b2('0x4b'),_0x60b2('0x4c')]})[_0x60b2('0xd')](function(_0x587e27){if(_0x587e27[_0x60b2('0x4a')])authService[_0x60b2('0x4d')](_0x4a3fb9[_0x60b2('0x37')][_0x60b2('0xf')]);if(!_0x587e27['enforcePasswordHistory']||!_0x828583['previousPasswords'])return _0x828583;authService['validatePasswordHistory'](_0x4a3fb9['body'][_0x60b2('0xf')],_0x828583[_0x60b2('0x4e')],_0x587e27[_0x60b2('0x4c')]);return _0x828583;})['then'](function(){_0x828583[_0x60b2('0xf')]=_0x4a3fb9[_0x60b2('0x37')][_0x60b2('0xf')];_0x828583['resetPasswordToken']=null;_0x828583['resetPasswordExpires']=null;return _0x828583[_0x60b2('0x3f')]();});})['then'](function(){_0x41ddf6['status'](0xc8)[_0x60b2('0x31')]({'message':_0x60b2('0x4f')});})['catch'](function(_0x1a02f8){return handleError(_0x41ddf6,0x1f4,_0x1a02f8);});};passport[_0x60b2('0x50')]('local-login',new LocalStrategy({'usernameField':'name','passwordField':_0x60b2('0xf')},function(_0x3c9900,_0x334b66,_0x15462d){return localAuthenticate(db[_0x60b2('0x3b')],_0x3c9900,_0x334b66,_0x15462d);}));