Built motion from commit (unavailable).|2.5.20
[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 _0x7096=['User','This\x20email\x20is\x20not\x20registered.','The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.','resetPasswordToken','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','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','Reset\x20Email\x20sent!','reset','params','token','securePassword','enforcePasswordHistory','passwordHistoryLimit','validatePasswordPattern','password','validatePasswordHistory','previousPasswords','Password\x20reset!','passport','Strategy','lodash','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','findOne','allowedLoginAttempts','blockDuration','then','salt','role','disabled','blocked','blockedAt','loginAttempts','admin','user','name','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','add','clearBlockUser','catch','find','MailServerOut','service','host','Smtp','port','secure','authentication','auth','pass','merge','format','email','request','error','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','status','send','login','local','Something\x20went\x20wrong,\x20please\x20try\x20again.','signToken','online','forgot','body','generate','Setting'];(function(_0x1e1f1c,_0x59fca4){var _0x1751fd=function(_0x290d75){while(--_0x290d75){_0x1e1f1c['push'](_0x1e1f1c['shift']());}};_0x1751fd(++_0x59fca4);}(_0x7096,0x10c));var _0x6709=function(_0x311c35,_0x534915){_0x311c35=_0x311c35-0x0;var _0x5cc50c=_0x7096[_0x311c35];return _0x5cc50c;};'use strict';var util=require('util');var passport=require(_0x6709('0x0'));var LocalStrategy=require('passport-local')[_0x6709('0x1')];var jayson=require('jayson/promise');var _=require(_0x6709('0x2'));var rs=require(_0x6709('0x3'));var moment=require(_0x6709('0x4'));var db=require(_0x6709('0x5'))['db'];var authService=require(_0x6709('0x6'));var utils=require(_0x6709('0x7'));var client=jayson[_0x6709('0x8')][_0x6709('0x9')]({'port':0x232b});function localAuthenticate(_0xa35832,_0x3e2223,_0x11ad23,_0x985814){var _0x30147f,_0x513ab6;return db['Setting'][_0x6709('0xa')]({'where':{'id':0x1},'attributes':[_0x6709('0xb'),_0x6709('0xc')],'raw':!![]})[_0x6709('0xd')](function(_0x12eea2){_0x30147f=_0x12eea2;return _0xa35832[_0x6709('0xa')]({'attributes':['id','name','password',_0x6709('0xe'),_0x6709('0xf'),_0x6709('0x10'),_0x6709('0x11'),_0x6709('0x12'),_0x6709('0x13')],'where':{'name':_0x3e2223,'role':{'$or':[_0x6709('0x14'),_0x6709('0x15'),'agent']}}});})[_0x6709('0xd')](function(_0xf59b6e){if(!_0xf59b6e||_0xf59b6e&&_0xf59b6e[_0x6709('0x16')]!==_0x3e2223){throw new Error(_0x6709('0x17'));}else{_0x513ab6=_0xf59b6e;return _0x513ab6;}})['then'](function(){_0x513ab6[_0x6709('0x18')](_0x11ad23,function(_0x5c667c,_0x41af1f){var _0x4bc059=_0x513ab6[_0x6709('0x13')]+0x1;if(_0x5c667c){return _0x985814(_0x5c667c);}else if(!_0x41af1f){if(_0x513ab6[_0x6709('0x10')]){return _0x985814(null,![],{'message':_0x6709('0x17')});}else if(_0x30147f[_0x6709('0xb')]>0x0){if(_0x513ab6['blocked']){if(_0x30147f['blockDuration']>0x0){if(moment(_0x513ab6['blockedAt'])[_0x6709('0x19')](_0x30147f[_0x6709('0xc')],'minutes')>moment()){return _0x985814(null,![],{'message':_0x6709('0x17')});}else{return utils[_0x6709('0x1a')](_0x513ab6,_0x4bc059,![],null)[_0x6709('0xd')](function(){return _0x985814(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}}else{return _0x985814(null,![],{'message':_0x6709('0x17')});}}else{if(_0x4bc059>=_0x30147f[_0x6709('0xb')]){return utils[_0x6709('0x1a')](_0x513ab6,0x0,!![],moment())[_0x6709('0xd')](function(){return _0x985814(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}else{return utils[_0x6709('0x1a')](_0x513ab6,_0x4bc059,![],null)[_0x6709('0xd')](function(){return _0x985814(null,![],{'message':_0x6709('0x17')});});}}}else{return _0x985814(null,![],{'message':_0x6709('0x17')});}}else{if(_0x513ab6[_0x6709('0x10')]){return _0x985814(null,![],{'message':_0x6709('0x17')});}else if(_0x30147f[_0x6709('0xb')]>0x0){if(_0x513ab6[_0x6709('0x11')]){if(_0x30147f[_0x6709('0xc')]>0x0){if(moment(_0x513ab6[_0x6709('0x12')])[_0x6709('0x19')](_0x30147f[_0x6709('0xc')],'minutes')>moment()){return _0x985814(null,![],{'message':_0x6709('0x17')});}else{return utils[_0x6709('0x1a')](_0x513ab6,0x0,![],null)[_0x6709('0xd')](function(){return utils['getLicense'](_0x513ab6);})[_0x6709('0xd')](function(){return _0x985814(null,_0x513ab6);});}}else{return _0x985814(null,![],{'message':_0x6709('0x17')});}}else{return utils[_0x6709('0x1a')](_0x513ab6,0x0,![],null)[_0x6709('0xd')](function(){return utils['getLicense'](_0x513ab6);})[_0x6709('0xd')](function(){return _0x985814(null,_0x513ab6);})[_0x6709('0x1b')](function(_0x50f7d6){return _0x985814(null,![],_0x50f7d6);});}}else{if(_0x513ab6[_0x6709('0x11')]){return _0x985814(null,![],{'message':_0x6709('0x17')});}else{return utils['getLicense'](_0x513ab6)[_0x6709('0xd')](function(){return _0x985814(null,_0x513ab6);});}}}});})[_0x6709('0x1b')](function(_0x50ada6){return _0x985814(null,![],_0x50ada6);});}function sendServiceMail(_0x271098){return db['MailAccount'][_0x6709('0x1c')]({'where':{'service':!![]},'attributes':['id',_0x6709('0x16'),'email'],'include':[{'model':db[_0x6709('0x1d')],'as':'Smtp'}]})[_0x6709('0xd')](function(_0x388aee){if(!_0x388aee){throw new Error('Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!');}var _0x1a9eea={'tls':{'rejectUnauthorized':![]}};if(_0x388aee['Smtp'][_0x6709('0x1e')]){_0x1a9eea[_0x6709('0x1e')]=_0x388aee['Smtp']['service'];}else{_0x1a9eea[_0x6709('0x1f')]=_0x388aee[_0x6709('0x20')][_0x6709('0x1f')];_0x1a9eea[_0x6709('0x21')]=_0x388aee[_0x6709('0x20')][_0x6709('0x21')];_0x1a9eea[_0x6709('0x22')]=_0x388aee[_0x6709('0x20')][_0x6709('0x22')];}if(_0x388aee['Smtp'][_0x6709('0x23')]){_0x1a9eea[_0x6709('0x24')]={'user':_0x388aee[_0x6709('0x20')][_0x6709('0x15')],'pass':_0x388aee['Smtp'][_0x6709('0x25')]};}var _0x1da95d={'account':_0x1a9eea,'message':_[_0x6709('0x26')]({'from':util[_0x6709('0x27')]('\x22%s\x22\x20<%s>',_0x388aee[_0x6709('0x16')],_0x388aee[_0x6709('0x28')]||_0x388aee['Smtp'][_0x6709('0x15')])},_0x271098)};return client[_0x6709('0x29')]('SendMail',_0x1da95d);})[_0x6709('0xd')](function(_0x12b78b){if(_0x12b78b[_0x6709('0x2a')]){throw new Error(util[_0x6709('0x27')](_0x6709('0x2b'),_0x12b78b[_0x6709('0x2a')][_0x6709('0x2c')]||JSON['stringify'](_0x12b78b[_0x6709('0x2a')])));}return!![];});}function handleError(_0x34df09,_0x4fad54,_0x429737){return _0x34df09[_0x6709('0x2d')](_0x4fad54||0x1f4)[_0x6709('0x2e')]({'message':_0x429737?_0x429737[_0x6709('0x2c')]||_0x429737:''});}exports[_0x6709('0x2f')]=function(_0x1c12bb,_0x4b5d60,_0x9208e2){passport['authenticate'](_0x6709('0x30'),function(_0xbb7a64,_0x31e55c,_0x48492f){var _0x149a7a=_0xbb7a64||_0x48492f;if(_0x149a7a){return handleError(_0x4b5d60,0x191,_0x149a7a);}if(!_0x31e55c){return handleError(_0x4b5d60,0x194,{'message':_0x6709('0x31')});}else{var _0x2d9879={'payload':{'id':_0x31e55c['id'],'role':_0x31e55c[_0x6709('0xf')]},'options':{'expiresIn':0x15180}};return authService[_0x6709('0x32')](_0x2d9879)[_0x6709('0xd')](function(_0x450654){_0x4b5d60['json']({'id':_0x31e55c['id'],'token':_0x450654,'statusCall':'','isAlreadyLogged':_0x31e55c[_0x6709('0x33')]});});}})(_0x1c12bb,_0x4b5d60,_0x9208e2);};exports[_0x6709('0x34')]=function(_0x50fbcd,_0x31d2a6,_0xe80008){if(!_0x50fbcd[_0x6709('0x35')][_0x6709('0x28')]){return handleError(_0x31d2a6,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x5abb53=rs[_0x6709('0x36')]();_0x50fbcd[_0x6709('0x35')][_0x6709('0x28')]=_0x50fbcd[_0x6709('0x35')]['email']['trim']()['toLowerCase']();var _0x3d4237;return db[_0x6709('0x37')]['findOne']({'where':{'id':0x1},'attributes':[_0x6709('0xb'),_0x6709('0xc')],'raw':!![]})['then'](function(_0x558a9f){_0x3d4237=_0x558a9f;return db[_0x6709('0x38')][_0x6709('0x1c')]({'where':{'email':_0x50fbcd[_0x6709('0x35')][_0x6709('0x28')]}});})[_0x6709('0xd')](function(_0x47c88c){if(!_0x47c88c){throw new Error(_0x6709('0x39'));}if(_0x47c88c['disabled']){throw new Error(_0x6709('0x3a'));}if(_0x47c88c[_0x6709('0x11')]){if(moment(_0x47c88c[_0x6709('0x12')])['add'](_0x3d4237[_0x6709('0xc')],'minutes')>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x47c88c[_0x6709('0x11')]=![];_0x47c88c[_0x6709('0x12')]=null;}}_0x47c88c[_0x6709('0x3b')]=_0x5abb53;_0x47c88c[_0x6709('0x3c')]=Date[_0x6709('0x3d')]()+0x36ee80;return _0x47c88c[_0x6709('0x3e')]();})[_0x6709('0xd')](function(){return sendServiceMail({'to':_0x50fbcd[_0x6709('0x35')][_0x6709('0x28')],'subject':_0x6709('0x3f'),'text':_0x6709('0x40')+_0x6709('0x41')+_0x6709('0x42')+_0x50fbcd[_0x6709('0x43')][_0x6709('0x1f')]+'/reset/'+_0x5abb53+'\x0a\x0a'+_0x6709('0x44')});})['then'](function(){_0x31d2a6['status'](0xc8)[_0x6709('0x2e')]({'message':_0x6709('0x45')});})[_0x6709('0x1b')](function(_0xe8dd1){return handleError(_0x31d2a6,0x1f4,_0xe8dd1);});};exports[_0x6709('0x46')]=function(_0x2b05dc,_0x1f206a,_0x144f53){return db['User'][_0x6709('0x1c')]({'where':{'resetPasswordToken':_0x2b05dc[_0x6709('0x47')][_0x6709('0x48')],'resetPasswordExpires':{'$gt':Date[_0x6709('0x3d')]()}}})['then'](function(_0x296837){if(!_0x296837){throw new Error('Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.');}return db[_0x6709('0x37')][_0x6709('0xa')]({'attributes':['id',_0x6709('0x49'),_0x6709('0x4a'),_0x6709('0x4b')]})['then'](function(_0x26e507){if(_0x26e507[_0x6709('0x49')])authService[_0x6709('0x4c')](_0x2b05dc[_0x6709('0x35')][_0x6709('0x4d')]);if(!_0x26e507['enforcePasswordHistory']||!_0x296837['previousPasswords'])return _0x296837;authService[_0x6709('0x4e')](_0x2b05dc['body']['password'],_0x296837[_0x6709('0x4f')],_0x26e507[_0x6709('0x4b')]);return _0x296837;})[_0x6709('0xd')](function(){_0x296837[_0x6709('0x4d')]=_0x2b05dc[_0x6709('0x35')][_0x6709('0x4d')];_0x296837[_0x6709('0x3b')]=null;_0x296837[_0x6709('0x3c')]=null;return _0x296837[_0x6709('0x3e')]();});})[_0x6709('0xd')](function(){_0x1f206a[_0x6709('0x2d')](0xc8)['send']({'message':_0x6709('0x50')});})[_0x6709('0x1b')](function(_0x5ea29f){return handleError(_0x1f206a,0x1f4,_0x5ea29f);});};passport['use'](new LocalStrategy({'usernameField':_0x6709('0x16'),'passwordField':_0x6709('0x4d')},function(_0x14bdd3,_0x1875e3,_0x521e83){return localAuthenticate(db[_0x6709('0x38')],_0x14bdd3,_0x1875e3,_0x521e83);}));