Built motion from commit 10af8726.|2.6.34
[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 _0xc6b2=['\x22%s\x22\x20<%s>','Smtp','request','SendMail','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','status','authenticate','local-login','role','json','forgot','body','Email\x20parameter\x20is\x20missing','generate','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','Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a','https://','headers','host','/reset/','send','Reset\x20Email\x20sent!','reset','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','Setting','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','previousPasswords','validatePasswordHistory','Password\x20reset!','passport','Strategy','lodash','randomstring','../../mysqldb','client','http','allowedLoginAttempts','then','findOne','name','password','salt','disabled','blocked','blockedAt','admin','user','agent','loginAttempts','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','blockDuration','add','minutes','clearBlockUser','getLicense','catch','MailAccount','find','email','MailServerOut','CloudProvider','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','getSmtpOptions','merge','format'];(function(_0x4e6738,_0x35ff59){var _0x4eb631=function(_0x575e18){while(--_0x575e18){_0x4e6738['push'](_0x4e6738['shift']());}};_0x4eb631(++_0x35ff59);}(_0xc6b2,0xcc));var _0x2c6b=function(_0xf237f7,_0xb11ac){_0xf237f7=_0xf237f7-0x0;var _0x2c183b=_0xc6b2[_0xf237f7];return _0x2c183b;};'use strict';var util=require('util');var passport=require(_0x2c6b('0x0'));var LocalStrategy=require('passport-local')[_0x2c6b('0x1')];var jayson=require('jayson/promise');var _=require(_0x2c6b('0x2'));var rs=require(_0x2c6b('0x3'));var moment=require('moment');var db=require(_0x2c6b('0x4'))['db'];var authService=require('../../components/auth/service');var utils=require('../../config/utils');var client=jayson[_0x2c6b('0x5')][_0x2c6b('0x6')]({'port':0x232b});function localAuthenticate(_0x523342,_0x3bc3de,_0x570b54,_0x5114d6){var _0x49f0aa,_0x3f1ca4;return db['Setting']['findOne']({'where':{'id':0x1},'attributes':[_0x2c6b('0x7'),'blockDuration'],'raw':!![]})[_0x2c6b('0x8')](function(_0x29b4fa){_0x49f0aa=_0x29b4fa;return _0x523342[_0x2c6b('0x9')]({'attributes':['id',_0x2c6b('0xa'),_0x2c6b('0xb'),_0x2c6b('0xc'),'role',_0x2c6b('0xd'),_0x2c6b('0xe'),_0x2c6b('0xf'),'loginAttempts'],'where':{'name':_0x3bc3de,'role':{'$or':[_0x2c6b('0x10'),_0x2c6b('0x11'),_0x2c6b('0x12')]}}});})[_0x2c6b('0x8')](function(_0x374d79){if(!_0x374d79||_0x374d79&&_0x374d79[_0x2c6b('0xa')]!==_0x3bc3de){throw new Error('Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.');}else{_0x3f1ca4=_0x374d79;return _0x3f1ca4;}})[_0x2c6b('0x8')](function(){_0x3f1ca4['authenticate'](_0x570b54,function(_0xf55608,_0x487aff){var _0x4b20cb=_0x3f1ca4[_0x2c6b('0x13')]+0x1;if(_0xf55608){return _0x5114d6(_0xf55608);}else if(!_0x487aff){if(_0x3f1ca4[_0x2c6b('0xd')]){return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});}else if(_0x49f0aa[_0x2c6b('0x7')]>0x0){if(_0x3f1ca4['blocked']){if(_0x49f0aa[_0x2c6b('0x15')]>0x0){if(moment(_0x3f1ca4['blockedAt'])[_0x2c6b('0x16')](_0x49f0aa[_0x2c6b('0x15')],_0x2c6b('0x17'))>moment()){return _0x5114d6(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x2c6b('0x18')](_0x3f1ca4,_0x4b20cb,![],null)['then'](function(){return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});});}}else{return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});}}else{if(_0x4b20cb>=_0x49f0aa[_0x2c6b('0x7')]){return utils[_0x2c6b('0x18')](_0x3f1ca4,0x0,!![],moment())[_0x2c6b('0x8')](function(){return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});});}else{return utils[_0x2c6b('0x18')](_0x3f1ca4,_0x4b20cb,![],null)['then'](function(){return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});});}}}else{return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});}}else{if(_0x3f1ca4[_0x2c6b('0xd')]){return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});}else if(_0x49f0aa['allowedLoginAttempts']>0x0){if(_0x3f1ca4['blocked']){if(_0x49f0aa[_0x2c6b('0x15')]>0x0){if(moment(_0x3f1ca4[_0x2c6b('0xf')])['add'](_0x49f0aa[_0x2c6b('0x15')],_0x2c6b('0x17'))>moment()){return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});}else{return utils['clearBlockUser'](_0x3f1ca4,0x0,![],null)[_0x2c6b('0x8')](function(){return utils[_0x2c6b('0x19')](_0x3f1ca4);})['then'](function(){return _0x5114d6(null,_0x3f1ca4);});}}else{return _0x5114d6(null,![],{'message':_0x2c6b('0x14')});}}else{return utils[_0x2c6b('0x18')](_0x3f1ca4,0x0,![],null)['then'](function(){return utils[_0x2c6b('0x19')](_0x3f1ca4);})[_0x2c6b('0x8')](function(){return _0x5114d6(null,_0x3f1ca4);})[_0x2c6b('0x1a')](function(_0x11364f){return _0x5114d6(null,![],_0x11364f);});}}else{if(_0x3f1ca4[_0x2c6b('0xe')]){return _0x5114d6(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x2c6b('0x19')](_0x3f1ca4)[_0x2c6b('0x8')](function(){return _0x5114d6(null,_0x3f1ca4);});}}}});})[_0x2c6b('0x1a')](function(_0x2d5264){return _0x5114d6(null,![],_0x2d5264);});}function sendServiceMail(_0x53d0cd){return db[_0x2c6b('0x1b')][_0x2c6b('0x1c')]({'where':{'service':!![]},'attributes':['id',_0x2c6b('0xa'),_0x2c6b('0x1d')],'include':[{'model':db[_0x2c6b('0x1e')],'as':'Smtp','include':[{'model':db[_0x2c6b('0x1f')],'as':_0x2c6b('0x1f')}]}]})[_0x2c6b('0x8')](function(_0x414849){if(!_0x414849){throw new Error(_0x2c6b('0x20'));}var _0x35c575=_0x414849[_0x2c6b('0x21')]();var _0x59898b={'account':_0x35c575,'message':_[_0x2c6b('0x22')]({'from':util[_0x2c6b('0x23')](_0x2c6b('0x24'),_0x414849[_0x2c6b('0xa')],_0x414849['email']||_0x414849[_0x2c6b('0x25')][_0x2c6b('0x11')])},_0x53d0cd)};return client[_0x2c6b('0x26')](_0x2c6b('0x27'),_0x59898b);})[_0x2c6b('0x8')](function(_0x528a10){if(_0x528a10[_0x2c6b('0x28')]){throw new Error(util['format'](_0x2c6b('0x29'),_0x528a10[_0x2c6b('0x28')][_0x2c6b('0x2a')]||JSON['stringify'](_0x528a10[_0x2c6b('0x28')])));}return!![];});}function handleError(_0x2ebeb7,_0x458748,_0xcbcbe1){return _0x2ebeb7[_0x2c6b('0x2b')](_0x458748||0x1f4)['send']({'message':_0xcbcbe1?_0xcbcbe1['message']||_0xcbcbe1:''});}exports['login']=function(_0x3dc019,_0x35c59f,_0x17f3de){passport[_0x2c6b('0x2c')](_0x2c6b('0x2d'),function(_0x1c7584,_0x2d75de,_0x556241){var _0xa4a0fe=_0x1c7584||_0x556241;if(_0xa4a0fe){return handleError(_0x35c59f,0x191,_0xa4a0fe);}if(!_0x2d75de){return handleError(_0x35c59f,0x194,{'message':'Something\x20went\x20wrong,\x20please\x20try\x20again.'});}else{var _0x31670f={'payload':{'id':_0x2d75de['id'],'role':_0x2d75de[_0x2c6b('0x2e')]},'options':{'expiresIn':0x15180}};return authService['signToken'](_0x31670f)['then'](function(_0x22d3da){_0x35c59f[_0x2c6b('0x2f')]({'id':_0x2d75de['id'],'token':_0x22d3da,'statusCall':'','isAlreadyLogged':_0x2d75de['online']});});}})(_0x3dc019,_0x35c59f,_0x17f3de);};exports[_0x2c6b('0x30')]=function(_0x5b80a6,_0xdafb24){if(!_0x5b80a6[_0x2c6b('0x31')]['email']){return handleError(_0xdafb24,0x1f4,{'message':_0x2c6b('0x32')});}var _0x1095d6=rs[_0x2c6b('0x33')]();_0x5b80a6[_0x2c6b('0x31')]['email']=_0x5b80a6[_0x2c6b('0x31')][_0x2c6b('0x1d')]['trim']()[_0x2c6b('0x34')]();var _0x3ffa30;return db['Setting'][_0x2c6b('0x9')]({'where':{'id':0x1},'attributes':[_0x2c6b('0x7'),_0x2c6b('0x15')],'raw':!![]})[_0x2c6b('0x8')](function(_0x3e8c50){_0x3ffa30=_0x3e8c50;return db[_0x2c6b('0x35')][_0x2c6b('0x1c')]({'where':{'email':_0x5b80a6[_0x2c6b('0x31')]['email']}});})['then'](function(_0x4010f1){if(!_0x4010f1){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x4010f1[_0x2c6b('0xd')]){throw new Error(_0x2c6b('0x36'));}if(_0x4010f1[_0x2c6b('0xe')]){if(moment(_0x4010f1['blockedAt'])['add'](_0x3ffa30[_0x2c6b('0x15')],_0x2c6b('0x17'))>moment()){throw new Error(_0x2c6b('0x37'));}else{_0x4010f1[_0x2c6b('0xe')]=![];_0x4010f1[_0x2c6b('0xf')]=null;}}_0x4010f1[_0x2c6b('0x38')]=_0x1095d6;_0x4010f1[_0x2c6b('0x39')]=Date[_0x2c6b('0x3a')]()+0x36ee80;return _0x4010f1[_0x2c6b('0x3b')]();})[_0x2c6b('0x8')](function(){return sendServiceMail({'to':_0x5b80a6['body'][_0x2c6b('0x1d')],'subject':'xCally\x20Motion\x20Password\x20Reset','text':_0x2c6b('0x3c')+_0x2c6b('0x3d')+_0x2c6b('0x3e')+_0x5b80a6[_0x2c6b('0x3f')][_0x2c6b('0x40')]+_0x2c6b('0x41')+_0x1095d6+'\x0a\x0a'+'If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a'});})[_0x2c6b('0x8')](function(){_0xdafb24[_0x2c6b('0x2b')](0xc8)[_0x2c6b('0x42')]({'message':_0x2c6b('0x43')});})[_0x2c6b('0x1a')](function(_0x3188d8){return handleError(_0xdafb24,0x1f4,_0x3188d8);});};exports[_0x2c6b('0x44')]=function(_0x40a445,_0x4fbd7e){return db[_0x2c6b('0x35')][_0x2c6b('0x1c')]({'where':{'resetPasswordToken':_0x40a445[_0x2c6b('0x45')][_0x2c6b('0x46')],'resetPasswordExpires':{'$gt':Date[_0x2c6b('0x3a')]()}}})[_0x2c6b('0x8')](function(_0x32e6c8){if(!_0x32e6c8){throw new Error(_0x2c6b('0x47'));}return db[_0x2c6b('0x48')][_0x2c6b('0x9')]({'attributes':['id',_0x2c6b('0x49'),_0x2c6b('0x4a'),_0x2c6b('0x4b')]})[_0x2c6b('0x8')](function(_0xa5fd2){if(_0xa5fd2[_0x2c6b('0x49')])authService[_0x2c6b('0x4c')](_0x40a445['body'][_0x2c6b('0xb')]);if(!_0xa5fd2[_0x2c6b('0x4a')]||!_0x32e6c8[_0x2c6b('0x4d')])return _0x32e6c8;authService[_0x2c6b('0x4e')](_0x40a445['body']['password'],_0x32e6c8['previousPasswords'],_0xa5fd2[_0x2c6b('0x4b')]);return _0x32e6c8;})[_0x2c6b('0x8')](function(){_0x32e6c8['password']=_0x40a445[_0x2c6b('0x31')][_0x2c6b('0xb')];_0x32e6c8['resetPasswordToken']=null;_0x32e6c8[_0x2c6b('0x39')]=null;return _0x32e6c8[_0x2c6b('0x3b')]();});})[_0x2c6b('0x8')](function(){_0x4fbd7e[_0x2c6b('0x2b')](0xc8)[_0x2c6b('0x42')]({'message':_0x2c6b('0x4f')});})[_0x2c6b('0x1a')](function(_0x387d83){return handleError(_0x4fbd7e,0x1f4,_0x387d83);});};passport['use'](_0x2c6b('0x2d'),new LocalStrategy({'usernameField':_0x2c6b('0xa'),'passwordField':_0x2c6b('0xb')},function(_0x198a8f,_0x529317,_0x440b42){return localAuthenticate(db[_0x2c6b('0x35')],_0x198a8f,_0x529317,_0x440b42);}));