Built motion from commit (unavailable).|2.5.4
[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 _0x83ed=['User','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','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','headers','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','use','util','passport-local','Strategy','jayson/promise','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','findOne','allowedLoginAttempts','then','password','salt','disabled','blocked','blockedAt','admin','user','agent','name','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','loginAttempts','blockDuration','add','clearBlockUser','minutes','getLicense','catch','find','email','MailServerOut','Smtp','service','host','port','secure','authentication','auth','pass','merge','\x22%s\x22\x20<%s>','request','SendMail','error','message','stringify','status','send','login','local','Something\x20went\x20wrong,\x20please\x20try\x20again.','role','signToken','online','body','Email\x20parameter\x20is\x20missing','generate','trim','toLowerCase'];(function(_0x2f6819,_0x42c3ff){var _0x5d167f=function(_0x36378f){while(--_0x36378f){_0x2f6819['push'](_0x2f6819['shift']());}};_0x5d167f(++_0x42c3ff);}(_0x83ed,0x66));var _0xd83e=function(_0x4baae2,_0x487ab6){_0x4baae2=_0x4baae2-0x0;var _0x1a2285=_0x83ed[_0x4baae2];return _0x1a2285;};'use strict';var util=require(_0xd83e('0x0'));var passport=require('passport');var LocalStrategy=require(_0xd83e('0x1'))[_0xd83e('0x2')];var jayson=require(_0xd83e('0x3'));var _=require('lodash');var rs=require(_0xd83e('0x4'));var moment=require(_0xd83e('0x5'));var db=require(_0xd83e('0x6'))['db'];var authService=require(_0xd83e('0x7'));var utils=require(_0xd83e('0x8'));var client=jayson[_0xd83e('0x9')][_0xd83e('0xa')]({'port':0x232b});function localAuthenticate(_0x3285f8,_0x9c6ae,_0x542197,_0x384d0d){var _0x30f141,_0x47d268;return db[_0xd83e('0xb')][_0xd83e('0xc')]({'where':{'id':0x1},'attributes':[_0xd83e('0xd'),'blockDuration'],'raw':!![]})[_0xd83e('0xe')](function(_0x594ee2){_0x30f141=_0x594ee2;return _0x3285f8[_0xd83e('0xc')]({'attributes':['id','name',_0xd83e('0xf'),_0xd83e('0x10'),'role',_0xd83e('0x11'),_0xd83e('0x12'),_0xd83e('0x13'),'loginAttempts'],'where':{'name':_0x9c6ae,'role':{'$or':[_0xd83e('0x14'),_0xd83e('0x15'),_0xd83e('0x16')]}}});})[_0xd83e('0xe')](function(_0x131938){if(!_0x131938||_0x131938&&_0x131938[_0xd83e('0x17')]!==_0x9c6ae){throw new Error(_0xd83e('0x18'));}else{_0x47d268=_0x131938;return _0x47d268;}})[_0xd83e('0xe')](function(){_0x47d268[_0xd83e('0x19')](_0x542197,function(_0x301767,_0x4129c5){var _0x41d742=_0x47d268[_0xd83e('0x1a')]+0x1;if(_0x301767){return _0x384d0d(_0x301767);}else if(!_0x4129c5){if(_0x47d268['disabled']){return _0x384d0d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x30f141[_0xd83e('0xd')]>0x0){if(_0x47d268['blocked']){if(_0x30f141[_0xd83e('0x1b')]>0x0){if(moment(_0x47d268['blockedAt'])[_0xd83e('0x1c')](_0x30f141[_0xd83e('0x1b')],'minutes')>moment()){return _0x384d0d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xd83e('0x1d')](_0x47d268,_0x41d742,![],null)[_0xd83e('0xe')](function(){return _0x384d0d(null,![],{'message':_0xd83e('0x18')});});}}else{return _0x384d0d(null,![],{'message':_0xd83e('0x18')});}}else{if(_0x41d742>=_0x30f141[_0xd83e('0xd')]){return utils[_0xd83e('0x1d')](_0x47d268,0x0,!![],moment())[_0xd83e('0xe')](function(){return _0x384d0d(null,![],{'message':_0xd83e('0x18')});});}else{return utils[_0xd83e('0x1d')](_0x47d268,_0x41d742,![],null)['then'](function(){return _0x384d0d(null,![],{'message':_0xd83e('0x18')});});}}}else{return _0x384d0d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x47d268[_0xd83e('0x11')]){return _0x384d0d(null,![],{'message':_0xd83e('0x18')});}else if(_0x30f141['allowedLoginAttempts']>0x0){if(_0x47d268[_0xd83e('0x12')]){if(_0x30f141[_0xd83e('0x1b')]>0x0){if(moment(_0x47d268[_0xd83e('0x13')])[_0xd83e('0x1c')](_0x30f141[_0xd83e('0x1b')],_0xd83e('0x1e'))>moment()){return _0x384d0d(null,![],{'message':_0xd83e('0x18')});}else{return utils[_0xd83e('0x1d')](_0x47d268,0x0,![],null)['then'](function(){return utils['getLicense'](_0x47d268);})['then'](function(){return _0x384d0d(null,_0x47d268);});}}else{return _0x384d0d(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{return utils[_0xd83e('0x1d')](_0x47d268,0x0,![],null)[_0xd83e('0xe')](function(){return utils[_0xd83e('0x1f')](_0x47d268);})[_0xd83e('0xe')](function(){return _0x384d0d(null,_0x47d268);})[_0xd83e('0x20')](function(_0x2bc6f8){return _0x384d0d(null,![],_0x2bc6f8);});}}else{if(_0x47d268[_0xd83e('0x12')]){return _0x384d0d(null,![],{'message':_0xd83e('0x18')});}else{return utils[_0xd83e('0x1f')](_0x47d268)[_0xd83e('0xe')](function(){return _0x384d0d(null,_0x47d268);});}}}});})[_0xd83e('0x20')](function(_0x1176f4){return _0x384d0d(null,![],_0x1176f4);});}function sendServiceMail(_0x40e2d2){return db['MailAccount'][_0xd83e('0x21')]({'where':{'service':!![]},'attributes':['id',_0xd83e('0x17'),_0xd83e('0x22')],'include':[{'model':db[_0xd83e('0x23')],'as':'Smtp'}]})[_0xd83e('0xe')](function(_0x51c1dc){if(!_0x51c1dc){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x52a207={'tls':{'rejectUnauthorized':![]}};if(_0x51c1dc[_0xd83e('0x24')][_0xd83e('0x25')]){_0x52a207[_0xd83e('0x25')]=_0x51c1dc[_0xd83e('0x24')]['service'];}else{_0x52a207['host']=_0x51c1dc[_0xd83e('0x24')][_0xd83e('0x26')];_0x52a207[_0xd83e('0x27')]=_0x51c1dc[_0xd83e('0x24')]['port'];_0x52a207[_0xd83e('0x28')]=_0x51c1dc[_0xd83e('0x24')][_0xd83e('0x28')];}if(_0x51c1dc[_0xd83e('0x24')][_0xd83e('0x29')]){_0x52a207[_0xd83e('0x2a')]={'user':_0x51c1dc[_0xd83e('0x24')][_0xd83e('0x15')],'pass':_0x51c1dc['Smtp'][_0xd83e('0x2b')]};}var _0x59faa1={'account':_0x52a207,'message':_[_0xd83e('0x2c')]({'from':util['format'](_0xd83e('0x2d'),_0x51c1dc[_0xd83e('0x17')],_0x51c1dc[_0xd83e('0x22')]||_0x51c1dc[_0xd83e('0x24')][_0xd83e('0x15')])},_0x40e2d2)};return client[_0xd83e('0x2e')](_0xd83e('0x2f'),_0x59faa1);})[_0xd83e('0xe')](function(_0xef82e8){if(_0xef82e8[_0xd83e('0x30')]){throw new Error(util['format']('SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!',_0xef82e8[_0xd83e('0x30')][_0xd83e('0x31')]||JSON[_0xd83e('0x32')](_0xef82e8[_0xd83e('0x30')])));}return!![];});}function handleError(_0x5e4711,_0x59b435,_0x49c969){return _0x5e4711[_0xd83e('0x33')](_0x59b435||0x1f4)[_0xd83e('0x34')]({'message':_0x49c969?_0x49c969['message']||_0x49c969:''});}function checkPasswordPattern(_0x394cab,_0x1e4dcf,_0x281f4f){if(_0x281f4f){var _0x1fcd6b=new RegExp(/(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[?!@#\$%\^&\*~\-_=+[{\]\}])(?=.{8,})/);if(_0x1fcd6b['test'](_0x1e4dcf)){return _0x394cab;}else{throw new Error('The\x20password\x20must\x20be\x20at\x20least\x208\x20characters\x20long\x20and\x20have\x201\x20lowercase\x20character,\x201\x20uppercase\x20character,\x201\x20number\x20and\x201\x20special\x20character\x20~!@#$%^&-_=+[{]}.');}}else{return _0x394cab;}}exports[_0xd83e('0x35')]=function(_0x259888,_0x204ea0,_0x21956b){passport[_0xd83e('0x19')](_0xd83e('0x36'),function(_0x3a4351,_0x2fec68,_0x4200a8){var _0x127934=_0x3a4351||_0x4200a8;if(_0x127934){return handleError(_0x204ea0,0x191,_0x127934);}if(!_0x2fec68){return handleError(_0x204ea0,0x194,{'message':_0xd83e('0x37')});}else{var _0xec7d54={'payload':{'id':_0x2fec68['id'],'role':_0x2fec68[_0xd83e('0x38')]},'options':{'expiresIn':0x15180}};return authService[_0xd83e('0x39')](_0xec7d54)[_0xd83e('0xe')](function(_0x26355b){_0x204ea0['json']({'id':_0x2fec68['id'],'token':_0x26355b,'statusCall':'','isAlreadyLogged':_0x2fec68[_0xd83e('0x3a')]});});}})(_0x259888,_0x204ea0,_0x21956b);};exports['forgot']=function(_0x5cfef0,_0x45879a,_0x49a24c){if(!_0x5cfef0[_0xd83e('0x3b')][_0xd83e('0x22')]){return handleError(_0x45879a,0x1f4,{'message':_0xd83e('0x3c')});}var _0x10a6d3=rs[_0xd83e('0x3d')]();_0x5cfef0[_0xd83e('0x3b')][_0xd83e('0x22')]=_0x5cfef0[_0xd83e('0x3b')][_0xd83e('0x22')][_0xd83e('0x3e')]()[_0xd83e('0x3f')]();var _0x1b1dd8;return db[_0xd83e('0xb')][_0xd83e('0xc')]({'where':{'id':0x1},'attributes':[_0xd83e('0xd'),'blockDuration'],'raw':!![]})['then'](function(_0x1bb9fd){_0x1b1dd8=_0x1bb9fd;return db[_0xd83e('0x40')][_0xd83e('0x21')]({'where':{'email':_0x5cfef0['body']['email']}});})[_0xd83e('0xe')](function(_0x14ff0b){if(!_0x14ff0b){throw new Error(_0xd83e('0x41'));}if(_0x14ff0b['disabled']){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x14ff0b[_0xd83e('0x12')]){if(moment(_0x14ff0b[_0xd83e('0x13')])['add'](_0x1b1dd8['blockDuration'],_0xd83e('0x1e'))>moment()){throw new Error(_0xd83e('0x42'));}else{_0x14ff0b['blocked']=![];_0x14ff0b['blockedAt']=null;}}_0x14ff0b[_0xd83e('0x43')]=_0x10a6d3;_0x14ff0b[_0xd83e('0x44')]=Date[_0xd83e('0x45')]()+0x36ee80;return _0x14ff0b[_0xd83e('0x46')]();})[_0xd83e('0xe')](function(){return sendServiceMail({'to':_0x5cfef0[_0xd83e('0x3b')][_0xd83e('0x22')],'subject':_0xd83e('0x47'),'text':_0xd83e('0x48')+_0xd83e('0x49')+'http://'+_0x5cfef0[_0xd83e('0x4a')][_0xd83e('0x26')]+'/reset/'+_0x10a6d3+'\x0a\x0a'+_0xd83e('0x4b')});})[_0xd83e('0xe')](function(){_0x45879a[_0xd83e('0x33')](0xc8)[_0xd83e('0x34')]({'message':_0xd83e('0x4c')});})[_0xd83e('0x20')](function(_0x1bedde){return handleError(_0x45879a,0x1f4,_0x1bedde);});};exports[_0xd83e('0x4d')]=function(_0x532bfe,_0x463223,_0x5561ea){var _0x556c0b;return db[_0xd83e('0x40')][_0xd83e('0x21')]({'where':{'resetPasswordToken':_0x532bfe[_0xd83e('0x4e')][_0xd83e('0x4f')],'resetPasswordExpires':{'$gt':Date[_0xd83e('0x45')]()}}})[_0xd83e('0xe')](function(_0x544beb){_0x556c0b=_0x544beb;if(!_0x556c0b){throw new Error(_0xd83e('0x50'));}return db[_0xd83e('0xb')][_0xd83e('0xc')]({'attributes':['id',_0xd83e('0x51')]});})[_0xd83e('0xe')](function(_0x5b9731){return checkPasswordPattern(_0x5b9731,_0x532bfe[_0xd83e('0x3b')][_0xd83e('0xf')],_0x5b9731[_0xd83e('0x51')]);})[_0xd83e('0xe')](function(){_0x556c0b[_0xd83e('0xf')]=_0x532bfe['body']['password'];_0x556c0b[_0xd83e('0x43')]=null;_0x556c0b['resetPasswordExpires']=null;return _0x556c0b[_0xd83e('0x46')]();})['then'](function(){_0x463223[_0xd83e('0x33')](0xc8)[_0xd83e('0x34')]({'message':'Password\x20reset!'});})[_0xd83e('0x20')](function(_0x438831){return handleError(_0x463223,0x1f4,_0x438831);});};passport[_0xd83e('0x52')](new LocalStrategy({'usernameField':_0xd83e('0x17'),'passwordField':_0xd83e('0xf')},function(_0x32f09e,_0x4829f3,_0x35f734){return localAuthenticate(db['User'],_0x32f09e,_0x4829f3,_0x35f734);}));