Built motion from commit (unavailable).|2.4.6
[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 _0xea06=['catch','MailAccount','email','MailServerOut','Smtp','Unable\x20to\x20find\x20a\x20configured\x20SMTP\x20service!','service','host','port','authentication','auth','pass','merge','\x22%s\x22\x20<%s>','request','SendMail','error','format','SendMail\x20error:\x20%s.\x20Please\x20contact\x20your\x20Administrator!','message','stringify','send','test','The\x20password\x20must\x20be\x20at\x20least\x208\x20characters\x20long\x20and\x20have\x201\x20lowercase\x20character,\x201\x20uppercase\x20character,\x201\x20number\x20and\x201\x20special\x20character\x20~!@#$%^&-_=+[{]}.','local','Something\x20went\x20wrong,\x20please\x20try\x20again.','json','online','forgot','body','generate','trim','toLowerCase','User','This\x20email\x20is\x20not\x20registered.','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','http://','headers','If\x20you\x20did\x20not\x20request\x20this,\x20please\x20ignore\x20this\x20email\x20and\x20your\x20password\x20will\x20remain\x20unchanged.\x0a','status','Reset\x20Email\x20sent!','reset','find','params','Password\x20reset\x20token\x20is\x20invalid\x20or\x20has\x20expired.','password','Password\x20reset!','use','util','passport','passport-local','Strategy','jayson/promise','randomstring','moment','../../mysqldb','../../components/auth/service','../../config/utils','client','http','Setting','findOne','blockDuration','then','name','role','disabled','blocked','blockedAt','loginAttempts','user','Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.','authenticate','allowedLoginAttempts','add','minutes','clearBlockUser','getLicense'];(function(_0x46287f,_0x3a9a37){var _0x1ba83f=function(_0x44d3a2){while(--_0x44d3a2){_0x46287f['push'](_0x46287f['shift']());}};_0x1ba83f(++_0x3a9a37);}(_0xea06,0x181));var _0x6ea0=function(_0x4633fa,_0x5cd49a){_0x4633fa=_0x4633fa-0x0;var _0x4639fb=_0xea06[_0x4633fa];return _0x4639fb;};'use strict';var util=require(_0x6ea0('0x0'));var passport=require(_0x6ea0('0x1'));var LocalStrategy=require(_0x6ea0('0x2'))[_0x6ea0('0x3')];var jayson=require(_0x6ea0('0x4'));var _=require('lodash');var rs=require(_0x6ea0('0x5'));var moment=require(_0x6ea0('0x6'));var db=require(_0x6ea0('0x7'))['db'];var signToken=require(_0x6ea0('0x8'))['signToken'];var utils=require(_0x6ea0('0x9'));var client=jayson[_0x6ea0('0xa')][_0x6ea0('0xb')]({'port':0x232b});function localAuthenticate(_0x56362f,_0x1e2d40,_0x5e5eaf,_0x1758d7){var _0x3c6ccd,_0x25d36b;return db[_0x6ea0('0xc')][_0x6ea0('0xd')]({'where':{'id':0x1},'attributes':['allowedLoginAttempts',_0x6ea0('0xe')],'raw':!![]})[_0x6ea0('0xf')](function(_0x3f76dd){_0x3c6ccd=_0x3f76dd;return _0x56362f[_0x6ea0('0xd')]({'attributes':['id',_0x6ea0('0x10'),'password','salt',_0x6ea0('0x11'),_0x6ea0('0x12'),_0x6ea0('0x13'),_0x6ea0('0x14'),_0x6ea0('0x15')],'where':{'name':_0x1e2d40,'role':{'$or':['admin',_0x6ea0('0x16'),'agent']}}});})[_0x6ea0('0xf')](function(_0x28cd05){if(!_0x28cd05||_0x28cd05&&_0x28cd05['name']!==_0x1e2d40){throw new Error(_0x6ea0('0x17'));}else{_0x25d36b=_0x28cd05;return _0x25d36b;}})[_0x6ea0('0xf')](function(){_0x25d36b[_0x6ea0('0x18')](_0x5e5eaf,function(_0x4bab0e,_0x952304){var _0x490dda=_0x25d36b[_0x6ea0('0x15')]+0x1;if(_0x4bab0e){return _0x1758d7(_0x4bab0e);}else if(!_0x952304){if(_0x25d36b[_0x6ea0('0x12')]){return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});}else if(_0x3c6ccd[_0x6ea0('0x19')]>0x0){if(_0x25d36b[_0x6ea0('0x13')]){if(_0x3c6ccd[_0x6ea0('0xe')]>0x0){if(moment(_0x25d36b[_0x6ea0('0x14')])[_0x6ea0('0x1a')](_0x3c6ccd[_0x6ea0('0xe')],_0x6ea0('0x1b'))>moment()){return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});}else{return utils[_0x6ea0('0x1c')](_0x25d36b,_0x490dda,![],null)[_0x6ea0('0xf')](function(){return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});});}}else{return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});}}else{if(_0x490dda>=_0x3c6ccd['allowedLoginAttempts']){return utils[_0x6ea0('0x1c')](_0x25d36b,0x0,!![],moment())[_0x6ea0('0xf')](function(){return _0x1758d7(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});});}else{return utils[_0x6ea0('0x1c')](_0x25d36b,_0x490dda,![],null)[_0x6ea0('0xf')](function(){return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});});}}}else{return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});}}else{if(_0x25d36b[_0x6ea0('0x12')]){return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});}else if(_0x3c6ccd[_0x6ea0('0x19')]>0x0){if(_0x25d36b[_0x6ea0('0x13')]){if(_0x3c6ccd['blockDuration']>0x0){if(moment(_0x25d36b[_0x6ea0('0x14')])[_0x6ea0('0x1a')](_0x3c6ccd['blockDuration'],'minutes')>moment()){return _0x1758d7(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils['clearBlockUser'](_0x25d36b,0x0,![],null)[_0x6ea0('0xf')](function(){return utils[_0x6ea0('0x1d')](_0x25d36b);})[_0x6ea0('0xf')](function(){return _0x1758d7(null,_0x25d36b);});}}else{return _0x1758d7(null,![],{'message':_0x6ea0('0x17')});}}else{return utils[_0x6ea0('0x1c')](_0x25d36b,0x0,![],null)[_0x6ea0('0xf')](function(){return utils['getLicense'](_0x25d36b);})[_0x6ea0('0xf')](function(){return _0x1758d7(null,_0x25d36b);})[_0x6ea0('0x1e')](function(_0x1d8ccc){return _0x1758d7(null,![],_0x1d8ccc);});}}else{if(_0x25d36b[_0x6ea0('0x13')]){return _0x1758d7(null,![],{'message':'Incorrect\x20username\x20and/or\x20password.\x20Please\x20retry\x20again\x20or\x20contact\x20the\x20administrator.'});}else{return utils[_0x6ea0('0x1d')](_0x25d36b)[_0x6ea0('0xf')](function(){return _0x1758d7(null,_0x25d36b);});}}}});})[_0x6ea0('0x1e')](function(_0x1876ee){return _0x1758d7(null,![],_0x1876ee);});}function sendServiceMail(_0x3d7313){return db[_0x6ea0('0x1f')]['find']({'where':{'service':!![]},'attributes':['id',_0x6ea0('0x10'),_0x6ea0('0x20')],'include':[{'model':db[_0x6ea0('0x21')],'as':_0x6ea0('0x22')}]})[_0x6ea0('0xf')](function(_0x177a49){if(!_0x177a49){throw new Error(_0x6ea0('0x23'));}var _0x5c0f98={'tls':{'rejectUnauthorized':![]}};if(_0x177a49['Smtp'][_0x6ea0('0x24')]){_0x5c0f98[_0x6ea0('0x24')]=_0x177a49[_0x6ea0('0x22')][_0x6ea0('0x24')];}else{_0x5c0f98[_0x6ea0('0x25')]=_0x177a49[_0x6ea0('0x22')]['host'];_0x5c0f98['port']=_0x177a49[_0x6ea0('0x22')][_0x6ea0('0x26')];_0x5c0f98['secure']=_0x177a49['Smtp']['secure'];}if(_0x177a49['Smtp'][_0x6ea0('0x27')]){_0x5c0f98[_0x6ea0('0x28')]={'user':_0x177a49[_0x6ea0('0x22')]['user'],'pass':_0x177a49[_0x6ea0('0x22')][_0x6ea0('0x29')]};}var _0x494f0b={'account':_0x5c0f98,'message':_[_0x6ea0('0x2a')]({'from':util['format'](_0x6ea0('0x2b'),_0x177a49[_0x6ea0('0x10')],_0x177a49[_0x6ea0('0x20')]||_0x177a49[_0x6ea0('0x22')][_0x6ea0('0x16')])},_0x3d7313)};return client[_0x6ea0('0x2c')](_0x6ea0('0x2d'),_0x494f0b);})[_0x6ea0('0xf')](function(_0x16ae8a){if(_0x16ae8a[_0x6ea0('0x2e')]){throw new Error(util[_0x6ea0('0x2f')](_0x6ea0('0x30'),_0x16ae8a[_0x6ea0('0x2e')][_0x6ea0('0x31')]||JSON[_0x6ea0('0x32')](_0x16ae8a[_0x6ea0('0x2e')])));}return!![];});}function handleError(_0x218f46,_0x5c4068,_0x462105){return _0x218f46['status'](_0x5c4068||0x1f4)[_0x6ea0('0x33')]({'message':_0x462105?_0x462105[_0x6ea0('0x31')]||_0x462105:''});}function checkPasswordPattern(_0x3d7eb6,_0x4e58bb,_0x1a0117){if(_0x1a0117){var _0x17e202=new RegExp(/(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[?!@#\$%\^&\*~\-_=+[{\]\}])(?=.{8,})/);if(_0x17e202[_0x6ea0('0x34')](_0x4e58bb)){return _0x3d7eb6;}else{throw new Error(_0x6ea0('0x35'));}}else{return _0x3d7eb6;}}exports['login']=function(_0x4fd9f7,_0x3fc1ea,_0x564c59){passport[_0x6ea0('0x18')](_0x6ea0('0x36'),function(_0x32931e,_0x415c70,_0x25129b){var _0x2aa440=_0x32931e||_0x25129b;if(_0x2aa440){return handleError(_0x3fc1ea,0x191,_0x2aa440);}if(!_0x415c70){return handleError(_0x3fc1ea,0x194,{'message':_0x6ea0('0x37')});}else{var _0x41dd5f=signToken(_0x415c70['id'],_0x415c70['role']);_0x3fc1ea[_0x6ea0('0x38')]({'id':_0x415c70['id'],'token':_0x41dd5f,'statusCall':'','isAlreadyLogged':_0x415c70[_0x6ea0('0x39')]});}})(_0x4fd9f7,_0x3fc1ea,_0x564c59);};exports[_0x6ea0('0x3a')]=function(_0x154dc0,_0x1ea86a,_0x35dc2e){if(!_0x154dc0[_0x6ea0('0x3b')][_0x6ea0('0x20')]){return handleError(_0x1ea86a,0x1f4,{'message':'Email\x20parameter\x20is\x20missing'});}var _0x31811e=rs[_0x6ea0('0x3c')]();_0x154dc0['body']['email']=_0x154dc0[_0x6ea0('0x3b')][_0x6ea0('0x20')][_0x6ea0('0x3d')]()[_0x6ea0('0x3e')]();var _0x39787c;return db['Setting'][_0x6ea0('0xd')]({'where':{'id':0x1},'attributes':[_0x6ea0('0x19'),_0x6ea0('0xe')],'raw':!![]})[_0x6ea0('0xf')](function(_0x19174a){_0x39787c=_0x19174a;return db[_0x6ea0('0x3f')]['find']({'where':{'email':_0x154dc0[_0x6ea0('0x3b')][_0x6ea0('0x20')]}});})[_0x6ea0('0xf')](function(_0x801b16){if(!_0x801b16){throw new Error(_0x6ea0('0x40'));}if(_0x801b16['disabled']){throw new Error('The\x20user\x20is\x20disabled.\x20Please\x20contact\x20the\x20administrator.');}if(_0x801b16[_0x6ea0('0x13')]){if(moment(_0x801b16[_0x6ea0('0x14')])[_0x6ea0('0x1a')](_0x39787c['blockDuration'],_0x6ea0('0x1b'))>moment()){throw new Error('The\x20user\x20is\x20blocked.\x20Please\x20contact\x20the\x20administrator.');}else{_0x801b16[_0x6ea0('0x13')]=![];_0x801b16[_0x6ea0('0x14')]=null;}}_0x801b16[_0x6ea0('0x41')]=_0x31811e;_0x801b16[_0x6ea0('0x42')]=Date[_0x6ea0('0x43')]()+0x36ee80;return _0x801b16[_0x6ea0('0x44')]();})[_0x6ea0('0xf')](function(){return sendServiceMail({'to':_0x154dc0[_0x6ea0('0x3b')][_0x6ea0('0x20')],'subject':_0x6ea0('0x45'),'text':_0x6ea0('0x46')+'Please\x20click\x20on\x20the\x20following\x20link,\x20or\x20paste\x20this\x20into\x20your\x20browser\x20to\x20complete\x20the\x20process:\x0a\x0a'+_0x6ea0('0x47')+_0x154dc0[_0x6ea0('0x48')]['host']+'/reset/'+_0x31811e+'\x0a\x0a'+_0x6ea0('0x49')});})[_0x6ea0('0xf')](function(){_0x1ea86a[_0x6ea0('0x4a')](0xc8)[_0x6ea0('0x33')]({'message':_0x6ea0('0x4b')});})[_0x6ea0('0x1e')](function(_0x554aad){return handleError(_0x1ea86a,0x1f4,_0x554aad);});};exports[_0x6ea0('0x4c')]=function(_0x118693,_0x2134a6,_0xd560d){var _0x3fb11e;return db[_0x6ea0('0x3f')][_0x6ea0('0x4d')]({'where':{'resetPasswordToken':_0x118693[_0x6ea0('0x4e')]['token'],'resetPasswordExpires':{'$gt':Date[_0x6ea0('0x43')]()}}})[_0x6ea0('0xf')](function(_0x12a286){_0x3fb11e=_0x12a286;if(!_0x3fb11e){throw new Error(_0x6ea0('0x4f'));}return db['Setting'][_0x6ea0('0xd')]({'attributes':['id','securePassword']});})[_0x6ea0('0xf')](function(_0x3e07ae){return checkPasswordPattern(_0x3e07ae,_0x118693[_0x6ea0('0x3b')][_0x6ea0('0x50')],_0x3e07ae['securePassword']);})[_0x6ea0('0xf')](function(){_0x3fb11e['password']=_0x118693[_0x6ea0('0x3b')][_0x6ea0('0x50')];_0x3fb11e['resetPasswordToken']=null;_0x3fb11e[_0x6ea0('0x42')]=null;return _0x3fb11e[_0x6ea0('0x44')]();})['then'](function(){_0x2134a6[_0x6ea0('0x4a')](0xc8)[_0x6ea0('0x33')]({'message':_0x6ea0('0x51')});})['catch'](function(_0xee0cef){return handleError(_0x2134a6,0x1f4,_0xee0cef);});};passport[_0x6ea0('0x52')](new LocalStrategy({'usernameField':_0x6ea0('0x10'),'passwordField':_0x6ea0('0x50')},function(_0x2c9c9d,_0x1b58be,_0x5b7c76){return localAuthenticate(db[_0x6ea0('0x3f')],_0x2c9c9d,_0x1b58be,_0x5b7c76);}));