mirror of
https://github.com/datahub-project/datahub.git
synced 2025-08-04 07:18:02 +00:00
72 lines
2.5 KiB
JavaScript
72 lines
2.5 KiB
JavaScript
import Ember from 'ember';
|
|
|
|
const { get, set, isBlank, $: { getJSON }, inject: { service }, Service } = Ember;
|
|
const currentUserUrl = '/api/v1/user/me';
|
|
/**
|
|
* Indicates that the current user has already been tracked in the current session
|
|
* @type {boolean}
|
|
* @private
|
|
*/
|
|
let _hasUserBeenTracked = false;
|
|
|
|
export default Service.extend({
|
|
session: service(),
|
|
|
|
/**
|
|
* Attempt to load the currently logged in user.
|
|
* If the userName is found from a previously retained session,
|
|
* append to service. Request the full user object, and append
|
|
* to service.
|
|
* @returns {Promise}
|
|
*/
|
|
load() {
|
|
const userName = get(this, 'session.data.authenticated.username');
|
|
|
|
if (!isBlank(userName)) {
|
|
set(this, 'userName', userName);
|
|
}
|
|
|
|
// If we have a valid session, get the currently logged in user, and set the currentUser attribute,
|
|
// otherwise raise an exception
|
|
if (get(this, 'session.isAuthenticated')) {
|
|
return Promise.resolve(getJSON(currentUserUrl)).then(
|
|
({ status = 'failed', user = {} }) =>
|
|
status === 'ok'
|
|
? Promise.resolve(set(this, 'currentUser', user))
|
|
: Promise.reject(new Error(`Load current user failed with status: ${status}`))
|
|
);
|
|
}
|
|
|
|
return Promise.resolve();
|
|
},
|
|
|
|
/**
|
|
* Invalidates the current session if the session is currently valid
|
|
* useful if, for example, the server is no able to provide the currently logged in user
|
|
* @return {Boolean|*|Ember.RSVP.Promise}
|
|
*/
|
|
invalidateSession() {
|
|
const sessionService = get(this, 'session');
|
|
return sessionService.isAuthenticated && sessionService.invalidate();
|
|
},
|
|
|
|
/**
|
|
* Uses the provided tracking function to track the currently logged in user's userId
|
|
|
|
* This is not a self-contained method, since it depends on other values that cannot be enforced as dependency
|
|
* of this service as a whole. The dependency on the tracking implementation is also not a concern of this service,
|
|
* injecting as a function is the better approach.
|
|
* @param {Function} userIdTracker a function that takes the userId and tracks it
|
|
*/
|
|
trackCurrentUser(userIdTracker = () => ({})) {
|
|
const userId = get(this, 'userName') || get(this, 'currentUser.userName');
|
|
|
|
// If we have a non-empty userId, the user hasn't already been tracked and the userIdTracker is a valid argument
|
|
// then track the user and toggle the flag affirmative
|
|
if (userId && !_hasUserBeenTracked && typeof userIdTracker === 'function') {
|
|
userIdTracker(userId);
|
|
_hasUserBeenTracked = true;
|
|
}
|
|
}
|
|
});
|