6c2fc78bd7f2a441a9b2d5a281c83963f490ebe4
[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 _0xba10=['Something\x20went\x20wrong,\x20please\x20try\x20again.','json','online','body','Email\x20parameter\x20is\x20missing','generate','trim','toLowerCase','User','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','resetPasswordExpires','now','save','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!','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','enforcePasswordHistory','passwordHistoryLimit','securePassword','previousPasswords','validatePasswordHistory','Password\x20reset!','use','passport','passport-local','Strategy','lodash','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','findOne','blockDuration','then','name','password','salt','role','disabled','blocked','blockedAt','admin','user','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','loginAttempts','allowedLoginAttempts','add','minutes','clearBlockUser','getLicense','catch','find','email','MailServerOut','Smtp','CloudProvider','getSmtpOptions','merge','\x22%s\x22\x20<%s>','request','SendMail','error','format','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','status','send','login','local-login'];(function(_0x2b6793,_0x5aa576){var _0x314d0d=function(_0x3cbf54){while(--_0x3cbf54){_0x2b6793['push'](_0x2b6793['shift']());}};_0x314d0d(++_0x5aa576);}(_0xba10,0xc8));var _0x0ba1=function(_0x200733,_0xfe1ffb){_0x200733=_0x200733-0x0;var _0xb926be=_0xba10[_0x200733];return _0xb926be;};'use strict';var util=require('util');var passport=require(_0x0ba1('0x0'));var LocalStrategy=require(_0x0ba1('0x1'))[_0x0ba1('0x2')];var jayson=require('jayson/promise');var _=require(_0x0ba1('0x3'));var rs=require(_0x0ba1('0x4'));var moment=require(_0x0ba1('0x5'));var db=require(_0x0ba1('0x6'))['db'];var authService=require(_0x0ba1('0x7'));var utils=require(_0x0ba1('0x8'));var client=jayson[_0x0ba1('0x9')][_0x0ba1('0xa')]({'port':0x232b});function localAuthenticate(_0x552444,_0x46d1ba,_0x17e51e,_0x16cd19){var _0x315e47,_0x343d62;return db[_0x0ba1('0xb')][_0x0ba1('0xc')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts',_0x0ba1('0xd')],'raw':!![]})[_0x0ba1('0xe')](function(_0x16e8ad){_0x315e47=_0x16e8ad;return _0x552444[_0x0ba1('0xc')]({'attributes':['id',_0x0ba1('0xf'),_0x0ba1('0x10'),_0x0ba1('0x11'),_0x0ba1('0x12'),_0x0ba1('0x13'),_0x0ba1('0x14'),_0x0ba1('0x15'),'loginAttempts'],'where':{'name':_0x46d1ba,'role':{'$or':[_0x0ba1('0x16'),_0x0ba1('0x17'),'agent']}}});})[_0x0ba1('0xe')](function(_0x2ff8fc){if(!_0x2ff8fc||_0x2ff8fc&&_0x2ff8fc[_0x0ba1('0xf')]!==_0x46d1ba){throw new Error(_0x0ba1('0x18'));}else{_0x343d62=_0x2ff8fc;return _0x343d62;}})[_0x0ba1('0xe')](function(){_0x343d62[_0x0ba1('0x19')](_0x17e51e,function(_0x743264,_0x1a29b8){var _0x4cc551=_0x343d62[_0x0ba1('0x1a')]+0x1;if(_0x743264){return _0x16cd19(_0x743264);}else if(!_0x1a29b8){if(_0x343d62['disabled']){return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}else if(_0x315e47[_0x0ba1('0x1b')]>0x0){if(_0x343d62['blocked']){if(_0x315e47[_0x0ba1('0xd')]>0x0){if(moment(_0x343d62['blockedAt'])[_0x0ba1('0x1c')](_0x315e47[_0x0ba1('0xd')],_0x0ba1('0x1d'))>moment()){return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}else{return utils[_0x0ba1('0x1e')](_0x343d62,_0x4cc551,![],null)[_0x0ba1('0xe')](function(){return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});});}}else{return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}}else{if(_0x4cc551>=_0x315e47[_0x0ba1('0x1b')]){return utils[_0x0ba1('0x1e')](_0x343d62,0x0,!![],moment())[_0x0ba1('0xe')](function(){return _0x16cd19(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}else{return utils['clearBlockUser'](_0x343d62,_0x4cc551,![],null)[_0x0ba1('0xe')](function(){return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});});}}}else{return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}}else{if(_0x343d62[_0x0ba1('0x13')]){return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}else if(_0x315e47[_0x0ba1('0x1b')]>0x0){if(_0x343d62[_0x0ba1('0x14')]){if(_0x315e47[_0x0ba1('0xd')]>0x0){if(moment(_0x343d62[_0x0ba1('0x15')])['add'](_0x315e47[_0x0ba1('0xd')],_0x0ba1('0x1d'))>moment()){return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}else{return utils[_0x0ba1('0x1e')](_0x343d62,0x0,![],null)['then'](function(){return utils[_0x0ba1('0x1f')](_0x343d62);})[_0x0ba1('0xe')](function(){return _0x16cd19(null,_0x343d62);});}}else{return _0x16cd19(null,![],{'message':_0x0ba1('0x18')});}}else{return utils['clearBlockUser'](_0x343d62,0x0,![],null)['then'](function(){return utils[_0x0ba1('0x1f')](_0x343d62);})[_0x0ba1('0xe')](function(){return _0x16cd19(null,_0x343d62);})[_0x0ba1('0x20')](function(_0x2c9b3a){return _0x16cd19(null,![],_0x2c9b3a);});}}else{if(_0x343d62[_0x0ba1('0x14')]){return _0x16cd19(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x0ba1('0x1f')](_0x343d62)[_0x0ba1('0xe')](function(){return _0x16cd19(null,_0x343d62);});}}}});})[_0x0ba1('0x20')](function(_0x523ac2){return _0x16cd19(null,![],_0x523ac2);});}function sendServiceMail(_0xd66399){return db['MailAccount'][_0x0ba1('0x21')]({'where':{'service':!![]},'attributes':['id',_0x0ba1('0xf'),_0x0ba1('0x22')],'include':[{'model':db[_0x0ba1('0x23')],'as':_0x0ba1('0x24'),'include':[{'model':db[_0x0ba1('0x25')],'as':_0x0ba1('0x25')}]}]})[_0x0ba1('0xe')](function(_0x1ea6eb){if(!_0x1ea6eb){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x24db66=_0x1ea6eb[_0x0ba1('0x26')]();var _0x3424a5={'account':_0x24db66,'message':_[_0x0ba1('0x27')]({'from':util['format'](_0x0ba1('0x28'),_0x1ea6eb['name'],_0x1ea6eb[_0x0ba1('0x22')]||_0x1ea6eb[_0x0ba1('0x24')]['user'])},_0xd66399)};return client[_0x0ba1('0x29')](_0x0ba1('0x2a'),_0x3424a5);})[_0x0ba1('0xe')](function(_0x4b5d1e){if(_0x4b5d1e[_0x0ba1('0x2b')]){throw new Error(util[_0x0ba1('0x2c')](_0x0ba1('0x2d'),_0x4b5d1e[_0x0ba1('0x2b')][_0x0ba1('0x2e')]||JSON[_0x0ba1('0x2f')](_0x4b5d1e['error'])));}return!![];});}function handleError(_0x5c7923,_0x1de1c0,_0x4e7c0e){return _0x5c7923[_0x0ba1('0x30')](_0x1de1c0||0x1f4)[_0x0ba1('0x31')]({'message':_0x4e7c0e?_0x4e7c0e[_0x0ba1('0x2e')]||_0x4e7c0e:''});}exports[_0x0ba1('0x32')]=function(_0x3bd497,_0x2b2092,_0x48c6db){passport[_0x0ba1('0x19')](_0x0ba1('0x33'),function(_0x30d170,_0x5e139e,_0x47380e){var _0x4e0d09=_0x30d170||_0x47380e;if(_0x4e0d09){return handleError(_0x2b2092,0x191,_0x4e0d09);}if(!_0x5e139e){return handleError(_0x2b2092,0x194,{'message':_0x0ba1('0x34')});}else{var _0x34e495={'payload':{'id':_0x5e139e['id'],'role':_0x5e139e['role']},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x34e495)[_0x0ba1('0xe')](function(_0x4fd45a){_0x2b2092[_0x0ba1('0x35')]({'id':_0x5e139e['id'],'token':_0x4fd45a,'statusCall':'','isAlreadyLogged':_0x5e139e[_0x0ba1('0x36')]});});}})(_0x3bd497,_0x2b2092,_0x48c6db);};exports['forgot']=function(_0x43776e,_0x288da0){if(!_0x43776e[_0x0ba1('0x37')][_0x0ba1('0x22')]){return handleError(_0x288da0,0x1f4,{'message':_0x0ba1('0x38')});}var _0xc24b28=rs[_0x0ba1('0x39')]();_0x43776e[_0x0ba1('0x37')][_0x0ba1('0x22')]=_0x43776e[_0x0ba1('0x37')][_0x0ba1('0x22')][_0x0ba1('0x3a')]()[_0x0ba1('0x3b')]();var _0x3c5e67;return db[_0x0ba1('0xb')][_0x0ba1('0xc')]({'where':{'id':0x1},'attributes':[_0x0ba1('0x1b'),'blockDuration'],'raw':!![]})[_0x0ba1('0xe')](function(_0x14426a){_0x3c5e67=_0x14426a;return db[_0x0ba1('0x3c')][_0x0ba1('0x21')]({'where':{'email':_0x43776e[_0x0ba1('0x37')][_0x0ba1('0x22')]}});})[_0x0ba1('0xe')](function(_0xa78e71){if(!_0xa78e71){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0xa78e71[_0x0ba1('0x13')]){throw new Error(_0x0ba1('0x3d'));}if(_0xa78e71[_0x0ba1('0x14')]){if(moment(_0xa78e71[_0x0ba1('0x15')])[_0x0ba1('0x1c')](_0x3c5e67[_0x0ba1('0xd')],_0x0ba1('0x1d'))>moment()){throw new Error(_0x0ba1('0x3e'));}else{_0xa78e71['blocked']=![];_0xa78e71[_0x0ba1('0x15')]=null;}}_0xa78e71[_0x0ba1('0x3f')]=_0xc24b28;_0xa78e71[_0x0ba1('0x40')]=Date[_0x0ba1('0x41')]()+0x36ee80;return _0xa78e71[_0x0ba1('0x42')]();})[_0x0ba1('0xe')](function(){return sendServiceMail({'to':_0x43776e[_0x0ba1('0x37')]['email'],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0x0ba1('0x43')+'Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a'+_0x0ba1('0x44')+_0x43776e[_0x0ba1('0x45')][_0x0ba1('0x46')]+_0x0ba1('0x47')+_0xc24b28+'\x0a\x0a'+_0x0ba1('0x48')});})[_0x0ba1('0xe')](function(){_0x288da0['status'](0xc8)[_0x0ba1('0x31')]({'message':_0x0ba1('0x49')});})[_0x0ba1('0x20')](function(_0x4ed000){return handleError(_0x288da0,0x1f4,_0x4ed000);});};exports['reset']=function(_0xbb235f,_0x20f76d){return db['User'][_0x0ba1('0x21')]({'where':{'resetPasswordToken':_0xbb235f[_0x0ba1('0x4a')][_0x0ba1('0x4b')],'resetPasswordExpires':{'$gt':Date[_0x0ba1('0x41')]()}}})[_0x0ba1('0xe')](function(_0x4a40bc){if(!_0x4a40bc){throw new Error(_0x0ba1('0x4c'));}return db[_0x0ba1('0xb')][_0x0ba1('0xc')]({'attributes':['id','securePassword',_0x0ba1('0x4d'),_0x0ba1('0x4e')]})[_0x0ba1('0xe')](function(_0x3cd22f){if(_0x3cd22f[_0x0ba1('0x4f')])authService['validatePasswordPattern'](_0xbb235f[_0x0ba1('0x37')][_0x0ba1('0x10')]);if(!_0x3cd22f[_0x0ba1('0x4d')]||!_0x4a40bc[_0x0ba1('0x50')])return _0x4a40bc;authService[_0x0ba1('0x51')](_0xbb235f[_0x0ba1('0x37')][_0x0ba1('0x10')],_0x4a40bc[_0x0ba1('0x50')],_0x3cd22f[_0x0ba1('0x4e')]);return _0x4a40bc;})[_0x0ba1('0xe')](function(){_0x4a40bc[_0x0ba1('0x10')]=_0xbb235f[_0x0ba1('0x37')][_0x0ba1('0x10')];_0x4a40bc[_0x0ba1('0x3f')]=null;_0x4a40bc[_0x0ba1('0x40')]=null;return _0x4a40bc[_0x0ba1('0x42')]();});})[_0x0ba1('0xe')](function(){_0x20f76d['status'](0xc8)[_0x0ba1('0x31')]({'message':_0x0ba1('0x52')});})[_0x0ba1('0x20')](function(_0x17dde1){return handleError(_0x20f76d,0x1f4,_0x17dde1);});};passport[_0x0ba1('0x53')](_0x0ba1('0x33'),new LocalStrategy({'usernameField':'name','passwordField':_0x0ba1('0x10')},function(_0x2760ee,_0x553e4a,_0x17ce67){return localAuthenticate(db[_0x0ba1('0x3c')],_0x2760ee,_0x553e4a,_0x17ce67);}));