API Docs for: 0.25.0
Show:

File: addon/mixins/osf-cookie-login-route.js

import Ember from 'ember';

/**
 * @module ember-osf
 * @submodule mixins
 */

/**
 * Route mixin for login based on OSF cookie authentication. Intended to be used in tandem with OsfCookieLoginController mixin.
 * This auth method is not available to third-party applications.
 *
 * @class OsfCookieLoginRoute
 * @extends Ember.Mixin
 * @uses ember-simple-auth/UnauthenticatedRouteMixin
 */
export default Ember.Mixin.create({
    session: Ember.inject.service(),
    beforeModel() {
        // Determine whether the user is logged in by making a test request. This is quite a crude way of
        // determining whether the user has a cookie and should be improved in the future.

        // TODO: Should this check for resolution of a promise?
        this._super(...arguments);
        if (this.get('session.isAuthenticated')) return;

        // Block transition until auth attempt resolves.
        return this.get('session').authenticate('authenticator:osf-cookie');
    },
    actions: {
        error() {
            // To manually transition to a wildcard route
            // we need to pass a arbitrary, non-empty argument as the model
            return this.intermediateTransitionTo('error-no-api', 'no-api');
        }
    }
});