Built motion from commit 00bf23f6.|2.6.16
[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 _0x3bbf=['resetPasswordToken','Password\x20reset!','use','local-login','util','passport-local','Strategy','jayson/promise','lodash','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','allowedLoginAttempts','blockDuration','then','findOne','name','salt','role','disabled','blockedAt','user','agent','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','loginAttempts','blocked','minutes','clearBlockUser','add','getLicense','catch','MailAccount','email','MailServerOut','CloudProvider','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','getSmtpOptions','merge','format','\x22%s\x22\x20<%s>','Smtp','request','error','message','stringify','status','login','Something\x20went\x20wrong,\x20please\x20try\x20again.','signToken','json','online','forgot','body','generate','trim','toLowerCase','find','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordExpires','now','save','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','https://','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','send','Reset\x20Email\x20sent!','User','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','password','previousPasswords','validatePasswordHistory'];(function(_0x39d666,_0x2ef328){var _0x1a5677=function(_0xe3f545){while(--_0xe3f545){_0x39d666['push'](_0x39d666['shift']());}};_0x1a5677(++_0x2ef328);}(_0x3bbf,0xb4));var _0xf3bb=function(_0x1fdf85,_0x5c801d){_0x1fdf85=_0x1fdf85-0x0;var _0x18d1b1=_0x3bbf[_0x1fdf85];return _0x18d1b1;};'use strict';var util=require(_0xf3bb('0x0'));var passport=require('passport');var LocalStrategy=require(_0xf3bb('0x1'))[_0xf3bb('0x2')];var jayson=require(_0xf3bb('0x3'));var _=require(_0xf3bb('0x4'));var rs=require(_0xf3bb('0x5'));var moment=require(_0xf3bb('0x6'));var db=require(_0xf3bb('0x7'))['db'];var authService=require(_0xf3bb('0x8'));var utils=require(_0xf3bb('0x9'));var client=jayson[_0xf3bb('0xa')][_0xf3bb('0xb')]({'port':0x232b});function localAuthenticate(_0x3d89e0,_0x45e4e4,_0x30c290,_0x19eb59){var _0x2dd4c6,_0x53b317;return db[_0xf3bb('0xc')]['findOne']({'where':{'id':0x1},'attributes':[_0xf3bb('0xd'),_0xf3bb('0xe')],'raw':!![]})[_0xf3bb('0xf')](function(_0xcbab60){_0x2dd4c6=_0xcbab60;return _0x3d89e0[_0xf3bb('0x10')]({'attributes':['id',_0xf3bb('0x11'),'password',_0xf3bb('0x12'),_0xf3bb('0x13'),_0xf3bb('0x14'),'blocked',_0xf3bb('0x15'),'loginAttempts'],'where':{'name':_0x45e4e4,'role':{'$or':['admin',_0xf3bb('0x16'),_0xf3bb('0x17')]}}});})[_0xf3bb('0xf')](function(_0xb6110){if(!_0xb6110||_0xb6110&&_0xb6110[_0xf3bb('0x11')]!==_0x45e4e4){throw new Error(_0xf3bb('0x18'));}else{_0x53b317=_0xb6110;return _0x53b317;}})[_0xf3bb('0xf')](function(){_0x53b317[_0xf3bb('0x19')](_0x30c290,function(_0x1b46e3,_0x354964){var _0x4348f8=_0x53b317[_0xf3bb('0x1a')]+0x1;if(_0x1b46e3){return _0x19eb59(_0x1b46e3);}else if(!_0x354964){if(_0x53b317[_0xf3bb('0x14')]){return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});}else if(_0x2dd4c6[_0xf3bb('0xd')]>0x0){if(_0x53b317[_0xf3bb('0x1b')]){if(_0x2dd4c6[_0xf3bb('0xe')]>0x0){if(moment(_0x53b317[_0xf3bb('0x15')])['add'](_0x2dd4c6[_0xf3bb('0xe')],_0xf3bb('0x1c'))>moment()){return _0x19eb59(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xf3bb('0x1d')](_0x53b317,_0x4348f8,![],null)[_0xf3bb('0xf')](function(){return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});});}}else{return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});}}else{if(_0x4348f8>=_0x2dd4c6[_0xf3bb('0xd')]){return utils['clearBlockUser'](_0x53b317,0x0,!![],moment())[_0xf3bb('0xf')](function(){return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});});}else{return utils[_0xf3bb('0x1d')](_0x53b317,_0x4348f8,![],null)[_0xf3bb('0xf')](function(){return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});});}}}else{return _0x19eb59(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x53b317[_0xf3bb('0x14')]){return _0x19eb59(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x2dd4c6[_0xf3bb('0xd')]>0x0){if(_0x53b317['blocked']){if(_0x2dd4c6['blockDuration']>0x0){if(moment(_0x53b317[_0xf3bb('0x15')])[_0xf3bb('0x1e')](_0x2dd4c6[_0xf3bb('0xe')],'minutes')>moment()){return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});}else{return utils[_0xf3bb('0x1d')](_0x53b317,0x0,![],null)['then'](function(){return utils[_0xf3bb('0x1f')](_0x53b317);})[_0xf3bb('0xf')](function(){return _0x19eb59(null,_0x53b317);});}}else{return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});}}else{return utils[_0xf3bb('0x1d')](_0x53b317,0x0,![],null)['then'](function(){return utils[_0xf3bb('0x1f')](_0x53b317);})['then'](function(){return _0x19eb59(null,_0x53b317);})[_0xf3bb('0x20')](function(_0x456287){return _0x19eb59(null,![],_0x456287);});}}else{if(_0x53b317[_0xf3bb('0x1b')]){return _0x19eb59(null,![],{'message':_0xf3bb('0x18')});}else{return utils[_0xf3bb('0x1f')](_0x53b317)[_0xf3bb('0xf')](function(){return _0x19eb59(null,_0x53b317);});}}}});})[_0xf3bb('0x20')](function(_0x1ec676){return _0x19eb59(null,![],_0x1ec676);});}function sendServiceMail(_0xe9194d){return db[_0xf3bb('0x21')]['find']({'where':{'service':!![]},'attributes':['id','name',_0xf3bb('0x22')],'include':[{'model':db[_0xf3bb('0x23')],'as':'Smtp','include':[{'model':db[_0xf3bb('0x24')],'as':_0xf3bb('0x24')}]}]})['then'](function(_0xb117d){if(!_0xb117d){throw new Error(_0xf3bb('0x25'));}var _0x3a581d=_0xb117d[_0xf3bb('0x26')]();var _0x4c2536={'account':_0x3a581d,'message':_[_0xf3bb('0x27')]({'from':util[_0xf3bb('0x28')](_0xf3bb('0x29'),_0xb117d[_0xf3bb('0x11')],_0xb117d['email']||_0xb117d[_0xf3bb('0x2a')][_0xf3bb('0x16')])},_0xe9194d)};return client[_0xf3bb('0x2b')]('SendMail',_0x4c2536);})[_0xf3bb('0xf')](function(_0x18bf68){if(_0x18bf68['error']){throw new Error(util[_0xf3bb('0x28')]('SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!',_0x18bf68[_0xf3bb('0x2c')][_0xf3bb('0x2d')]||JSON[_0xf3bb('0x2e')](_0x18bf68[_0xf3bb('0x2c')])));}return!![];});}function handleError(_0x237582,_0x2a92ed,_0x491865){return _0x237582[_0xf3bb('0x2f')](_0x2a92ed||0x1f4)['send']({'message':_0x491865?_0x491865[_0xf3bb('0x2d')]||_0x491865:''});}exports[_0xf3bb('0x30')]=function(_0x332815,_0x352654,_0x52edbc){passport[_0xf3bb('0x19')]('local-login',function(_0x1ec0ca,_0xc24a5b,_0x1d8ac9){var _0xd09cd7=_0x1ec0ca||_0x1d8ac9;if(_0xd09cd7){return handleError(_0x352654,0x191,_0xd09cd7);}if(!_0xc24a5b){return handleError(_0x352654,0x194,{'message':_0xf3bb('0x31')});}else{var _0x548454={'payload':{'id':_0xc24a5b['id'],'role':_0xc24a5b[_0xf3bb('0x13')]},'options':{'expiresIn':0x15180}};return authService[_0xf3bb('0x32')](_0x548454)[_0xf3bb('0xf')](function(_0x426194){_0x352654[_0xf3bb('0x33')]({'id':_0xc24a5b['id'],'token':_0x426194,'statusCall':'','isAlreadyLogged':_0xc24a5b[_0xf3bb('0x34')]});});}})(_0x332815,_0x352654,_0x52edbc);};exports[_0xf3bb('0x35')]=function(_0x98961c,_0x5e107a){if(!_0x98961c[_0xf3bb('0x36')][_0xf3bb('0x22')]){return handleError(_0x5e107a,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x4dd9c4=rs[_0xf3bb('0x37')]();_0x98961c[_0xf3bb('0x36')][_0xf3bb('0x22')]=_0x98961c[_0xf3bb('0x36')][_0xf3bb('0x22')][_0xf3bb('0x38')]()[_0xf3bb('0x39')]();var _0x11dad3;return db[_0xf3bb('0xc')][_0xf3bb('0x10')]({'where':{'id':0x1},'attributes':[_0xf3bb('0xd'),_0xf3bb('0xe')],'raw':!![]})[_0xf3bb('0xf')](function(_0x91b301){_0x11dad3=_0x91b301;return db['User'][_0xf3bb('0x3a')]({'where':{'email':_0x98961c['body'][_0xf3bb('0x22')]}});})['then'](function(_0x15a7b4){if(!_0x15a7b4){throw new Error(_0xf3bb('0x3b'));}if(_0x15a7b4[_0xf3bb('0x14')]){throw new Error(_0xf3bb('0x3c'));}if(_0x15a7b4[_0xf3bb('0x1b')]){if(moment(_0x15a7b4[_0xf3bb('0x15')])['add'](_0x11dad3[_0xf3bb('0xe')],_0xf3bb('0x1c'))>moment()){throw new Error(_0xf3bb('0x3d'));}else{_0x15a7b4[_0xf3bb('0x1b')]=![];_0x15a7b4[_0xf3bb('0x15')]=null;}}_0x15a7b4['resetPasswordToken']=_0x4dd9c4;_0x15a7b4[_0xf3bb('0x3e')]=Date[_0xf3bb('0x3f')]()+0x36ee80;return _0x15a7b4[_0xf3bb('0x40')]();})[_0xf3bb('0xf')](function(){return sendServiceMail({'to':_0x98961c[_0xf3bb('0x36')][_0xf3bb('0x22')],'subject':_0xf3bb('0x41'),'text':_0xf3bb('0x42')+_0xf3bb('0x43')+_0xf3bb('0x44')+_0x98961c['headers']['host']+_0xf3bb('0x45')+_0x4dd9c4+'\x0a\x0a'+_0xf3bb('0x46')});})[_0xf3bb('0xf')](function(){_0x5e107a[_0xf3bb('0x2f')](0xc8)[_0xf3bb('0x47')]({'message':_0xf3bb('0x48')});})[_0xf3bb('0x20')](function(_0x234a29){return handleError(_0x5e107a,0x1f4,_0x234a29);});};exports['reset']=function(_0x46a986,_0x4bd790){return db[_0xf3bb('0x49')][_0xf3bb('0x3a')]({'where':{'resetPasswordToken':_0x46a986[_0xf3bb('0x4a')][_0xf3bb('0x4b')],'resetPasswordExpires':{'$gt':Date[_0xf3bb('0x3f')]()}}})[_0xf3bb('0xf')](function(_0x3679c4){if(!_0x3679c4){throw new Error(_0xf3bb('0x4c'));}return db[_0xf3bb('0xc')]['findOne']({'attributes':['id',_0xf3bb('0x4d'),_0xf3bb('0x4e'),_0xf3bb('0x4f')]})[_0xf3bb('0xf')](function(_0x4eac70){if(_0x4eac70[_0xf3bb('0x4d')])authService[_0xf3bb('0x50')](_0x46a986[_0xf3bb('0x36')][_0xf3bb('0x51')]);if(!_0x4eac70[_0xf3bb('0x4e')]||!_0x3679c4[_0xf3bb('0x52')])return _0x3679c4;authService[_0xf3bb('0x53')](_0x46a986[_0xf3bb('0x36')][_0xf3bb('0x51')],_0x3679c4[_0xf3bb('0x52')],_0x4eac70[_0xf3bb('0x4f')]);return _0x3679c4;})['then'](function(){_0x3679c4[_0xf3bb('0x51')]=_0x46a986[_0xf3bb('0x36')][_0xf3bb('0x51')];_0x3679c4[_0xf3bb('0x54')]=null;_0x3679c4['resetPasswordExpires']=null;return _0x3679c4[_0xf3bb('0x40')]();});})[_0xf3bb('0xf')](function(){_0x4bd790['status'](0xc8)['send']({'message':_0xf3bb('0x55')});})['catch'](function(_0x1898b4){return handleError(_0x4bd790,0x1f4,_0x1898b4);});};passport[_0xf3bb('0x56')](_0xf3bb('0x57'),new LocalStrategy({'usernameField':_0xf3bb('0x11'),'passwordField':_0xf3bb('0x51')},function(_0x455fb5,_0x5429a4,_0x55f7b6){return localAuthenticate(db['User'],_0x455fb5,_0x5429a4,_0x55f7b6);}));