Built motion from commit 639a1a7f.|2.6.19
[motion2.git] / server / api / authLocal / authLocal.controller.js
index 8585dc9..ae9e2d9 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xd117=['local','Something\x20went\x20wrong,\x20please\x20try\x20again.','role','json','forgot','Email\x20parameter\x20is\x20missing','body','trim','toLowerCase','User','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://','headers','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','reset','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','passwordHistoryLimit','password','previousPasswords','validatePasswordHistory','resetPasswordToken','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','lodash','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','allowedLoginAttempts','blockDuration','then','findOne','salt','blocked','loginAttempts','admin','agent','name','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockedAt','minutes','clearBlockUser','disabled','add','getLicense','catch','find','email','MailServerOut','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','Smtp','service','host','port','authentication','user','pass','merge','format','request','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','error','message','stringify','status','send','login'];(function(_0x1c7c88,_0x5e3dbd){var _0x4ba224=function(_0x377b22){while(--_0x377b22){_0x1c7c88['push'](_0x1c7c88['shift']());}};_0x4ba224(++_0x5e3dbd);}(_0xd117,0x182));var _0x7d11=function(_0x1622a0,_0x2b55a9){_0x1622a0=_0x1622a0-0x0;var _0x2a2308=_0xd117[_0x1622a0];return _0x2a2308;};'use strict';var util=require(_0x7d11('0x0'));var passport=require(_0x7d11('0x1'));var LocalStrategy=require(_0x7d11('0x2'))[_0x7d11('0x3')];var jayson=require(_0x7d11('0x4'));var _=require(_0x7d11('0x5'));var rs=require(_0x7d11('0x6'));var moment=require(_0x7d11('0x7'));var db=require(_0x7d11('0x8'))['db'];var authService=require(_0x7d11('0x9'));var utils=require(_0x7d11('0xa'));var client=jayson[_0x7d11('0xb')][_0x7d11('0xc')]({'port':0x232b});function localAuthenticate(_0x40c3c4,_0x345602,_0x3c8d66,_0x47b5e6){var _0x3803b5,_0xffd020;return db[_0x7d11('0xd')]['findOne']({'where':{'id':0x1},'attributes':[_0x7d11('0xe'),_0x7d11('0xf')],'raw':!![]})[_0x7d11('0x10')](function(_0x4ed7ae){_0x3803b5=_0x4ed7ae;return _0x40c3c4[_0x7d11('0x11')]({'attributes':['id','name','password',_0x7d11('0x12'),'role','disabled',_0x7d11('0x13'),'blockedAt',_0x7d11('0x14')],'where':{'name':_0x345602,'role':{'$or':[_0x7d11('0x15'),'user',_0x7d11('0x16')]}}});})[_0x7d11('0x10')](function(_0x4cda5d){if(!_0x4cda5d||_0x4cda5d&&_0x4cda5d[_0x7d11('0x17')]!==_0x345602){throw new Error(_0x7d11('0x18'));}else{_0xffd020=_0x4cda5d;return _0xffd020;}})[_0x7d11('0x10')](function(){_0xffd020[_0x7d11('0x19')](_0x3c8d66,function(_0x417e2d,_0xeae744){var _0x2a269e=_0xffd020[_0x7d11('0x14')]+0x1;if(_0x417e2d){return _0x47b5e6(_0x417e2d);}else if(!_0xeae744){if(_0xffd020['disabled']){return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});}else if(_0x3803b5[_0x7d11('0xe')]>0x0){if(_0xffd020[_0x7d11('0x13')]){if(_0x3803b5[_0x7d11('0xf')]>0x0){if(moment(_0xffd020[_0x7d11('0x1a')])['add'](_0x3803b5[_0x7d11('0xf')],_0x7d11('0x1b'))>moment()){return _0x47b5e6(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils['clearBlockUser'](_0xffd020,_0x2a269e,![],null)[_0x7d11('0x10')](function(){return _0x47b5e6(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});}}else{if(_0x2a269e>=_0x3803b5['allowedLoginAttempts']){return utils[_0x7d11('0x1c')](_0xffd020,0x0,!![],moment())[_0x7d11('0x10')](function(){return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});});}else{return utils[_0x7d11('0x1c')](_0xffd020,_0x2a269e,![],null)[_0x7d11('0x10')](function(){return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});});}}}else{return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});}}else{if(_0xffd020[_0x7d11('0x1d')]){return _0x47b5e6(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x3803b5[_0x7d11('0xe')]>0x0){if(_0xffd020['blocked']){if(_0x3803b5['blockDuration']>0x0){if(moment(_0xffd020['blockedAt'])[_0x7d11('0x1e')](_0x3803b5[_0x7d11('0xf')],_0x7d11('0x1b'))>moment()){return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});}else{return utils[_0x7d11('0x1c')](_0xffd020,0x0,![],null)[_0x7d11('0x10')](function(){return utils[_0x7d11('0x1f')](_0xffd020);})[_0x7d11('0x10')](function(){return _0x47b5e6(null,_0xffd020);});}}else{return _0x47b5e6(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{return utils[_0x7d11('0x1c')](_0xffd020,0x0,![],null)['then'](function(){return utils['getLicense'](_0xffd020);})['then'](function(){return _0x47b5e6(null,_0xffd020);})[_0x7d11('0x20')](function(_0x59cdba){return _0x47b5e6(null,![],_0x59cdba);});}}else{if(_0xffd020[_0x7d11('0x13')]){return _0x47b5e6(null,![],{'message':_0x7d11('0x18')});}else{return utils[_0x7d11('0x1f')](_0xffd020)['then'](function(){return _0x47b5e6(null,_0xffd020);});}}}});})[_0x7d11('0x20')](function(_0x3bb9b8){return _0x47b5e6(null,![],_0x3bb9b8);});}function sendServiceMail(_0x427200){return db['MailAccount'][_0x7d11('0x21')]({'where':{'service':!![]},'attributes':['id',_0x7d11('0x17'),_0x7d11('0x22')],'include':[{'model':db[_0x7d11('0x23')],'as':'Smtp'}]})[_0x7d11('0x10')](function(_0x512f7f){if(!_0x512f7f){throw new Error(_0x7d11('0x24'));}var _0x509164={'tls':{'rejectUnauthorized':![]}};if(_0x512f7f[_0x7d11('0x25')][_0x7d11('0x26')]){_0x509164[_0x7d11('0x26')]=_0x512f7f['Smtp']['service'];}else{_0x509164[_0x7d11('0x27')]=_0x512f7f[_0x7d11('0x25')]['host'];_0x509164[_0x7d11('0x28')]=_0x512f7f[_0x7d11('0x25')][_0x7d11('0x28')];_0x509164['secure']=_0x512f7f[_0x7d11('0x25')]['secure'];}if(_0x512f7f['Smtp'][_0x7d11('0x29')]){_0x509164['auth']={'user':_0x512f7f[_0x7d11('0x25')][_0x7d11('0x2a')],'pass':_0x512f7f[_0x7d11('0x25')][_0x7d11('0x2b')]};}var _0x4b2500={'account':_0x509164,'message':_[_0x7d11('0x2c')]({'from':util[_0x7d11('0x2d')]('\x22%s\x22\x20<%s>',_0x512f7f['name'],_0x512f7f[_0x7d11('0x22')]||_0x512f7f[_0x7d11('0x25')]['user'])},_0x427200)};return client[_0x7d11('0x2e')]('SendMail',_0x4b2500);})['then'](function(_0x1286d6){if(_0x1286d6['error']){throw new Error(util['format'](_0x7d11('0x2f'),_0x1286d6[_0x7d11('0x30')][_0x7d11('0x31')]||JSON[_0x7d11('0x32')](_0x1286d6[_0x7d11('0x30')])));}return!![];});}function handleError(_0x2ac5df,_0x7c9516,_0x3f8676){return _0x2ac5df[_0x7d11('0x33')](_0x7c9516||0x1f4)[_0x7d11('0x34')]({'message':_0x3f8676?_0x3f8676[_0x7d11('0x31')]||_0x3f8676:''});}exports[_0x7d11('0x35')]=function(_0x5d2305,_0x157731,_0x49d16b){passport[_0x7d11('0x19')](_0x7d11('0x36'),function(_0x36be62,_0xa37410,_0x4f8fd2){var _0xd36cd3=_0x36be62||_0x4f8fd2;if(_0xd36cd3){return handleError(_0x157731,0x191,_0xd36cd3);}if(!_0xa37410){return handleError(_0x157731,0x194,{'message':_0x7d11('0x37')});}else{var _0x19284={'payload':{'id':_0xa37410['id'],'role':_0xa37410[_0x7d11('0x38')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x19284)[_0x7d11('0x10')](function(_0x5ea7ca){_0x157731[_0x7d11('0x39')]({'id':_0xa37410['id'],'token':_0x5ea7ca,'statusCall':'','isAlreadyLogged':_0xa37410['online']});});}})(_0x5d2305,_0x157731,_0x49d16b);};exports[_0x7d11('0x3a')]=function(_0x622725,_0x1b07fa,_0x107255){if(!_0x622725['body']['email']){return handleError(_0x1b07fa,0x1f4,{'message':_0x7d11('0x3b')});}var _0x332243=rs['generate']();_0x622725[_0x7d11('0x3c')][_0x7d11('0x22')]=_0x622725[_0x7d11('0x3c')][_0x7d11('0x22')][_0x7d11('0x3d')]()[_0x7d11('0x3e')]();var _0x47e968;return db[_0x7d11('0xd')]['findOne']({'where':{'id':0x1},'attributes':[_0x7d11('0xe'),_0x7d11('0xf')],'raw':!![]})[_0x7d11('0x10')](function(_0x3c5491){_0x47e968=_0x3c5491;return db[_0x7d11('0x3f')][_0x7d11('0x21')]({'where':{'email':_0x622725['body']['email']}});})['then'](function(_0x30469a){if(!_0x30469a){throw new Error(_0x7d11('0x40'));}if(_0x30469a[_0x7d11('0x1d')]){throw new Error(_0x7d11('0x41'));}if(_0x30469a[_0x7d11('0x13')]){if(moment(_0x30469a['blockedAt'])[_0x7d11('0x1e')](_0x47e968[_0x7d11('0xf')],'minutes')>moment()){throw new Error(_0x7d11('0x42'));}else{_0x30469a[_0x7d11('0x13')]=![];_0x30469a[_0x7d11('0x1a')]=null;}}_0x30469a['resetPasswordToken']=_0x332243;_0x30469a[_0x7d11('0x43')]=Date[_0x7d11('0x44')]()+0x36ee80;return _0x30469a[_0x7d11('0x45')]();})['then'](function(){return sendServiceMail({'to':_0x622725[_0x7d11('0x3c')]['email'],'subject':_0x7d11('0x46'),'text':_0x7d11('0x47')+_0x7d11('0x48')+_0x7d11('0x49')+_0x622725[_0x7d11('0x4a')][_0x7d11('0x27')]+_0x7d11('0x4b')+_0x332243+'\x0a\x0a'+_0x7d11('0x4c')});})[_0x7d11('0x10')](function(){_0x1b07fa['status'](0xc8)['send']({'message':'Reset\x20Email\x20sent!'});})[_0x7d11('0x20')](function(_0x1e5bb5){return handleError(_0x1b07fa,0x1f4,_0x1e5bb5);});};exports[_0x7d11('0x4d')]=function(_0x18ae0e,_0x140acc,_0x1b159d){return db[_0x7d11('0x3f')][_0x7d11('0x21')]({'where':{'resetPasswordToken':_0x18ae0e[_0x7d11('0x4e')][_0x7d11('0x4f')],'resetPasswordExpires':{'$gt':Date[_0x7d11('0x44')]()}}})[_0x7d11('0x10')](function(_0x47e46d){if(!_0x47e46d){throw new Error(_0x7d11('0x50'));}return db[_0x7d11('0xd')][_0x7d11('0x11')]({'attributes':['id','securePassword','enforcePasswordHistory',_0x7d11('0x51')]})[_0x7d11('0x10')](function(_0x218485){if(_0x218485['securePassword'])authService['validatePasswordPattern'](_0x18ae0e[_0x7d11('0x3c')][_0x7d11('0x52')]);if(!_0x218485['enforcePasswordHistory']||!_0x47e46d[_0x7d11('0x53')])return _0x47e46d;authService[_0x7d11('0x54')](_0x18ae0e[_0x7d11('0x3c')][_0x7d11('0x52')],_0x47e46d['previousPasswords'],_0x218485[_0x7d11('0x51')]);return _0x47e46d;})[_0x7d11('0x10')](function(){_0x47e46d[_0x7d11('0x52')]=_0x18ae0e['body']['password'];_0x47e46d[_0x7d11('0x55')]=null;_0x47e46d[_0x7d11('0x43')]=null;return _0x47e46d[_0x7d11('0x45')]();});})[_0x7d11('0x10')](function(){_0x140acc[_0x7d11('0x33')](0xc8)['send']({'message':_0x7d11('0x56')});})[_0x7d11('0x20')](function(_0x2f5d5a){return handleError(_0x140acc,0x1f4,_0x2f5d5a);});};passport[_0x7d11('0x57')](new LocalStrategy({'usernameField':'name','passwordField':'password'},function(_0x46e1db,_0x1958a8,_0x44928d){return localAuthenticate(db[_0x7d11('0x3f')],_0x46e1db,_0x1958a8,_0x44928d);}));
\ No newline at end of file
+var _0x152b=['If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','reset','User','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','password','resetPasswordToken','resetPasswordExpires','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','lodash','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','findOne','allowedLoginAttempts','blockDuration','then','name','blocked','blockedAt','loginAttempts','admin','user','agent','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','disabled','add','minutes','clearBlockUser','getLicense','catch','MailAccount','email','MailServerOut','Smtp','CloudProvider','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','getSmtpOptions','merge','format','\x22%s\x22\x20<%s>','request','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','status','login','authenticate','local-login','Something\x20went\x20wrong,\x20please\x20try\x20again.','role','signToken','json','online','forgot','body','Email\x20parameter\x20is\x20missing','generate','trim','toLowerCase','find','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','now','save','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','host','/reset/'];(function(_0x1d72d6,_0x1517de){var _0x5d7e7b=function(_0xe589d8){while(--_0xe589d8){_0x1d72d6['push'](_0x1d72d6['shift']());}};_0x5d7e7b(++_0x1517de);}(_0x152b,0x109));var _0xb152=function(_0x53a7af,_0x1408a5){_0x53a7af=_0x53a7af-0x0;var _0x3cc7f6=_0x152b[_0x53a7af];return _0x3cc7f6;};'use strict';var util=require(_0xb152('0x0'));var passport=require(_0xb152('0x1'));var LocalStrategy=require(_0xb152('0x2'))[_0xb152('0x3')];var jayson=require(_0xb152('0x4'));var _=require(_0xb152('0x5'));var rs=require('randomstring');var moment=require(_0xb152('0x6'));var db=require(_0xb152('0x7'))['db'];var authService=require(_0xb152('0x8'));var utils=require(_0xb152('0x9'));var client=jayson[_0xb152('0xa')][_0xb152('0xb')]({'port':0x232b});function localAuthenticate(_0x111ce7,_0xdbcdb5,_0x443751,_0x25ec24){var _0xdb8a00,_0x5e114e;return db[_0xb152('0xc')][_0xb152('0xd')]({'where':{'id':0x1},'attributes':[_0xb152('0xe'),_0xb152('0xf')],'raw':!![]})[_0xb152('0x10')](function(_0x47220c){_0xdb8a00=_0x47220c;return _0x111ce7[_0xb152('0xd')]({'attributes':['id',_0xb152('0x11'),'password','salt','role','disabled',_0xb152('0x12'),_0xb152('0x13'),_0xb152('0x14')],'where':{'name':_0xdbcdb5,'role':{'$or':[_0xb152('0x15'),_0xb152('0x16'),_0xb152('0x17')]}}});})[_0xb152('0x10')](function(_0x5a31bf){if(!_0x5a31bf||_0x5a31bf&&_0x5a31bf[_0xb152('0x11')]!==_0xdbcdb5){throw new Error(_0xb152('0x18'));}else{_0x5e114e=_0x5a31bf;return _0x5e114e;}})['then'](function(){_0x5e114e['authenticate'](_0x443751,function(_0x1001ca,_0x299c32){var _0x4646dd=_0x5e114e[_0xb152('0x14')]+0x1;if(_0x1001ca){return _0x25ec24(_0x1001ca);}else if(!_0x299c32){if(_0x5e114e[_0xb152('0x19')]){return _0x25ec24(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0xdb8a00[_0xb152('0xe')]>0x0){if(_0x5e114e['blocked']){if(_0xdb8a00[_0xb152('0xf')]>0x0){if(moment(_0x5e114e[_0xb152('0x13')])[_0xb152('0x1a')](_0xdb8a00[_0xb152('0xf')],_0xb152('0x1b'))>moment()){return _0x25ec24(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xb152('0x1c')](_0x5e114e,_0x4646dd,![],null)[_0xb152('0x10')](function(){return _0x25ec24(null,![],{'message':_0xb152('0x18')});});}}else{return _0x25ec24(null,![],{'message':_0xb152('0x18')});}}else{if(_0x4646dd>=_0xdb8a00[_0xb152('0xe')]){return utils['clearBlockUser'](_0x5e114e,0x0,!![],moment())[_0xb152('0x10')](function(){return _0x25ec24(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}else{return utils['clearBlockUser'](_0x5e114e,_0x4646dd,![],null)['then'](function(){return _0x25ec24(null,![],{'message':_0xb152('0x18')});});}}}else{return _0x25ec24(null,![],{'message':_0xb152('0x18')});}}else{if(_0x5e114e[_0xb152('0x19')]){return _0x25ec24(null,![],{'message':_0xb152('0x18')});}else if(_0xdb8a00['allowedLoginAttempts']>0x0){if(_0x5e114e[_0xb152('0x12')]){if(_0xdb8a00['blockDuration']>0x0){if(moment(_0x5e114e[_0xb152('0x13')])['add'](_0xdb8a00[_0xb152('0xf')],_0xb152('0x1b'))>moment()){return _0x25ec24(null,![],{'message':_0xb152('0x18')});}else{return utils[_0xb152('0x1c')](_0x5e114e,0x0,![],null)[_0xb152('0x10')](function(){return utils[_0xb152('0x1d')](_0x5e114e);})[_0xb152('0x10')](function(){return _0x25ec24(null,_0x5e114e);});}}else{return _0x25ec24(null,![],{'message':_0xb152('0x18')});}}else{return utils[_0xb152('0x1c')](_0x5e114e,0x0,![],null)[_0xb152('0x10')](function(){return utils[_0xb152('0x1d')](_0x5e114e);})[_0xb152('0x10')](function(){return _0x25ec24(null,_0x5e114e);})[_0xb152('0x1e')](function(_0x51f6b2){return _0x25ec24(null,![],_0x51f6b2);});}}else{if(_0x5e114e[_0xb152('0x12')]){return _0x25ec24(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0xb152('0x1d')](_0x5e114e)[_0xb152('0x10')](function(){return _0x25ec24(null,_0x5e114e);});}}}});})[_0xb152('0x1e')](function(_0x53a704){return _0x25ec24(null,![],_0x53a704);});}function sendServiceMail(_0x296f0c){return db[_0xb152('0x1f')]['find']({'where':{'service':!![]},'attributes':['id','name',_0xb152('0x20')],'include':[{'model':db[_0xb152('0x21')],'as':_0xb152('0x22'),'include':[{'model':db['CloudProvider'],'as':_0xb152('0x23')}]}]})['then'](function(_0x4f74e2){if(!_0x4f74e2){throw new Error(_0xb152('0x24'));}var _0x397166=_0x4f74e2[_0xb152('0x25')]();var _0x569ffd={'account':_0x397166,'message':_[_0xb152('0x26')]({'from':util[_0xb152('0x27')](_0xb152('0x28'),_0x4f74e2[_0xb152('0x11')],_0x4f74e2['email']||_0x4f74e2[_0xb152('0x22')]['user'])},_0x296f0c)};return client[_0xb152('0x29')]('SendMail',_0x569ffd);})[_0xb152('0x10')](function(_0x2ac248){if(_0x2ac248[_0xb152('0x2a')]){throw new Error(util[_0xb152('0x27')](_0xb152('0x2b'),_0x2ac248['error'][_0xb152('0x2c')]||JSON['stringify'](_0x2ac248[_0xb152('0x2a')])));}return!![];});}function handleError(_0x413bd2,_0x26831f,_0x386088){return _0x413bd2[_0xb152('0x2d')](_0x26831f||0x1f4)['send']({'message':_0x386088?_0x386088[_0xb152('0x2c')]||_0x386088:''});}exports[_0xb152('0x2e')]=function(_0x237a8d,_0x3ba2ee,_0x42167c){passport[_0xb152('0x2f')](_0xb152('0x30'),function(_0x136c29,_0x126758,_0x5310ec){var _0x26579e=_0x136c29||_0x5310ec;if(_0x26579e){return handleError(_0x3ba2ee,0x191,_0x26579e);}if(!_0x126758){return handleError(_0x3ba2ee,0x194,{'message':_0xb152('0x31')});}else{var _0x32ab8c={'payload':{'id':_0x126758['id'],'role':_0x126758[_0xb152('0x32')]},'options':{'expiresIn':0x15180}};return authService[_0xb152('0x33')](_0x32ab8c)[_0xb152('0x10')](function(_0x256f08){_0x3ba2ee[_0xb152('0x34')]({'id':_0x126758['id'],'token':_0x256f08,'statusCall':'','isAlreadyLogged':_0x126758[_0xb152('0x35')]});});}})(_0x237a8d,_0x3ba2ee,_0x42167c);};exports[_0xb152('0x36')]=function(_0x4a6806,_0x479e7e){if(!_0x4a6806[_0xb152('0x37')][_0xb152('0x20')]){return handleError(_0x479e7e,0x1f4,{'message':_0xb152('0x38')});}var _0x57d836=rs[_0xb152('0x39')]();_0x4a6806['body'][_0xb152('0x20')]=_0x4a6806[_0xb152('0x37')][_0xb152('0x20')][_0xb152('0x3a')]()[_0xb152('0x3b')]();var _0x2c5e90;return db['Setting'][_0xb152('0xd')]({'where':{'id':0x1},'attributes':[_0xb152('0xe'),_0xb152('0xf')],'raw':!![]})['then'](function(_0x3dc09d){_0x2c5e90=_0x3dc09d;return db['User'][_0xb152('0x3c')]({'where':{'email':_0x4a6806['body']['email']}});})['then'](function(_0x4b5344){if(!_0x4b5344){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x4b5344['disabled']){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x4b5344[_0xb152('0x12')]){if(moment(_0x4b5344[_0xb152('0x13')])[_0xb152('0x1a')](_0x2c5e90['blockDuration'],_0xb152('0x1b'))>moment()){throw new Error(_0xb152('0x3d'));}else{_0x4b5344[_0xb152('0x12')]=![];_0x4b5344[_0xb152('0x13')]=null;}}_0x4b5344['resetPasswordToken']=_0x57d836;_0x4b5344['resetPasswordExpires']=Date[_0xb152('0x3e')]()+0x36ee80;return _0x4b5344[_0xb152('0x3f')]();})[_0xb152('0x10')](function(){return sendServiceMail({'to':_0x4a6806[_0xb152('0x37')][_0xb152('0x20')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':'You\x20are\x20receiving\x20this\x20because\x20you\x20(or\x20someone\x20else)\x20have\x20requested\x20the\x20reset\x20of\x20the\x20password\x20for\x20your\x20account.\x0a\x0a'+_0xb152('0x40')+'https://'+_0x4a6806['headers'][_0xb152('0x41')]+_0xb152('0x42')+_0x57d836+'\x0a\x0a'+_0xb152('0x43')});})['then'](function(){_0x479e7e[_0xb152('0x2d')](0xc8)['send']({'message':_0xb152('0x44')});})[_0xb152('0x1e')](function(_0x5d66d6){return handleError(_0x479e7e,0x1f4,_0x5d66d6);});};exports[_0xb152('0x45')]=function(_0x512ac7,_0x3139a9){return db[_0xb152('0x46')]['find']({'where':{'resetPasswordToken':_0x512ac7['params'][_0xb152('0x47')],'resetPasswordExpires':{'$gt':Date['now']()}}})[_0xb152('0x10')](function(_0x358305){if(!_0x358305){throw new Error(_0xb152('0x48'));}return db[_0xb152('0xc')][_0xb152('0xd')]({'attributes':['id',_0xb152('0x49'),_0xb152('0x4a'),_0xb152('0x4b')]})[_0xb152('0x10')](function(_0x4b414a){if(_0x4b414a[_0xb152('0x49')])authService[_0xb152('0x4c')](_0x512ac7[_0xb152('0x37')]['password']);if(!_0x4b414a[_0xb152('0x4a')]||!_0x358305[_0xb152('0x4d')])return _0x358305;authService['validatePasswordHistory'](_0x512ac7['body'][_0xb152('0x4e')],_0x358305[_0xb152('0x4d')],_0x4b414a[_0xb152('0x4b')]);return _0x358305;})[_0xb152('0x10')](function(){_0x358305[_0xb152('0x4e')]=_0x512ac7['body'][_0xb152('0x4e')];_0x358305[_0xb152('0x4f')]=null;_0x358305[_0xb152('0x50')]=null;return _0x358305['save']();});})[_0xb152('0x10')](function(){_0x3139a9['status'](0xc8)['send']({'message':_0xb152('0x51')});})['catch'](function(_0x28f38f){return handleError(_0x3139a9,0x1f4,_0x28f38f);});};passport[_0xb152('0x52')](_0xb152('0x30'),new LocalStrategy({'usernameField':_0xb152('0x11'),'passwordField':'password'},function(_0x6633ff,_0xefc06c,_0x19a1d0){return localAuthenticate(db[_0xb152('0x46')],_0x6633ff,_0xefc06c,_0x19a1d0);}));
\ No newline at end of file