Built motion from commit (unavailable).|2.5.15
[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 _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);}));