Built motion from commit d1eab355.|2.6.28
[motion2.git] / server / api / authLocal / authLocal.controller.js
index 049cff7..3014035 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x831b=['headers','host','/reset/','Reset\x20Email\x20sent!','reset','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','validatePasswordPattern','password','previousPasswords','passwordHistoryLimit','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','lodash','randomstring','moment','../../mysqldb','client','http','Setting','allowedLoginAttempts','blockDuration','findOne','salt','role','disabled','blocked','blockedAt','loginAttempts','user','agent','then','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','add','minutes','clearBlockUser','getLicense','catch','MailAccount','name','email','MailServerOut','Smtp','CloudProvider','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','merge','format','request','SendMail','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','send','login','authenticate','local-login','signToken','online','body','Email\x20parameter\x20is\x20missing','trim','toLowerCase','User','find','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','now','save','xCally\x20Motion\x20Password\x20Reset','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','https://'];(function(_0x4b369d,_0x265eb8){var _0x571a98=function(_0x56341a){while(--_0x56341a){_0x4b369d['push'](_0x4b369d['shift']());}};_0x571a98(++_0x265eb8);}(_0x831b,0x160));var _0xb831=function(_0x16a5a4,_0x11b08e){_0x16a5a4=_0x16a5a4-0x0;var _0x37c973=_0x831b[_0x16a5a4];return _0x37c973;};'use strict';var util=require(_0xb831('0x0'));var passport=require(_0xb831('0x1'));var LocalStrategy=require(_0xb831('0x2'))[_0xb831('0x3')];var jayson=require(_0xb831('0x4'));var _=require(_0xb831('0x5'));var rs=require(_0xb831('0x6'));var moment=require(_0xb831('0x7'));var db=require(_0xb831('0x8'))['db'];var authService=require('../../components/auth/service');var utils=require('../../config/utils');var client=jayson[_0xb831('0x9')][_0xb831('0xa')]({'port':0x232b});function localAuthenticate(_0x225b47,_0x4a2878,_0x1994ce,_0x1cb198){var _0x2934d4,_0x237d7a;return db[_0xb831('0xb')]['findOne']({'where':{'id':0x1},'attributes':[_0xb831('0xc'),_0xb831('0xd')],'raw':!![]})['then'](function(_0x2b19c6){_0x2934d4=_0x2b19c6;return _0x225b47[_0xb831('0xe')]({'attributes':['id','name','password',_0xb831('0xf'),_0xb831('0x10'),_0xb831('0x11'),_0xb831('0x12'),_0xb831('0x13'),_0xb831('0x14')],'where':{'name':_0x4a2878,'role':{'$or':['admin',_0xb831('0x15'),_0xb831('0x16')]}}});})[_0xb831('0x17')](function(_0x4f96ae){if(!_0x4f96ae||_0x4f96ae&&_0x4f96ae['name']!==_0x4a2878){throw new Error(_0xb831('0x18'));}else{_0x237d7a=_0x4f96ae;return _0x237d7a;}})[_0xb831('0x17')](function(){_0x237d7a['authenticate'](_0x1994ce,function(_0xeb784e,_0x56d666){var _0x546074=_0x237d7a[_0xb831('0x14')]+0x1;if(_0xeb784e){return _0x1cb198(_0xeb784e);}else if(!_0x56d666){if(_0x237d7a[_0xb831('0x11')]){return _0x1cb198(null,![],{'message':_0xb831('0x18')});}else if(_0x2934d4['allowedLoginAttempts']>0x0){if(_0x237d7a[_0xb831('0x12')]){if(_0x2934d4['blockDuration']>0x0){if(moment(_0x237d7a['blockedAt'])[_0xb831('0x19')](_0x2934d4[_0xb831('0xd')],_0xb831('0x1a'))>moment()){return _0x1cb198(null,![],{'message':_0xb831('0x18')});}else{return utils['clearBlockUser'](_0x237d7a,_0x546074,![],null)['then'](function(){return _0x1cb198(null,![],{'message':_0xb831('0x18')});});}}else{return _0x1cb198(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x546074>=_0x2934d4[_0xb831('0xc')]){return utils[_0xb831('0x1b')](_0x237d7a,0x0,!![],moment())[_0xb831('0x17')](function(){return _0x1cb198(null,![],{'message':_0xb831('0x18')});});}else{return utils[_0xb831('0x1b')](_0x237d7a,_0x546074,![],null)['then'](function(){return _0x1cb198(null,![],{'message':_0xb831('0x18')});});}}}else{return _0x1cb198(null,![],{'message':_0xb831('0x18')});}}else{if(_0x237d7a[_0xb831('0x11')]){return _0x1cb198(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x2934d4[_0xb831('0xc')]>0x0){if(_0x237d7a[_0xb831('0x12')]){if(_0x2934d4['blockDuration']>0x0){if(moment(_0x237d7a[_0xb831('0x13')])[_0xb831('0x19')](_0x2934d4[_0xb831('0xd')],_0xb831('0x1a'))>moment()){return _0x1cb198(null,![],{'message':_0xb831('0x18')});}else{return utils[_0xb831('0x1b')](_0x237d7a,0x0,![],null)['then'](function(){return utils['getLicense'](_0x237d7a);})[_0xb831('0x17')](function(){return _0x1cb198(null,_0x237d7a);});}}else{return _0x1cb198(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{return utils['clearBlockUser'](_0x237d7a,0x0,![],null)[_0xb831('0x17')](function(){return utils[_0xb831('0x1c')](_0x237d7a);})['then'](function(){return _0x1cb198(null,_0x237d7a);})[_0xb831('0x1d')](function(_0x4e9dca){return _0x1cb198(null,![],_0x4e9dca);});}}else{if(_0x237d7a['blocked']){return _0x1cb198(null,![],{'message':_0xb831('0x18')});}else{return utils[_0xb831('0x1c')](_0x237d7a)[_0xb831('0x17')](function(){return _0x1cb198(null,_0x237d7a);});}}}});})[_0xb831('0x1d')](function(_0x2e26d4){return _0x1cb198(null,![],_0x2e26d4);});}function sendServiceMail(_0x230e5d){return db[_0xb831('0x1e')]['find']({'where':{'service':!![]},'attributes':['id',_0xb831('0x1f'),_0xb831('0x20')],'include':[{'model':db[_0xb831('0x21')],'as':_0xb831('0x22'),'include':[{'model':db['CloudProvider'],'as':_0xb831('0x23')}]}]})[_0xb831('0x17')](function(_0x349088){if(!_0x349088){throw new Error(_0xb831('0x24'));}var _0x1b9c76=_0x349088['getSmtpOptions']();var _0x52332b={'account':_0x1b9c76,'message':_[_0xb831('0x25')]({'from':util[_0xb831('0x26')]('\x22%s\x22\x20<%s>',_0x349088[_0xb831('0x1f')],_0x349088[_0xb831('0x20')]||_0x349088[_0xb831('0x22')]['user'])},_0x230e5d)};return client[_0xb831('0x27')](_0xb831('0x28'),_0x52332b);})[_0xb831('0x17')](function(_0x3c6dfd){if(_0x3c6dfd[_0xb831('0x29')]){throw new Error(util[_0xb831('0x26')](_0xb831('0x2a'),_0x3c6dfd[_0xb831('0x29')][_0xb831('0x2b')]||JSON[_0xb831('0x2c')](_0x3c6dfd['error'])));}return!![];});}function handleError(_0x4a9c2c,_0x42edd1,_0x1476f8){return _0x4a9c2c[_0xb831('0x2d')](_0x42edd1||0x1f4)[_0xb831('0x2e')]({'message':_0x1476f8?_0x1476f8['message']||_0x1476f8:''});}exports[_0xb831('0x2f')]=function(_0x407557,_0x10f495,_0xe46518){passport[_0xb831('0x30')](_0xb831('0x31'),function(_0x4d98c0,_0x245753,_0x52e700){var _0x373b7b=_0x4d98c0||_0x52e700;if(_0x373b7b){return handleError(_0x10f495,0x191,_0x373b7b);}if(!_0x245753){return handleError(_0x10f495,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x2bd936={'payload':{'id':_0x245753['id'],'role':_0x245753['role']},'options':{'expiresIn':0x15180}};return authService[_0xb831('0x32')](_0x2bd936)[_0xb831('0x17')](function(_0x659f8f){_0x10f495['json']({'id':_0x245753['id'],'token':_0x659f8f,'statusCall':'','isAlreadyLogged':_0x245753[_0xb831('0x33')]});});}})(_0x407557,_0x10f495,_0xe46518);};exports['forgot']=function(_0x1d1dc5,_0x4533b3){if(!_0x1d1dc5[_0xb831('0x34')][_0xb831('0x20')]){return handleError(_0x4533b3,0x1f4,{'message':_0xb831('0x35')});}var _0x2c6d10=rs['generate']();_0x1d1dc5[_0xb831('0x34')][_0xb831('0x20')]=_0x1d1dc5['body'][_0xb831('0x20')][_0xb831('0x36')]()[_0xb831('0x37')]();var _0x347d82;return db[_0xb831('0xb')][_0xb831('0xe')]({'where':{'id':0x1},'attributes':[_0xb831('0xc'),_0xb831('0xd')],'raw':!![]})[_0xb831('0x17')](function(_0x525a96){_0x347d82=_0x525a96;return db[_0xb831('0x38')][_0xb831('0x39')]({'where':{'email':_0x1d1dc5[_0xb831('0x34')][_0xb831('0x20')]}});})[_0xb831('0x17')](function(_0x25b6f6){if(!_0x25b6f6){throw new Error(_0xb831('0x3a'));}if(_0x25b6f6[_0xb831('0x11')]){throw new Error(_0xb831('0x3b'));}if(_0x25b6f6[_0xb831('0x12')]){if(moment(_0x25b6f6['blockedAt'])[_0xb831('0x19')](_0x347d82[_0xb831('0xd')],_0xb831('0x1a'))>moment()){throw new Error(_0xb831('0x3c'));}else{_0x25b6f6[_0xb831('0x12')]=![];_0x25b6f6['blockedAt']=null;}}_0x25b6f6[_0xb831('0x3d')]=_0x2c6d10;_0x25b6f6[_0xb831('0x3e')]=Date[_0xb831('0x3f')]()+0x36ee80;return _0x25b6f6[_0xb831('0x40')]();})[_0xb831('0x17')](function(){return sendServiceMail({'to':_0x1d1dc5['body']['email'],'subject':_0xb831('0x41'),'text':'You\x20are\x20receiving\x20this\x20because\x20you\x20(or\x20someone\x20else)\x20have\x20requested\x20the\x20reset\x20of\x20the\x20password\x20for\x20your\x20account.\x0a\x0a'+_0xb831('0x42')+_0xb831('0x43')+_0x1d1dc5[_0xb831('0x44')][_0xb831('0x45')]+_0xb831('0x46')+_0x2c6d10+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})[_0xb831('0x17')](function(){_0x4533b3[_0xb831('0x2d')](0xc8)[_0xb831('0x2e')]({'message':_0xb831('0x47')});})[_0xb831('0x1d')](function(_0x210596){return handleError(_0x4533b3,0x1f4,_0x210596);});};exports[_0xb831('0x48')]=function(_0x3dcf8e,_0x5537d7){return db[_0xb831('0x38')][_0xb831('0x39')]({'where':{'resetPasswordToken':_0x3dcf8e[_0xb831('0x49')][_0xb831('0x4a')],'resetPasswordExpires':{'$gt':Date[_0xb831('0x3f')]()}}})['then'](function(_0x46996d){if(!_0x46996d){throw new Error(_0xb831('0x4b'));}return db['Setting']['findOne']({'attributes':['id',_0xb831('0x4c'),_0xb831('0x4d'),'passwordHistoryLimit']})[_0xb831('0x17')](function(_0x31a108){if(_0x31a108[_0xb831('0x4c')])authService[_0xb831('0x4e')](_0x3dcf8e[_0xb831('0x34')][_0xb831('0x4f')]);if(!_0x31a108[_0xb831('0x4d')]||!_0x46996d[_0xb831('0x50')])return _0x46996d;authService['validatePasswordHistory'](_0x3dcf8e['body'][_0xb831('0x4f')],_0x46996d['previousPasswords'],_0x31a108[_0xb831('0x51')]);return _0x46996d;})[_0xb831('0x17')](function(){_0x46996d[_0xb831('0x4f')]=_0x3dcf8e['body'][_0xb831('0x4f')];_0x46996d['resetPasswordToken']=null;_0x46996d[_0xb831('0x3e')]=null;return _0x46996d[_0xb831('0x40')]();});})[_0xb831('0x17')](function(){_0x5537d7['status'](0xc8)[_0xb831('0x2e')]({'message':_0xb831('0x52')});})[_0xb831('0x1d')](function(_0x4e3c80){return handleError(_0x5537d7,0x1f4,_0x4e3c80);});};passport[_0xb831('0x53')](_0xb831('0x31'),new LocalStrategy({'usernameField':'name','passwordField':_0xb831('0x4f')},function(_0xd89517,_0x174860,_0x43dc4e){return localAuthenticate(db[_0xb831('0x38')],_0xd89517,_0x174860,_0x43dc4e);}));
\ No newline at end of file
+var _0xc508=['salt','disabled','blocked','loginAttempts','admin','user','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','blockDuration','blockedAt','add','clearBlockUser','allowedLoginAttempts','getLicense','catch','MailAccount','Smtp','CloudProvider','merge','request','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','send','Something\x20went\x20wrong,\x20please\x20try\x20again.','role','json','body','email','toLowerCase','Setting','find','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','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','https://','headers','/reset/','Reset\x20Email\x20sent!','reset','User','params','token','now','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','validatePasswordHistory','use','util','passport','Strategy','jayson/promise','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','findOne','then','name','password'];(function(_0x14c184,_0x5859a3){var _0x12ddad=function(_0x2f0e70){while(--_0x2f0e70){_0x14c184['push'](_0x14c184['shift']());}};_0x12ddad(++_0x5859a3);}(_0xc508,0x1ea));var _0x8c50=function(_0x324f0b,_0x149bbd){_0x324f0b=_0x324f0b-0x0;var _0x5c5c4f=_0xc508[_0x324f0b];return _0x5c5c4f;};'use strict';var util=require(_0x8c50('0x0'));var passport=require(_0x8c50('0x1'));var LocalStrategy=require('passport-local')[_0x8c50('0x2')];var jayson=require(_0x8c50('0x3'));var _=require('lodash');var rs=require('randomstring');var moment=require(_0x8c50('0x4'));var db=require(_0x8c50('0x5'))['db'];var authService=require(_0x8c50('0x6'));var utils=require(_0x8c50('0x7'));var client=jayson[_0x8c50('0x8')][_0x8c50('0x9')]({'port':0x232b});function localAuthenticate(_0x479f85,_0x49813a,_0x335a4b,_0x3a6b99){var _0x39fdfb,_0x571935;return db['Setting'][_0x8c50('0xa')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts','blockDuration'],'raw':!![]})[_0x8c50('0xb')](function(_0x158afe){_0x39fdfb=_0x158afe;return _0x479f85[_0x8c50('0xa')]({'attributes':['id',_0x8c50('0xc'),_0x8c50('0xd'),_0x8c50('0xe'),'role',_0x8c50('0xf'),_0x8c50('0x10'),'blockedAt',_0x8c50('0x11')],'where':{'name':_0x49813a,'role':{'$or':[_0x8c50('0x12'),_0x8c50('0x13'),'agent']}}});})[_0x8c50('0xb')](function(_0x58170f){if(!_0x58170f||_0x58170f&&_0x58170f[_0x8c50('0xc')]!==_0x49813a){throw new Error(_0x8c50('0x14'));}else{_0x571935=_0x58170f;return _0x571935;}})[_0x8c50('0xb')](function(){_0x571935[_0x8c50('0x15')](_0x335a4b,function(_0x3bbd79,_0x25ff5){var _0x29705e=_0x571935[_0x8c50('0x11')]+0x1;if(_0x3bbd79){return _0x3a6b99(_0x3bbd79);}else if(!_0x25ff5){if(_0x571935[_0x8c50('0xf')]){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}else if(_0x39fdfb['allowedLoginAttempts']>0x0){if(_0x571935[_0x8c50('0x10')]){if(_0x39fdfb[_0x8c50('0x16')]>0x0){if(moment(_0x571935[_0x8c50('0x17')])[_0x8c50('0x18')](_0x39fdfb[_0x8c50('0x16')],'minutes')>moment()){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}else{return utils[_0x8c50('0x19')](_0x571935,_0x29705e,![],null)[_0x8c50('0xb')](function(){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});});}}else{return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x29705e>=_0x39fdfb['allowedLoginAttempts']){return utils[_0x8c50('0x19')](_0x571935,0x0,!![],moment())[_0x8c50('0xb')](function(){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});});}else{return utils[_0x8c50('0x19')](_0x571935,_0x29705e,![],null)[_0x8c50('0xb')](function(){return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});});}}}else{return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}}else{if(_0x571935[_0x8c50('0xf')]){return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x39fdfb[_0x8c50('0x1a')]>0x0){if(_0x571935[_0x8c50('0x10')]){if(_0x39fdfb[_0x8c50('0x16')]>0x0){if(moment(_0x571935[_0x8c50('0x17')])['add'](_0x39fdfb[_0x8c50('0x16')],'minutes')>moment()){return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils['clearBlockUser'](_0x571935,0x0,![],null)['then'](function(){return utils[_0x8c50('0x1b')](_0x571935);})[_0x8c50('0xb')](function(){return _0x3a6b99(null,_0x571935);});}}else{return _0x3a6b99(null,![],{'message':_0x8c50('0x14')});}}else{return utils[_0x8c50('0x19')](_0x571935,0x0,![],null)['then'](function(){return utils['getLicense'](_0x571935);})['then'](function(){return _0x3a6b99(null,_0x571935);})[_0x8c50('0x1c')](function(_0x2d52c6){return _0x3a6b99(null,![],_0x2d52c6);});}}else{if(_0x571935[_0x8c50('0x10')]){return _0x3a6b99(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x8c50('0x1b')](_0x571935)[_0x8c50('0xb')](function(){return _0x3a6b99(null,_0x571935);});}}}});})[_0x8c50('0x1c')](function(_0x1430da){return _0x3a6b99(null,![],_0x1430da);});}function sendServiceMail(_0x309974){return db[_0x8c50('0x1d')]['find']({'where':{'service':!![]},'attributes':['id',_0x8c50('0xc'),'email'],'include':[{'model':db['MailServerOut'],'as':_0x8c50('0x1e'),'include':[{'model':db[_0x8c50('0x1f')],'as':_0x8c50('0x1f')}]}]})[_0x8c50('0xb')](function(_0x4fe1d1){if(!_0x4fe1d1){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0xdbf541=_0x4fe1d1['getSmtpOptions']();var _0x14121f={'account':_0xdbf541,'message':_[_0x8c50('0x20')]({'from':util['format']('\x22%s\x22\x20<%s>',_0x4fe1d1[_0x8c50('0xc')],_0x4fe1d1['email']||_0x4fe1d1[_0x8c50('0x1e')][_0x8c50('0x13')])},_0x309974)};return client[_0x8c50('0x21')]('SendMail',_0x14121f);})[_0x8c50('0xb')](function(_0x2c83e6){if(_0x2c83e6[_0x8c50('0x22')]){throw new Error(util['format'](_0x8c50('0x23'),_0x2c83e6[_0x8c50('0x22')][_0x8c50('0x24')]||JSON[_0x8c50('0x25')](_0x2c83e6[_0x8c50('0x22')])));}return!![];});}function handleError(_0x22cdfb,_0x30e090,_0x414e64){return _0x22cdfb[_0x8c50('0x26')](_0x30e090||0x1f4)[_0x8c50('0x27')]({'message':_0x414e64?_0x414e64[_0x8c50('0x24')]||_0x414e64:''});}exports['login']=function(_0xe26566,_0x237fe5,_0x5a095c){passport['authenticate']('local-login',function(_0x260983,_0x386ab0,_0x4ec302){var _0x5e9263=_0x260983||_0x4ec302;if(_0x5e9263){return handleError(_0x237fe5,0x191,_0x5e9263);}if(!_0x386ab0){return handleError(_0x237fe5,0x194,{'message':_0x8c50('0x28')});}else{var _0x33d09a={'payload':{'id':_0x386ab0['id'],'role':_0x386ab0[_0x8c50('0x29')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x33d09a)[_0x8c50('0xb')](function(_0x35f2ad){_0x237fe5[_0x8c50('0x2a')]({'id':_0x386ab0['id'],'token':_0x35f2ad,'statusCall':'','isAlreadyLogged':_0x386ab0['online']});});}})(_0xe26566,_0x237fe5,_0x5a095c);};exports['forgot']=function(_0x402b88,_0x2cd4a8){if(!_0x402b88[_0x8c50('0x2b')]['email']){return handleError(_0x2cd4a8,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x522556=rs['generate']();_0x402b88[_0x8c50('0x2b')][_0x8c50('0x2c')]=_0x402b88[_0x8c50('0x2b')]['email']['trim']()[_0x8c50('0x2d')]();var _0x5f1551;return db[_0x8c50('0x2e')][_0x8c50('0xa')]({'where':{'id':0x1},'attributes':[_0x8c50('0x1a'),'blockDuration'],'raw':!![]})[_0x8c50('0xb')](function(_0x54ad32){_0x5f1551=_0x54ad32;return db['User'][_0x8c50('0x2f')]({'where':{'email':_0x402b88[_0x8c50('0x2b')][_0x8c50('0x2c')]}});})['then'](function(_0x4e6ab0){if(!_0x4e6ab0){throw new Error(_0x8c50('0x30'));}if(_0x4e6ab0[_0x8c50('0xf')]){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x4e6ab0['blocked']){if(moment(_0x4e6ab0[_0x8c50('0x17')])[_0x8c50('0x18')](_0x5f1551[_0x8c50('0x16')],'minutes')>moment()){throw new Error(_0x8c50('0x31'));}else{_0x4e6ab0[_0x8c50('0x10')]=![];_0x4e6ab0[_0x8c50('0x17')]=null;}}_0x4e6ab0[_0x8c50('0x32')]=_0x522556;_0x4e6ab0[_0x8c50('0x33')]=Date['now']()+0x36ee80;return _0x4e6ab0[_0x8c50('0x34')]();})[_0x8c50('0xb')](function(){return sendServiceMail({'to':_0x402b88[_0x8c50('0x2b')][_0x8c50('0x2c')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0x8c50('0x35')+_0x8c50('0x36')+_0x8c50('0x37')+_0x402b88[_0x8c50('0x38')]['host']+_0x8c50('0x39')+_0x522556+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})[_0x8c50('0xb')](function(){_0x2cd4a8['status'](0xc8)[_0x8c50('0x27')]({'message':_0x8c50('0x3a')});})['catch'](function(_0x41fb66){return handleError(_0x2cd4a8,0x1f4,_0x41fb66);});};exports[_0x8c50('0x3b')]=function(_0x446369,_0x1d2078){return db[_0x8c50('0x3c')][_0x8c50('0x2f')]({'where':{'resetPasswordToken':_0x446369[_0x8c50('0x3d')][_0x8c50('0x3e')],'resetPasswordExpires':{'$gt':Date[_0x8c50('0x3f')]()}}})[_0x8c50('0xb')](function(_0x58d982){if(!_0x58d982){throw new Error(_0x8c50('0x40'));}return db['Setting'][_0x8c50('0xa')]({'attributes':['id',_0x8c50('0x41'),_0x8c50('0x42'),_0x8c50('0x43')]})[_0x8c50('0xb')](function(_0x32b792){if(_0x32b792[_0x8c50('0x41')])authService[_0x8c50('0x44')](_0x446369['body'][_0x8c50('0xd')]);if(!_0x32b792['enforcePasswordHistory']||!_0x58d982[_0x8c50('0x45')])return _0x58d982;authService[_0x8c50('0x46')](_0x446369['body']['password'],_0x58d982['previousPasswords'],_0x32b792['passwordHistoryLimit']);return _0x58d982;})[_0x8c50('0xb')](function(){_0x58d982[_0x8c50('0xd')]=_0x446369['body'][_0x8c50('0xd')];_0x58d982['resetPasswordToken']=null;_0x58d982[_0x8c50('0x33')]=null;return _0x58d982[_0x8c50('0x34')]();});})[_0x8c50('0xb')](function(){_0x1d2078['status'](0xc8)[_0x8c50('0x27')]({'message':'Password\x20reset!'});})[_0x8c50('0x1c')](function(_0x73851a){return handleError(_0x1d2078,0x1f4,_0x73851a);});};passport[_0x8c50('0x47')]('local-login',new LocalStrategy({'usernameField':_0x8c50('0xc'),'passwordField':_0x8c50('0xd')},function(_0x1690da,_0x109d2b,_0x47f5d6){return localAuthenticate(db['User'],_0x1690da,_0x109d2b,_0x47f5d6);}));
\ No newline at end of file