73 lines
1.9 KiB
JavaScript
73 lines
1.9 KiB
JavaScript
'use strict';
|
|
|
|
angular.module('users').factory('Auth', ['$window',
|
|
function($window) {
|
|
|
|
var userState = {
|
|
isLoggedIn: false
|
|
};
|
|
|
|
var service = {
|
|
_currentUser: null,
|
|
get currentUser(){
|
|
return this._currentUser;
|
|
},
|
|
|
|
// Note: we can't make the User a dependency of Auth
|
|
// because that would create a circular dependency
|
|
// Auth <- $http <- $resource <- LoopBackResource <- User <- Auth
|
|
ensureHasCurrentUser: function(User) {
|
|
if (service._currentUser && service._currentUser.username) {
|
|
//console.log('Using local current user.');
|
|
//console.log(service._currentUser);
|
|
return service._currentUser;
|
|
}
|
|
else if ($window.user){
|
|
//console.log('Using cached current user.');
|
|
//console.log($window.user);
|
|
service._currentUser = $window.user;
|
|
return service._currentUser;
|
|
}
|
|
else{
|
|
//console.log('Fetching current user from the server.');
|
|
User.getCurrent().then(function(user) {
|
|
// success
|
|
service._currentUser = user;
|
|
userState.isLoggedIn = true;
|
|
$window.user = service._currentUser;
|
|
return service._currentUser;
|
|
},
|
|
function(response) {
|
|
userState.isLoggedIn = false;
|
|
service._currentUser = null;
|
|
$window.user = null;
|
|
console.log('User.getCurrent() err', response);
|
|
return null;
|
|
});
|
|
}
|
|
},
|
|
|
|
isAuthenticated: function() {
|
|
return !!service._currentUser;
|
|
},
|
|
|
|
getUserState: function() {
|
|
return userState;
|
|
},
|
|
|
|
login: function(new_user) {
|
|
userState.isLoggedIn = true;
|
|
service._currentUser = new_user;
|
|
},
|
|
|
|
logout: function() {
|
|
$window.user = null;
|
|
userState.isLoggedIn = false;
|
|
service._currentUser = null;
|
|
}
|
|
};
|
|
return service;
|
|
|
|
}
|
|
]);
|