Built motion from commit 9d0783e6.|2.6.13
[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 _0x9860=['The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','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','https://','headers','host','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','reset','params','token','now','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','validatePasswordHistory','resetPasswordExpires','save','Password\x20reset!','util','passport','passport-local','jayson/promise','randomstring','moment','../../components/auth/service','../../config/utils','client','http','findOne','allowedLoginAttempts','blockDuration','password','salt','disabled','blocked','loginAttempts','admin','user','then','name','authenticate','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','blockedAt','add','minutes','clearBlockUser','getLicense','catch','MailAccount','find','email','MailServerOut','Smtp','CloudProvider','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','getSmtpOptions','merge','\x22%s\x22\x20<%s>','request','SendMail','error','format','message','status','send','login','local-login','role','signToken','online','forgot','body','generate','trim','toLowerCase','Setting','User','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.'];(function(_0x2ce307,_0x26f21d){var _0x54cda2=function(_0x382935){while(--_0x382935){_0x2ce307['push'](_0x2ce307['shift']());}};_0x54cda2(++_0x26f21d);}(_0x9860,0x117));var _0x0986=function(_0x2dafbe,_0x5d04de){_0x2dafbe=_0x2dafbe-0x0;var _0x58a45a=_0x9860[_0x2dafbe];return _0x58a45a;};'use strict';var util=require(_0x0986('0x0'));var passport=require(_0x0986('0x1'));var LocalStrategy=require(_0x0986('0x2'))['Strategy'];var jayson=require(_0x0986('0x3'));var _=require('lodash');var rs=require(_0x0986('0x4'));var moment=require(_0x0986('0x5'));var db=require('../../mysqldb')['db'];var authService=require(_0x0986('0x6'));var utils=require(_0x0986('0x7'));var client=jayson[_0x0986('0x8')][_0x0986('0x9')]({'port':0x232b});function localAuthenticate(_0x1de4f4,_0x3fe208,_0x1ccd41,_0x487407){var _0x3b7e9f,_0xda0ee7;return db['Setting'][_0x0986('0xa')]({'where':{'id':0x1},'attributes':[_0x0986('0xb'),_0x0986('0xc')],'raw':!![]})['then'](function(_0x4c3d13){_0x3b7e9f=_0x4c3d13;return _0x1de4f4['findOne']({'attributes':['id','name',_0x0986('0xd'),_0x0986('0xe'),'role',_0x0986('0xf'),_0x0986('0x10'),'blockedAt',_0x0986('0x11')],'where':{'name':_0x3fe208,'role':{'$or':[_0x0986('0x12'),_0x0986('0x13'),'agent']}}});})[_0x0986('0x14')](function(_0x118ff2){if(!_0x118ff2||_0x118ff2&&_0x118ff2[_0x0986('0x15')]!==_0x3fe208){throw new Error('Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.');}else{_0xda0ee7=_0x118ff2;return _0xda0ee7;}})[_0x0986('0x14')](function(){_0xda0ee7[_0x0986('0x16')](_0x1ccd41,function(_0x2c9f75,_0x37f77c){var _0x5e6ecf=_0xda0ee7[_0x0986('0x11')]+0x1;if(_0x2c9f75){return _0x487407(_0x2c9f75);}else if(!_0x37f77c){if(_0xda0ee7['disabled']){return _0x487407(null,![],{'message':_0x0986('0x17')});}else if(_0x3b7e9f[_0x0986('0xb')]>0x0){if(_0xda0ee7[_0x0986('0x10')]){if(_0x3b7e9f[_0x0986('0xc')]>0x0){if(moment(_0xda0ee7[_0x0986('0x18')])[_0x0986('0x19')](_0x3b7e9f['blockDuration'],_0x0986('0x1a'))>moment()){return _0x487407(null,![],{'message':_0x0986('0x17')});}else{return utils[_0x0986('0x1b')](_0xda0ee7,_0x5e6ecf,![],null)[_0x0986('0x14')](function(){return _0x487407(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x487407(null,![],{'message':_0x0986('0x17')});}}else{if(_0x5e6ecf>=_0x3b7e9f[_0x0986('0xb')]){return utils[_0x0986('0x1b')](_0xda0ee7,0x0,!![],moment())[_0x0986('0x14')](function(){return _0x487407(null,![],{'message':_0x0986('0x17')});});}else{return utils['clearBlockUser'](_0xda0ee7,_0x5e6ecf,![],null)[_0x0986('0x14')](function(){return _0x487407(null,![],{'message':_0x0986('0x17')});});}}}else{return _0x487407(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0xda0ee7[_0x0986('0xf')]){return _0x487407(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x3b7e9f[_0x0986('0xb')]>0x0){if(_0xda0ee7[_0x0986('0x10')]){if(_0x3b7e9f[_0x0986('0xc')]>0x0){if(moment(_0xda0ee7[_0x0986('0x18')])['add'](_0x3b7e9f[_0x0986('0xc')],'minutes')>moment()){return _0x487407(null,![],{'message':_0x0986('0x17')});}else{return utils[_0x0986('0x1b')](_0xda0ee7,0x0,![],null)[_0x0986('0x14')](function(){return utils[_0x0986('0x1c')](_0xda0ee7);})['then'](function(){return _0x487407(null,_0xda0ee7);});}}else{return _0x487407(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{return utils[_0x0986('0x1b')](_0xda0ee7,0x0,![],null)['then'](function(){return utils['getLicense'](_0xda0ee7);})['then'](function(){return _0x487407(null,_0xda0ee7);})[_0x0986('0x1d')](function(_0x2dae62){return _0x487407(null,![],_0x2dae62);});}}else{if(_0xda0ee7[_0x0986('0x10')]){return _0x487407(null,![],{'message':_0x0986('0x17')});}else{return utils[_0x0986('0x1c')](_0xda0ee7)[_0x0986('0x14')](function(){return _0x487407(null,_0xda0ee7);});}}}});})['catch'](function(_0x547991){return _0x487407(null,![],_0x547991);});}function sendServiceMail(_0x1c6d2e){return db[_0x0986('0x1e')][_0x0986('0x1f')]({'where':{'service':!![]},'attributes':['id','name',_0x0986('0x20')],'include':[{'model':db[_0x0986('0x21')],'as':_0x0986('0x22'),'include':[{'model':db[_0x0986('0x23')],'as':'CloudProvider'}]}]})['then'](function(_0x584563){if(!_0x584563){throw new Error(_0x0986('0x24'));}var _0x57ab3c=_0x584563[_0x0986('0x25')]();var _0x51a59b={'account':_0x57ab3c,'message':_[_0x0986('0x26')]({'from':util['format'](_0x0986('0x27'),_0x584563[_0x0986('0x15')],_0x584563[_0x0986('0x20')]||_0x584563[_0x0986('0x22')][_0x0986('0x13')])},_0x1c6d2e)};return client[_0x0986('0x28')](_0x0986('0x29'),_0x51a59b);})[_0x0986('0x14')](function(_0x2aa445){if(_0x2aa445[_0x0986('0x2a')]){throw new Error(util[_0x0986('0x2b')]('SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!',_0x2aa445['error'][_0x0986('0x2c')]||JSON['stringify'](_0x2aa445[_0x0986('0x2a')])));}return!![];});}function handleError(_0x444df9,_0x160751,_0x43644e){return _0x444df9[_0x0986('0x2d')](_0x160751||0x1f4)[_0x0986('0x2e')]({'message':_0x43644e?_0x43644e[_0x0986('0x2c')]||_0x43644e:''});}exports[_0x0986('0x2f')]=function(_0xb48c46,_0x5d3d5d,_0x49fe25){passport[_0x0986('0x16')](_0x0986('0x30'),function(_0x4e18c0,_0x58b3d9,_0x543e27){var _0x31fd56=_0x4e18c0||_0x543e27;if(_0x31fd56){return handleError(_0x5d3d5d,0x191,_0x31fd56);}if(!_0x58b3d9){return handleError(_0x5d3d5d,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x32ee69={'payload':{'id':_0x58b3d9['id'],'role':_0x58b3d9[_0x0986('0x31')]},'options':{'expiresIn':0x15180}};return authService[_0x0986('0x32')](_0x32ee69)[_0x0986('0x14')](function(_0x321965){_0x5d3d5d['json']({'id':_0x58b3d9['id'],'token':_0x321965,'statusCall':'','isAlreadyLogged':_0x58b3d9[_0x0986('0x33')]});});}})(_0xb48c46,_0x5d3d5d,_0x49fe25);};exports[_0x0986('0x34')]=function(_0x52cd5c,_0x3e2b15){if(!_0x52cd5c[_0x0986('0x35')][_0x0986('0x20')]){return handleError(_0x3e2b15,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x186a97=rs[_0x0986('0x36')]();_0x52cd5c[_0x0986('0x35')]['email']=_0x52cd5c['body']['email'][_0x0986('0x37')]()[_0x0986('0x38')]();var _0x20bf1b;return db[_0x0986('0x39')][_0x0986('0xa')]({'where':{'id':0x1},'attributes':[_0x0986('0xb'),_0x0986('0xc')],'raw':!![]})[_0x0986('0x14')](function(_0x29a259){_0x20bf1b=_0x29a259;return db[_0x0986('0x3a')][_0x0986('0x1f')]({'where':{'email':_0x52cd5c[_0x0986('0x35')]['email']}});})[_0x0986('0x14')](function(_0x2b5db3){if(!_0x2b5db3){throw new Error(_0x0986('0x3b'));}if(_0x2b5db3[_0x0986('0xf')]){throw new Error(_0x0986('0x3c'));}if(_0x2b5db3[_0x0986('0x10')]){if(moment(_0x2b5db3['blockedAt'])[_0x0986('0x19')](_0x20bf1b[_0x0986('0xc')],_0x0986('0x1a'))>moment()){throw new Error(_0x0986('0x3d'));}else{_0x2b5db3['blocked']=![];_0x2b5db3[_0x0986('0x18')]=null;}}_0x2b5db3[_0x0986('0x3e')]=_0x186a97;_0x2b5db3['resetPasswordExpires']=Date['now']()+0x36ee80;return _0x2b5db3['save']();})[_0x0986('0x14')](function(){return sendServiceMail({'to':_0x52cd5c[_0x0986('0x35')][_0x0986('0x20')],'subject':_0x0986('0x3f'),'text':_0x0986('0x40')+'Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a'+_0x0986('0x41')+_0x52cd5c[_0x0986('0x42')][_0x0986('0x43')]+_0x0986('0x44')+_0x186a97+'\x0a\x0a'+_0x0986('0x45')});})[_0x0986('0x14')](function(){_0x3e2b15['status'](0xc8)[_0x0986('0x2e')]({'message':_0x0986('0x46')});})[_0x0986('0x1d')](function(_0x386dfe){return handleError(_0x3e2b15,0x1f4,_0x386dfe);});};exports[_0x0986('0x47')]=function(_0x344e10,_0x58d1a4){return db['User'][_0x0986('0x1f')]({'where':{'resetPasswordToken':_0x344e10[_0x0986('0x48')][_0x0986('0x49')],'resetPasswordExpires':{'$gt':Date[_0x0986('0x4a')]()}}})[_0x0986('0x14')](function(_0x4ec42c){if(!_0x4ec42c){throw new Error(_0x0986('0x4b'));}return db[_0x0986('0x39')][_0x0986('0xa')]({'attributes':['id',_0x0986('0x4c'),_0x0986('0x4d'),_0x0986('0x4e')]})[_0x0986('0x14')](function(_0x25a3b3){if(_0x25a3b3[_0x0986('0x4c')])authService[_0x0986('0x4f')](_0x344e10[_0x0986('0x35')][_0x0986('0xd')]);if(!_0x25a3b3[_0x0986('0x4d')]||!_0x4ec42c[_0x0986('0x50')])return _0x4ec42c;authService[_0x0986('0x51')](_0x344e10['body'][_0x0986('0xd')],_0x4ec42c[_0x0986('0x50')],_0x25a3b3['passwordHistoryLimit']);return _0x4ec42c;})[_0x0986('0x14')](function(){_0x4ec42c[_0x0986('0xd')]=_0x344e10[_0x0986('0x35')][_0x0986('0xd')];_0x4ec42c[_0x0986('0x3e')]=null;_0x4ec42c[_0x0986('0x52')]=null;return _0x4ec42c[_0x0986('0x53')]();});})[_0x0986('0x14')](function(){_0x58d1a4[_0x0986('0x2d')](0xc8)[_0x0986('0x2e')]({'message':_0x0986('0x54')});})[_0x0986('0x1d')](function(_0x57688f){return handleError(_0x58d1a4,0x1f4,_0x57688f);});};passport['use'](_0x0986('0x30'),new LocalStrategy({'usernameField':_0x0986('0x15'),'passwordField':_0x0986('0xd')},function(_0xc1af0c,_0x45bae8,_0x2002db){return localAuthenticate(db['User'],_0xc1af0c,_0x45bae8,_0x2002db);}));