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
看到如何将观察者添加到 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