ember 简单验证 session.addObserver 示例?

ember simple auth session.addObserver example?

看到如何将观察者添加到 ember 简单身份验证的会话服务数据 属性.

的示例会很棒

我目前陷入了另一个问题,但很快就会回到这个问题上。

目前我在我的 application/route.js 中写了这个,但是我在另一个问题上被阻止了,所以我不知道它有多正确。我什至不知道应用程序路由是否是放置此观察者的最佳位置,更不用说放在 beforeModel 钩子中了。

export default Ember.Route.extend({ //adds in login/logout actions
  session: Ember.inject.service('session'),
  //I also tried putting this code in a model() hook, still no luck.
  beforeModel() {
    this.get('session').addObserver('data', (sender, key, value, rev) => {
      console.log('session data addObserver fired with these arguments:', sender, key, value, rev)
    })
  },
  actions: {
    error: function(error, transition) {
      console.error('ApplicationRoute error action', arguments)
      // substate implementation when returning `true`
      return true;
    }
  }
}).extend(ApplicationRouteMixin)

注意:我使用的是 service.addObserver api 的未记录版本,可能有点问题,但我提交了关于此的拉取请求:https://github.com/emberjs/ember.js/pull/12768

此代码已完成 99%。我缺少的是我应该为每个我想要跟踪的 data.key 添加观察者,而不仅仅是 data。这是我的申请路线中的最终代码:

var sentData = {}
var sendToExtension = (service, key, value, rev/*ignored*/) => {
  if (value != null) console.log('value actually is defined for once!', value, 'rev:', rev)
  // It seems value is always undefined. Here we check if it's undefined or null and if 
  if (value == null && service.get(key) != null) value = service.get(key) 
  if (sentData[key] != null && sentData[key] === value) {
    console.log('already sent '+key+': '+value+', returning')
    return
  }
  sentData[key] = value
  //proceed however you want with the knowledge that the `key` has just been set to this `value
}

var haveRegisteredSessionObservers = false
export default Ember.Route.extend({ //adds in login/logout actions
  session: Ember.inject.service('session'),
  beforeModel() {
    //if we're in chrome, add session data observer to send the session data back to the extension background page
    if (window.chrome && !haveRegisteredSessionObservers) {
      applicationRouteInstance = this
      ;['data.email', 'data.user_id', 'isAuthenticated'].forEach((key) => {
        this.get('session').addObserver(key, sendToExtension)
      })
      haveRegisteredSessionObservers = true