Search code examples
ember.jsember-cli

Ember CLI - Injecting a service


I created the following service and initializer using Ember CLI (generate blueprint):

// services/session.js
import Ember from 'ember';

export default Ember.Object.extend({
    loggedIn: false,

    ...
});

// initializers/session.js
export default {
  name: 'session',
  initialize: function(container, app) {
    app.inject('route', 'session', 'service:session');
    app.inject('controller', 'session', 'service:session');
  }
};

However, the session is undefined when attempting to access it in a route or controller. Am I missing a step?

// routes/application.js
import Ember from 'ember';

export default Ember.Route.extend({
    beforeModel: function() {
        var loggedIn = this.session.get('loggedIn'); // undefined
        ...
    }
});

Solution

  • Injected services are lazy loaded, you have to access them via a getter this.get('session') and not directly this.session.

    Also, you may want to check out Ember-Simple-Auth if you're doing authentication.