52e33a2536ea975b3644141e91cbb2345ac0df6c
[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 _0xc4fe=['/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.','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','validatePasswordHistory','Password\x20reset!','use','util','passport','Strategy','jayson/promise','randomstring','moment','../../mysqldb','../../config/utils','Setting','findOne','blockDuration','password','role','disabled','blockedAt','admin','agent','then','name','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','loginAttempts','allowedLoginAttempts','blocked','add','minutes','clearBlockUser','getLicense','catch','MailAccount','MailServerOut','Smtp','CloudProvider','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','getSmtpOptions','format','email','user','request','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','status','send','local-login','signToken','json','forgot','body','generate','trim','User','find','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','The\x20user\x20is\x20blocked.\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','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','host'];(function(_0x39448d,_0x51984e){var _0x3d5932=function(_0x1799bf){while(--_0x1799bf){_0x39448d['push'](_0x39448d['shift']());}};_0x3d5932(++_0x51984e);}(_0xc4fe,0x184));var _0xec4f=function(_0x3dd15e,_0x1f0015){_0x3dd15e=_0x3dd15e-0x0;var _0x231fd0=_0xc4fe[_0x3dd15e];return _0x231fd0;};'use strict';var util=require(_0xec4f('0x0'));var passport=require(_0xec4f('0x1'));var LocalStrategy=require('passport-local')[_0xec4f('0x2')];var jayson=require(_0xec4f('0x3'));var _=require('lodash');var rs=require(_0xec4f('0x4'));var moment=require(_0xec4f('0x5'));var db=require(_0xec4f('0x6'))['db'];var authService=require('../../components/auth/service');var utils=require(_0xec4f('0x7'));var client=jayson['client']['http']({'port':0x232b});function localAuthenticate(_0x2570ff,_0x2bebc5,_0x443e77,_0x293083){var _0x15a763,_0x4d8c16;return db[_0xec4f('0x8')][_0xec4f('0x9')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts',_0xec4f('0xa')],'raw':!![]})['then'](function(_0x275b16){_0x15a763=_0x275b16;return _0x2570ff[_0xec4f('0x9')]({'attributes':['id','name',_0xec4f('0xb'),'salt',_0xec4f('0xc'),_0xec4f('0xd'),'blocked',_0xec4f('0xe'),'loginAttempts'],'where':{'name':_0x2bebc5,'role':{'$or':[_0xec4f('0xf'),'user',_0xec4f('0x10')]}}});})[_0xec4f('0x11')](function(_0x2e55af){if(!_0x2e55af||_0x2e55af&&_0x2e55af[_0xec4f('0x12')]!==_0x2bebc5){throw new Error(_0xec4f('0x13'));}else{_0x4d8c16=_0x2e55af;return _0x4d8c16;}})[_0xec4f('0x11')](function(){_0x4d8c16[_0xec4f('0x14')](_0x443e77,function(_0xe99ab1,_0x521313){var _0x38134f=_0x4d8c16[_0xec4f('0x15')]+0x1;if(_0xe99ab1){return _0x293083(_0xe99ab1);}else if(!_0x521313){if(_0x4d8c16[_0xec4f('0xd')]){return _0x293083(null,![],{'message':_0xec4f('0x13')});}else if(_0x15a763[_0xec4f('0x16')]>0x0){if(_0x4d8c16[_0xec4f('0x17')]){if(_0x15a763[_0xec4f('0xa')]>0x0){if(moment(_0x4d8c16[_0xec4f('0xe')])[_0xec4f('0x18')](_0x15a763['blockDuration'],_0xec4f('0x19'))>moment()){return _0x293083(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils['clearBlockUser'](_0x4d8c16,_0x38134f,![],null)[_0xec4f('0x11')](function(){return _0x293083(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x293083(null,![],{'message':_0xec4f('0x13')});}}else{if(_0x38134f>=_0x15a763[_0xec4f('0x16')]){return utils[_0xec4f('0x1a')](_0x4d8c16,0x0,!![],moment())[_0xec4f('0x11')](function(){return _0x293083(null,![],{'message':_0xec4f('0x13')});});}else{return utils[_0xec4f('0x1a')](_0x4d8c16,_0x38134f,![],null)[_0xec4f('0x11')](function(){return _0x293083(null,![],{'message':_0xec4f('0x13')});});}}}else{return _0x293083(null,![],{'message':_0xec4f('0x13')});}}else{if(_0x4d8c16[_0xec4f('0xd')]){return _0x293083(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x15a763[_0xec4f('0x16')]>0x0){if(_0x4d8c16[_0xec4f('0x17')]){if(_0x15a763[_0xec4f('0xa')]>0x0){if(moment(_0x4d8c16[_0xec4f('0xe')])[_0xec4f('0x18')](_0x15a763[_0xec4f('0xa')],_0xec4f('0x19'))>moment()){return _0x293083(null,![],{'message':_0xec4f('0x13')});}else{return utils['clearBlockUser'](_0x4d8c16,0x0,![],null)[_0xec4f('0x11')](function(){return utils[_0xec4f('0x1b')](_0x4d8c16);})[_0xec4f('0x11')](function(){return _0x293083(null,_0x4d8c16);});}}else{return _0x293083(null,![],{'message':_0xec4f('0x13')});}}else{return utils['clearBlockUser'](_0x4d8c16,0x0,![],null)['then'](function(){return utils[_0xec4f('0x1b')](_0x4d8c16);})[_0xec4f('0x11')](function(){return _0x293083(null,_0x4d8c16);})['catch'](function(_0x53d1a9){return _0x293083(null,![],_0x53d1a9);});}}else{if(_0x4d8c16[_0xec4f('0x17')]){return _0x293083(null,![],{'message':_0xec4f('0x13')});}else{return utils['getLicense'](_0x4d8c16)['then'](function(){return _0x293083(null,_0x4d8c16);});}}}});})[_0xec4f('0x1c')](function(_0x4d48a0){return _0x293083(null,![],_0x4d48a0);});}function sendServiceMail(_0x1605bc){return db[_0xec4f('0x1d')]['find']({'where':{'service':!![]},'attributes':['id',_0xec4f('0x12'),'email'],'include':[{'model':db[_0xec4f('0x1e')],'as':_0xec4f('0x1f'),'include':[{'model':db[_0xec4f('0x20')],'as':_0xec4f('0x20')}]}]})[_0xec4f('0x11')](function(_0x4f7c62){if(!_0x4f7c62){throw new Error(_0xec4f('0x21'));}var _0x5b5a3d=_0x4f7c62[_0xec4f('0x22')]();var _0x4740c8={'account':_0x5b5a3d,'message':_['merge']({'from':util[_0xec4f('0x23')]('\x22%s\x22\x20<%s>',_0x4f7c62[_0xec4f('0x12')],_0x4f7c62[_0xec4f('0x24')]||_0x4f7c62['Smtp'][_0xec4f('0x25')])},_0x1605bc)};return client[_0xec4f('0x26')]('SendMail',_0x4740c8);})[_0xec4f('0x11')](function(_0x1eac14){if(_0x1eac14[_0xec4f('0x27')]){throw new Error(util['format'](_0xec4f('0x28'),_0x1eac14[_0xec4f('0x27')][_0xec4f('0x29')]||JSON['stringify'](_0x1eac14[_0xec4f('0x27')])));}return!![];});}function handleError(_0x5db9ae,_0x26fd78,_0x5868b1){return _0x5db9ae[_0xec4f('0x2a')](_0x26fd78||0x1f4)[_0xec4f('0x2b')]({'message':_0x5868b1?_0x5868b1[_0xec4f('0x29')]||_0x5868b1:''});}exports['login']=function(_0x13af70,_0x49e2d5,_0x25e503){passport['authenticate'](_0xec4f('0x2c'),function(_0x4095c3,_0x478b92,_0x3bd112){var _0x451825=_0x4095c3||_0x3bd112;if(_0x451825){return handleError(_0x49e2d5,0x191,_0x451825);}if(!_0x478b92){return handleError(_0x49e2d5,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x5a0389={'payload':{'id':_0x478b92['id'],'role':_0x478b92['role']},'options':{'expiresIn':0x15180}};return authService[_0xec4f('0x2d')](_0x5a0389)[_0xec4f('0x11')](function(_0x1461d5){_0x49e2d5[_0xec4f('0x2e')]({'id':_0x478b92['id'],'token':_0x1461d5,'statusCall':'','isAlreadyLogged':_0x478b92['online']});});}})(_0x13af70,_0x49e2d5,_0x25e503);};exports[_0xec4f('0x2f')]=function(_0x3bafec,_0x29ecf1){if(!_0x3bafec[_0xec4f('0x30')]['email']){return handleError(_0x29ecf1,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x18dd60=rs[_0xec4f('0x31')]();_0x3bafec[_0xec4f('0x30')]['email']=_0x3bafec[_0xec4f('0x30')][_0xec4f('0x24')][_0xec4f('0x32')]()['toLowerCase']();var _0x4df2cb;return db['Setting'][_0xec4f('0x9')]({'where':{'id':0x1},'attributes':[_0xec4f('0x16'),'blockDuration'],'raw':!![]})[_0xec4f('0x11')](function(_0x21cc43){_0x4df2cb=_0x21cc43;return db[_0xec4f('0x33')][_0xec4f('0x34')]({'where':{'email':_0x3bafec[_0xec4f('0x30')][_0xec4f('0x24')]}});})[_0xec4f('0x11')](function(_0x4d483b){if(!_0x4d483b){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x4d483b[_0xec4f('0xd')]){throw new Error(_0xec4f('0x35'));}if(_0x4d483b[_0xec4f('0x17')]){if(moment(_0x4d483b[_0xec4f('0xe')])[_0xec4f('0x18')](_0x4df2cb[_0xec4f('0xa')],_0xec4f('0x19'))>moment()){throw new Error(_0xec4f('0x36'));}else{_0x4d483b[_0xec4f('0x17')]=![];_0x4d483b[_0xec4f('0xe')]=null;}}_0x4d483b[_0xec4f('0x37')]=_0x18dd60;_0x4d483b[_0xec4f('0x38')]=Date[_0xec4f('0x39')]()+0x36ee80;return _0x4d483b[_0xec4f('0x3a')]();})[_0xec4f('0x11')](function(){return sendServiceMail({'to':_0x3bafec[_0xec4f('0x30')][_0xec4f('0x24')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0xec4f('0x3b')+_0xec4f('0x3c')+'https://'+_0x3bafec['headers'][_0xec4f('0x3d')]+_0xec4f('0x3e')+_0x18dd60+'\x0a\x0a'+_0xec4f('0x3f')});})[_0xec4f('0x11')](function(){_0x29ecf1['status'](0xc8)['send']({'message':_0xec4f('0x40')});})['catch'](function(_0x28972c){return handleError(_0x29ecf1,0x1f4,_0x28972c);});};exports[_0xec4f('0x41')]=function(_0x2e599b,_0x11baf5){return db[_0xec4f('0x33')]['find']({'where':{'resetPasswordToken':_0x2e599b[_0xec4f('0x42')][_0xec4f('0x43')],'resetPasswordExpires':{'$gt':Date[_0xec4f('0x39')]()}}})[_0xec4f('0x11')](function(_0x4002bd){if(!_0x4002bd){throw new Error(_0xec4f('0x44'));}return db[_0xec4f('0x8')][_0xec4f('0x9')]({'attributes':['id','securePassword',_0xec4f('0x45'),_0xec4f('0x46')]})[_0xec4f('0x11')](function(_0x4ba688){if(_0x4ba688['securePassword'])authService[_0xec4f('0x47')](_0x2e599b[_0xec4f('0x30')][_0xec4f('0xb')]);if(!_0x4ba688[_0xec4f('0x45')]||!_0x4002bd['previousPasswords'])return _0x4002bd;authService[_0xec4f('0x48')](_0x2e599b[_0xec4f('0x30')]['password'],_0x4002bd['previousPasswords'],_0x4ba688[_0xec4f('0x46')]);return _0x4002bd;})[_0xec4f('0x11')](function(){_0x4002bd[_0xec4f('0xb')]=_0x2e599b['body'][_0xec4f('0xb')];_0x4002bd['resetPasswordToken']=null;_0x4002bd[_0xec4f('0x38')]=null;return _0x4002bd[_0xec4f('0x3a')]();});})['then'](function(){_0x11baf5[_0xec4f('0x2a')](0xc8)[_0xec4f('0x2b')]({'message':_0xec4f('0x49')});})[_0xec4f('0x1c')](function(_0xe0585f){return handleError(_0x11baf5,0x1f4,_0xe0585f);});};passport[_0xec4f('0x4a')](_0xec4f('0x2c'),new LocalStrategy({'usernameField':_0xec4f('0x12'),'passwordField':_0xec4f('0xb')},function(_0x203986,_0x2ecf7d,_0x40a4b1){return localAuthenticate(db[_0xec4f('0x33')],_0x203986,_0x2ecf7d,_0x40a4b1);}));