Built motion from commit f7863d46.|2.5.41
[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 _0x26af=['Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockDuration','minutes','clearBlockUser','add','getLicense','catch','MailAccount','find','MailServerOut','Smtp','service','host','port','secure','authentication','merge','format','\x22%s\x22\x20<%s>','email','request','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','stringify','status','send','message','local-login','Something\x20went\x20wrong,\x20please\x20try\x20again.','signToken','json','body','Email\x20parameter\x20is\x20missing','generate','trim','toLowerCase','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','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','headers','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','reset','User','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','passwordHistoryLimit','validatePasswordPattern','enforcePasswordHistory','previousPasswords','validatePasswordHistory','password','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','lodash','randomstring','moment','../../components/auth/service','../../config/utils','client','http','Setting','findOne','allowedLoginAttempts','then','name','role','disabled','blocked','blockedAt','loginAttempts','user'];(function(_0xcd2975,_0x27d718){var _0x284074=function(_0x47a69d){while(--_0x47a69d){_0xcd2975['push'](_0xcd2975['shift']());}};_0x284074(++_0x27d718);}(_0x26af,0x1e1));var _0xf26a=function(_0x2d61b2,_0x142947){_0x2d61b2=_0x2d61b2-0x0;var _0x12df89=_0x26af[_0x2d61b2];return _0x12df89;};'use strict';var util=require(_0xf26a('0x0'));var passport=require(_0xf26a('0x1'));var LocalStrategy=require(_0xf26a('0x2'))[_0xf26a('0x3')];var jayson=require(_0xf26a('0x4'));var _=require(_0xf26a('0x5'));var rs=require(_0xf26a('0x6'));var moment=require(_0xf26a('0x7'));var db=require('../../mysqldb')['db'];var authService=require(_0xf26a('0x8'));var utils=require(_0xf26a('0x9'));var client=jayson[_0xf26a('0xa')][_0xf26a('0xb')]({'port':0x232b});function localAuthenticate(_0x25d426,_0x21f2ea,_0x22332a,_0x5f6e81){var _0x53687c,_0x5ceae4;return db[_0xf26a('0xc')][_0xf26a('0xd')]({'where':{'id':0x1},'attributes':[_0xf26a('0xe'),'blockDuration'],'raw':!![]})[_0xf26a('0xf')](function(_0x330a65){_0x53687c=_0x330a65;return _0x25d426[_0xf26a('0xd')]({'attributes':['id',_0xf26a('0x10'),'password','salt',_0xf26a('0x11'),_0xf26a('0x12'),_0xf26a('0x13'),_0xf26a('0x14'),_0xf26a('0x15')],'where':{'name':_0x21f2ea,'role':{'$or':['admin',_0xf26a('0x16'),'agent']}}});})['then'](function(_0x2ba5d5){if(!_0x2ba5d5||_0x2ba5d5&&_0x2ba5d5[_0xf26a('0x10')]!==_0x21f2ea){throw new Error(_0xf26a('0x17'));}else{_0x5ceae4=_0x2ba5d5;return _0x5ceae4;}})['then'](function(){_0x5ceae4[_0xf26a('0x18')](_0x22332a,function(_0x1da087,_0x585fd1){var _0x305644=_0x5ceae4[_0xf26a('0x15')]+0x1;if(_0x1da087){return _0x5f6e81(_0x1da087);}else if(!_0x585fd1){if(_0x5ceae4['disabled']){return _0x5f6e81(null,![],{'message':_0xf26a('0x17')});}else if(_0x53687c[_0xf26a('0xe')]>0x0){if(_0x5ceae4[_0xf26a('0x13')]){if(_0x53687c[_0xf26a('0x19')]>0x0){if(moment(_0x5ceae4['blockedAt'])['add'](_0x53687c[_0xf26a('0x19')],_0xf26a('0x1a'))>moment()){return _0x5f6e81(null,![],{'message':_0xf26a('0x17')});}else{return utils['clearBlockUser'](_0x5ceae4,_0x305644,![],null)[_0xf26a('0xf')](function(){return _0x5f6e81(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x5f6e81(null,![],{'message':_0xf26a('0x17')});}}else{if(_0x305644>=_0x53687c[_0xf26a('0xe')]){return utils[_0xf26a('0x1b')](_0x5ceae4,0x0,!![],moment())[_0xf26a('0xf')](function(){return _0x5f6e81(null,![],{'message':_0xf26a('0x17')});});}else{return utils[_0xf26a('0x1b')](_0x5ceae4,_0x305644,![],null)['then'](function(){return _0x5f6e81(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}}else{return _0x5f6e81(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x5ceae4['disabled']){return _0x5f6e81(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x53687c['allowedLoginAttempts']>0x0){if(_0x5ceae4[_0xf26a('0x13')]){if(_0x53687c[_0xf26a('0x19')]>0x0){if(moment(_0x5ceae4[_0xf26a('0x14')])[_0xf26a('0x1c')](_0x53687c[_0xf26a('0x19')],_0xf26a('0x1a'))>moment()){return _0x5f6e81(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils['clearBlockUser'](_0x5ceae4,0x0,![],null)[_0xf26a('0xf')](function(){return utils[_0xf26a('0x1d')](_0x5ceae4);})[_0xf26a('0xf')](function(){return _0x5f6e81(null,_0x5ceae4);});}}else{return _0x5f6e81(null,![],{'message':_0xf26a('0x17')});}}else{return utils[_0xf26a('0x1b')](_0x5ceae4,0x0,![],null)[_0xf26a('0xf')](function(){return utils[_0xf26a('0x1d')](_0x5ceae4);})[_0xf26a('0xf')](function(){return _0x5f6e81(null,_0x5ceae4);})['catch'](function(_0x1c582d){return _0x5f6e81(null,![],_0x1c582d);});}}else{if(_0x5ceae4[_0xf26a('0x13')]){return _0x5f6e81(null,![],{'message':_0xf26a('0x17')});}else{return utils[_0xf26a('0x1d')](_0x5ceae4)[_0xf26a('0xf')](function(){return _0x5f6e81(null,_0x5ceae4);});}}}});})[_0xf26a('0x1e')](function(_0x49211a){return _0x5f6e81(null,![],_0x49211a);});}function sendServiceMail(_0x2a0eb1){return db[_0xf26a('0x1f')][_0xf26a('0x20')]({'where':{'service':!![]},'attributes':['id',_0xf26a('0x10'),'email'],'include':[{'model':db[_0xf26a('0x21')],'as':'Smtp'}]})[_0xf26a('0xf')](function(_0x18c7e4){if(!_0x18c7e4){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x50ac81={'tls':{'rejectUnauthorized':![]}};if(_0x18c7e4[_0xf26a('0x22')][_0xf26a('0x23')]){_0x50ac81[_0xf26a('0x23')]=_0x18c7e4['Smtp'][_0xf26a('0x23')];}else{_0x50ac81['host']=_0x18c7e4['Smtp'][_0xf26a('0x24')];_0x50ac81[_0xf26a('0x25')]=_0x18c7e4[_0xf26a('0x22')]['port'];_0x50ac81[_0xf26a('0x26')]=_0x18c7e4['Smtp'][_0xf26a('0x26')];}if(_0x18c7e4[_0xf26a('0x22')][_0xf26a('0x27')]){_0x50ac81['auth']={'user':_0x18c7e4[_0xf26a('0x22')][_0xf26a('0x16')],'pass':_0x18c7e4[_0xf26a('0x22')]['pass']};}var _0xafab0={'account':_0x50ac81,'message':_[_0xf26a('0x28')]({'from':util[_0xf26a('0x29')](_0xf26a('0x2a'),_0x18c7e4[_0xf26a('0x10')],_0x18c7e4[_0xf26a('0x2b')]||_0x18c7e4[_0xf26a('0x22')][_0xf26a('0x16')])},_0x2a0eb1)};return client[_0xf26a('0x2c')]('SendMail',_0xafab0);})[_0xf26a('0xf')](function(_0x39ee95){if(_0x39ee95[_0xf26a('0x2d')]){throw new Error(util[_0xf26a('0x29')](_0xf26a('0x2e'),_0x39ee95[_0xf26a('0x2d')]['message']||JSON[_0xf26a('0x2f')](_0x39ee95[_0xf26a('0x2d')])));}return!![];});}function handleError(_0x13d4f9,_0x44d5c0,_0x22169f){return _0x13d4f9[_0xf26a('0x30')](_0x44d5c0||0x1f4)[_0xf26a('0x31')]({'message':_0x22169f?_0x22169f[_0xf26a('0x32')]||_0x22169f:''});}exports['login']=function(_0x4e8529,_0x33db3e,_0xd96eed){passport['authenticate'](_0xf26a('0x33'),function(_0x167ba1,_0x168421,_0x506719){var _0x4f4c5b=_0x167ba1||_0x506719;if(_0x4f4c5b){return handleError(_0x33db3e,0x191,_0x4f4c5b);}if(!_0x168421){return handleError(_0x33db3e,0x194,{'message':_0xf26a('0x34')});}else{var _0xbed9ac={'payload':{'id':_0x168421['id'],'role':_0x168421[_0xf26a('0x11')]},'options':{'expiresIn':0x15180}};return authService[_0xf26a('0x35')](_0xbed9ac)[_0xf26a('0xf')](function(_0xf2f2ee){_0x33db3e[_0xf26a('0x36')]({'id':_0x168421['id'],'token':_0xf2f2ee,'statusCall':'','isAlreadyLogged':_0x168421['online']});});}})(_0x4e8529,_0x33db3e,_0xd96eed);};exports['forgot']=function(_0x1d2870,_0x5260d8,_0x81beac){if(!_0x1d2870[_0xf26a('0x37')][_0xf26a('0x2b')]){return handleError(_0x5260d8,0x1f4,{'message':_0xf26a('0x38')});}var _0x92df34=rs[_0xf26a('0x39')]();_0x1d2870['body'][_0xf26a('0x2b')]=_0x1d2870[_0xf26a('0x37')][_0xf26a('0x2b')][_0xf26a('0x3a')]()[_0xf26a('0x3b')]();var _0x2de840;return db[_0xf26a('0xc')][_0xf26a('0xd')]({'where':{'id':0x1},'attributes':[_0xf26a('0xe'),_0xf26a('0x19')],'raw':!![]})['then'](function(_0x11dca7){_0x2de840=_0x11dca7;return db['User'][_0xf26a('0x20')]({'where':{'email':_0x1d2870[_0xf26a('0x37')][_0xf26a('0x2b')]}});})[_0xf26a('0xf')](function(_0x4d3e77){if(!_0x4d3e77){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x4d3e77[_0xf26a('0x12')]){throw new Error(_0xf26a('0x3c'));}if(_0x4d3e77[_0xf26a('0x13')]){if(moment(_0x4d3e77[_0xf26a('0x14')])[_0xf26a('0x1c')](_0x2de840[_0xf26a('0x19')],_0xf26a('0x1a'))>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x4d3e77['blocked']=![];_0x4d3e77[_0xf26a('0x14')]=null;}}_0x4d3e77[_0xf26a('0x3d')]=_0x92df34;_0x4d3e77[_0xf26a('0x3e')]=Date[_0xf26a('0x3f')]()+0x36ee80;return _0x4d3e77[_0xf26a('0x40')]();})[_0xf26a('0xf')](function(){return sendServiceMail({'to':_0x1d2870[_0xf26a('0x37')][_0xf26a('0x2b')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0xf26a('0x41')+'Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a'+'https://'+_0x1d2870[_0xf26a('0x42')][_0xf26a('0x24')]+_0xf26a('0x43')+_0x92df34+'\x0a\x0a'+_0xf26a('0x44')});})[_0xf26a('0xf')](function(){_0x5260d8[_0xf26a('0x30')](0xc8)[_0xf26a('0x31')]({'message':_0xf26a('0x45')});})['catch'](function(_0xfd5196){return handleError(_0x5260d8,0x1f4,_0xfd5196);});};exports[_0xf26a('0x46')]=function(_0x3434ba,_0x454ac4,_0xc04c94){return db[_0xf26a('0x47')][_0xf26a('0x20')]({'where':{'resetPasswordToken':_0x3434ba[_0xf26a('0x48')][_0xf26a('0x49')],'resetPasswordExpires':{'$gt':Date[_0xf26a('0x3f')]()}}})[_0xf26a('0xf')](function(_0x2d39fa){if(!_0x2d39fa){throw new Error(_0xf26a('0x4a'));}return db['Setting'][_0xf26a('0xd')]({'attributes':['id',_0xf26a('0x4b'),'enforcePasswordHistory',_0xf26a('0x4c')]})[_0xf26a('0xf')](function(_0x473b72){if(_0x473b72[_0xf26a('0x4b')])authService[_0xf26a('0x4d')](_0x3434ba[_0xf26a('0x37')]['password']);if(!_0x473b72[_0xf26a('0x4e')]||!_0x2d39fa[_0xf26a('0x4f')])return _0x2d39fa;authService[_0xf26a('0x50')](_0x3434ba['body']['password'],_0x2d39fa[_0xf26a('0x4f')],_0x473b72[_0xf26a('0x4c')]);return _0x2d39fa;})['then'](function(){_0x2d39fa[_0xf26a('0x51')]=_0x3434ba['body'][_0xf26a('0x51')];_0x2d39fa[_0xf26a('0x3d')]=null;_0x2d39fa[_0xf26a('0x3e')]=null;return _0x2d39fa['save']();});})[_0xf26a('0xf')](function(){_0x454ac4[_0xf26a('0x30')](0xc8)[_0xf26a('0x31')]({'message':_0xf26a('0x52')});})[_0xf26a('0x1e')](function(_0x7d8b02){return handleError(_0x454ac4,0x1f4,_0x7d8b02);});};passport[_0xf26a('0x53')](_0xf26a('0x33'),new LocalStrategy({'usernameField':'name','passwordField':'password'},function(_0x13a8e1,_0x301f24,_0x2dadfd){return localAuthenticate(db['User'],_0x13a8e1,_0x301f24,_0x2dadfd);}));