Built motion from commit (unavailable).|2.4.17
[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 _0x8f3a=['http','Setting','findOne','blockDuration','then','name','password','salt','role','disabled','blocked','loginAttempts','admin','agent','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','allowedLoginAttempts','blockedAt','minutes','clearBlockUser','add','getLicense','catch','MailAccount','find','email','MailServerOut','Smtp','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','service','host','port','secure','authentication','auth','user','pass','merge','\x22%s\x22\x20<%s>','request','SendMail','error','format','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','The\x20password\x20must\x20be\x20at\x20least\x208\x20characters\x20long\x20and\x20have\x201\x20lowercase\x20character,\x201\x20uppercase\x20character,\x201\x20number\x20and\x201\x20special\x20character\x20~!@#$%^&-_=+[{]}.','login','Something\x20went\x20wrong,\x20please\x20try\x20again.','signToken','json','online','forgot','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','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','http://','headers','/reset/','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','status','send','Reset\x20Email\x20sent!','reset','params','token','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','use','util','passport','passport-local','Strategy','jayson/promise','lodash','randomstring','moment','../../mysqldb','../../config/utils','client'];(function(_0x4536a4,_0x55af7b){var _0x4fd1c1=function(_0x4c68cd){while(--_0x4c68cd){_0x4536a4['push'](_0x4536a4['shift']());}};_0x4fd1c1(++_0x55af7b);}(_0x8f3a,0xa9));var _0xa8f3=function(_0x62a2ee,_0x39e90d){_0x62a2ee=_0x62a2ee-0x0;var _0x154d03=_0x8f3a[_0x62a2ee];return _0x154d03;};'use strict';var util=require(_0xa8f3('0x0'));var passport=require(_0xa8f3('0x1'));var LocalStrategy=require(_0xa8f3('0x2'))[_0xa8f3('0x3')];var jayson=require(_0xa8f3('0x4'));var _=require(_0xa8f3('0x5'));var rs=require(_0xa8f3('0x6'));var moment=require(_0xa8f3('0x7'));var db=require(_0xa8f3('0x8'))['db'];var authService=require('../../components/auth/service');var utils=require(_0xa8f3('0x9'));var client=jayson[_0xa8f3('0xa')][_0xa8f3('0xb')]({'port':0x232b});function localAuthenticate(_0x50977b,_0x41b21f,_0x4a812a,_0x427042){var _0x1fd787,_0x388968;return db[_0xa8f3('0xc')][_0xa8f3('0xd')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts',_0xa8f3('0xe')],'raw':!![]})[_0xa8f3('0xf')](function(_0x215804){_0x1fd787=_0x215804;return _0x50977b[_0xa8f3('0xd')]({'attributes':['id',_0xa8f3('0x10'),_0xa8f3('0x11'),_0xa8f3('0x12'),_0xa8f3('0x13'),_0xa8f3('0x14'),_0xa8f3('0x15'),'blockedAt',_0xa8f3('0x16')],'where':{'name':_0x41b21f,'role':{'$or':[_0xa8f3('0x17'),'user',_0xa8f3('0x18')]}}});})[_0xa8f3('0xf')](function(_0x25e870){if(!_0x25e870||_0x25e870&&_0x25e870[_0xa8f3('0x10')]!==_0x41b21f){throw new Error(_0xa8f3('0x19'));}else{_0x388968=_0x25e870;return _0x388968;}})[_0xa8f3('0xf')](function(){_0x388968[_0xa8f3('0x1a')](_0x4a812a,function(_0x416eef,_0x36fd16){var _0x572822=_0x388968[_0xa8f3('0x16')]+0x1;if(_0x416eef){return _0x427042(_0x416eef);}else if(!_0x36fd16){if(_0x388968[_0xa8f3('0x14')]){return _0x427042(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x1fd787[_0xa8f3('0x1b')]>0x0){if(_0x388968['blocked']){if(_0x1fd787[_0xa8f3('0xe')]>0x0){if(moment(_0x388968[_0xa8f3('0x1c')])['add'](_0x1fd787['blockDuration'],_0xa8f3('0x1d'))>moment()){return _0x427042(null,![],{'message':_0xa8f3('0x19')});}else{return utils[_0xa8f3('0x1e')](_0x388968,_0x572822,![],null)[_0xa8f3('0xf')](function(){return _0x427042(null,![],{'message':_0xa8f3('0x19')});});}}else{return _0x427042(null,![],{'message':_0xa8f3('0x19')});}}else{if(_0x572822>=_0x1fd787[_0xa8f3('0x1b')]){return utils['clearBlockUser'](_0x388968,0x0,!![],moment())['then'](function(){return _0x427042(null,![],{'message':_0xa8f3('0x19')});});}else{return utils['clearBlockUser'](_0x388968,_0x572822,![],null)[_0xa8f3('0xf')](function(){return _0x427042(null,![],{'message':_0xa8f3('0x19')});});}}}else{return _0x427042(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}}else{if(_0x388968[_0xa8f3('0x14')]){return _0x427042(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else if(_0x1fd787[_0xa8f3('0x1b')]>0x0){if(_0x388968[_0xa8f3('0x15')]){if(_0x1fd787[_0xa8f3('0xe')]>0x0){if(moment(_0x388968[_0xa8f3('0x1c')])[_0xa8f3('0x1f')](_0x1fd787[_0xa8f3('0xe')],_0xa8f3('0x1d'))>moment()){return _0x427042(null,![],{'message':_0xa8f3('0x19')});}else{return utils[_0xa8f3('0x1e')](_0x388968,0x0,![],null)['then'](function(){return utils['getLicense'](_0x388968);})['then'](function(){return _0x427042(null,_0x388968);});}}else{return _0x427042(null,![],{'message':_0xa8f3('0x19')});}}else{return utils[_0xa8f3('0x1e')](_0x388968,0x0,![],null)[_0xa8f3('0xf')](function(){return utils['getLicense'](_0x388968);})['then'](function(){return _0x427042(null,_0x388968);})['catch'](function(_0x274f4c){return _0x427042(null,![],_0x274f4c);});}}else{if(_0x388968['blocked']){return _0x427042(null,![],{'message':_0xa8f3('0x19')});}else{return utils[_0xa8f3('0x20')](_0x388968)['then'](function(){return _0x427042(null,_0x388968);});}}}});})[_0xa8f3('0x21')](function(_0x3d419d){return _0x427042(null,![],_0x3d419d);});}function sendServiceMail(_0x9b6b6a){return db[_0xa8f3('0x22')][_0xa8f3('0x23')]({'where':{'service':!![]},'attributes':['id',_0xa8f3('0x10'),_0xa8f3('0x24')],'include':[{'model':db[_0xa8f3('0x25')],'as':_0xa8f3('0x26')}]})['then'](function(_0x4ef416){if(!_0x4ef416){throw new Error(_0xa8f3('0x27'));}var _0x195fb6={'tls':{'rejectUnauthorized':![]}};if(_0x4ef416[_0xa8f3('0x26')][_0xa8f3('0x28')]){_0x195fb6[_0xa8f3('0x28')]=_0x4ef416['Smtp'][_0xa8f3('0x28')];}else{_0x195fb6[_0xa8f3('0x29')]=_0x4ef416[_0xa8f3('0x26')]['host'];_0x195fb6[_0xa8f3('0x2a')]=_0x4ef416[_0xa8f3('0x26')]['port'];_0x195fb6[_0xa8f3('0x2b')]=_0x4ef416[_0xa8f3('0x26')][_0xa8f3('0x2b')];}if(_0x4ef416[_0xa8f3('0x26')][_0xa8f3('0x2c')]){_0x195fb6[_0xa8f3('0x2d')]={'user':_0x4ef416[_0xa8f3('0x26')][_0xa8f3('0x2e')],'pass':_0x4ef416[_0xa8f3('0x26')][_0xa8f3('0x2f')]};}var _0x5ee408={'account':_0x195fb6,'message':_[_0xa8f3('0x30')]({'from':util['format'](_0xa8f3('0x31'),_0x4ef416[_0xa8f3('0x10')],_0x4ef416[_0xa8f3('0x24')]||_0x4ef416['Smtp'][_0xa8f3('0x2e')])},_0x9b6b6a)};return client[_0xa8f3('0x32')](_0xa8f3('0x33'),_0x5ee408);})[_0xa8f3('0xf')](function(_0x36dadc){if(_0x36dadc[_0xa8f3('0x34')]){throw new Error(util[_0xa8f3('0x35')](_0xa8f3('0x36'),_0x36dadc['error'][_0xa8f3('0x37')]||JSON[_0xa8f3('0x38')](_0x36dadc[_0xa8f3('0x34')])));}return!![];});}function handleError(_0x4d69f7,_0x10fecd,_0x1e0934){return _0x4d69f7['status'](_0x10fecd||0x1f4)['send']({'message':_0x1e0934?_0x1e0934[_0xa8f3('0x37')]||_0x1e0934:''});}function checkPasswordPattern(_0x5dd4a8,_0x390b68,_0x151352){if(_0x151352){var _0xdf002f=new RegExp(/(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[?!@#\$%\^&\*~\-_=+[{\]\}])(?=.{8,})/);if(_0xdf002f['test'](_0x390b68)){return _0x5dd4a8;}else{throw new Error(_0xa8f3('0x39'));}}else{return _0x5dd4a8;}}exports[_0xa8f3('0x3a')]=function(_0x3f7a96,_0x1e3753,_0x3dbe6f){passport[_0xa8f3('0x1a')]('local',function(_0x52862f,_0x2a7aa7,_0xcb4360){var _0x40b8b2=_0x52862f||_0xcb4360;if(_0x40b8b2){return handleError(_0x1e3753,0x191,_0x40b8b2);}if(!_0x2a7aa7){return handleError(_0x1e3753,0x194,{'message':_0xa8f3('0x3b')});}else{var _0x4c137d={'payload':{'id':_0x2a7aa7['id'],'role':_0x2a7aa7[_0xa8f3('0x13')]},'options':{'expiresIn':0x15180}};return authService[_0xa8f3('0x3c')](_0x4c137d)[_0xa8f3('0xf')](function(_0x16ad52){_0x1e3753[_0xa8f3('0x3d')]({'id':_0x2a7aa7['id'],'token':_0x16ad52,'statusCall':'','isAlreadyLogged':_0x2a7aa7[_0xa8f3('0x3e')]});});}})(_0x3f7a96,_0x1e3753,_0x3dbe6f);};exports[_0xa8f3('0x3f')]=function(_0x30f20b,_0x3953aa,_0x3bcf19){if(!_0x30f20b[_0xa8f3('0x40')][_0xa8f3('0x24')]){return handleError(_0x3953aa,0x1f4,{'message':_0xa8f3('0x41')});}var _0x5d6c6e=rs[_0xa8f3('0x42')]();_0x30f20b['body'][_0xa8f3('0x24')]=_0x30f20b[_0xa8f3('0x40')][_0xa8f3('0x24')][_0xa8f3('0x43')]()[_0xa8f3('0x44')]();var _0x253363;return db[_0xa8f3('0xc')]['findOne']({'where':{'id':0x1},'attributes':[_0xa8f3('0x1b'),_0xa8f3('0xe')],'raw':!![]})[_0xa8f3('0xf')](function(_0x32dafc){_0x253363=_0x32dafc;return db[_0xa8f3('0x45')][_0xa8f3('0x23')]({'where':{'email':_0x30f20b['body'][_0xa8f3('0x24')]}});})[_0xa8f3('0xf')](function(_0x17ffc3){if(!_0x17ffc3){throw new Error('This\x20email\x20is\x20not\x20registered.');}if(_0x17ffc3[_0xa8f3('0x14')]){throw new Error(_0xa8f3('0x46'));}if(_0x17ffc3[_0xa8f3('0x15')]){if(moment(_0x17ffc3[_0xa8f3('0x1c')])[_0xa8f3('0x1f')](_0x253363[_0xa8f3('0xe')],_0xa8f3('0x1d'))>moment()){throw new Error(_0xa8f3('0x47'));}else{_0x17ffc3['blocked']=![];_0x17ffc3[_0xa8f3('0x1c')]=null;}}_0x17ffc3[_0xa8f3('0x48')]=_0x5d6c6e;_0x17ffc3[_0xa8f3('0x49')]=Date['now']()+0x36ee80;return _0x17ffc3[_0xa8f3('0x4a')]();})[_0xa8f3('0xf')](function(){return sendServiceMail({'to':_0x30f20b[_0xa8f3('0x40')][_0xa8f3('0x24')],'subject':_0xa8f3('0x4b'),'text':_0xa8f3('0x4c')+_0xa8f3('0x4d')+_0xa8f3('0x4e')+_0x30f20b[_0xa8f3('0x4f')]['host']+_0xa8f3('0x50')+_0x5d6c6e+'\x0a\x0a'+_0xa8f3('0x51')});})['then'](function(){_0x3953aa[_0xa8f3('0x52')](0xc8)[_0xa8f3('0x53')]({'message':_0xa8f3('0x54')});})[_0xa8f3('0x21')](function(_0x3391c6){return handleError(_0x3953aa,0x1f4,_0x3391c6);});};exports[_0xa8f3('0x55')]=function(_0x7e29f2,_0x2beee4,_0x271b10){var _0x2bc3b3;return db['User'][_0xa8f3('0x23')]({'where':{'resetPasswordToken':_0x7e29f2[_0xa8f3('0x56')][_0xa8f3('0x57')],'resetPasswordExpires':{'$gt':Date['now']()}}})[_0xa8f3('0xf')](function(_0x49fc74){_0x2bc3b3=_0x49fc74;if(!_0x2bc3b3){throw new Error(_0xa8f3('0x58'));}return db['Setting'][_0xa8f3('0xd')]({'attributes':['id','securePassword']});})[_0xa8f3('0xf')](function(_0x234fd7){return checkPasswordPattern(_0x234fd7,_0x7e29f2[_0xa8f3('0x40')][_0xa8f3('0x11')],_0x234fd7['securePassword']);})[_0xa8f3('0xf')](function(){_0x2bc3b3[_0xa8f3('0x11')]=_0x7e29f2[_0xa8f3('0x40')][_0xa8f3('0x11')];_0x2bc3b3['resetPasswordToken']=null;_0x2bc3b3[_0xa8f3('0x49')]=null;return _0x2bc3b3['save']();})[_0xa8f3('0xf')](function(){_0x2beee4['status'](0xc8)['send']({'message':'Password\x20reset!'});})[_0xa8f3('0x21')](function(_0x3c4a7a){return handleError(_0x2beee4,0x1f4,_0x3c4a7a);});};passport[_0xa8f3('0x59')](new LocalStrategy({'usernameField':'name','passwordField':_0xa8f3('0x11')},function(_0xd16f43,_0x110823,_0x5aa137){return localAuthenticate(db[_0xa8f3('0x45')],_0xd16f43,_0x110823,_0x5aa137);}));