我遵循了EmberFire guide来使用torii提供程序设置身份验证,它可以完美地工作。我希望在对用户进行身份验证后将用户数据存储在firebase中,并可以在整个应用程序中访问用户对象。
我以前曾经用过 Ember 做过,但我不确定如何使用新的torii提供程序。
我在想我应该测试用户是否已经存储在firebase中的初始化函数中,然后将用户注入(inject)到 Controller /路由中。
向我指出正确方向的任何帮助将对您有所帮助,也可以提供一些示例代码。
谢谢
最佳答案
您需要一个Torii适配器,该适配器实现open
和fetch
并对您的应用程序特定用户模型执行find
/ save
。我们的ToriiFirebaseAdapter尚未执行此操作。我已经继续为您工作,将为您服务:
// app/torii-adapters/application.js
import Ember from 'ember';
export default Ember.Object.extend({
firebase: Ember.inject.service(),
store: Ember.inject.service(),
/**
* Executed after Firebase authentication.
*
* Find or create the user based on the Firebase `authData`
*
* @param {Object} authData
* @return {Promise<Object>} Updated session info
*/
open(authData) {
return this._findOrCreateUser(authData)
.then((user) => {
return { currentUser: user };
});
},
/**
* Fetch an existing Firebase auth session and place into `session.currentUser`
*
* @return {Promise<Object>} Updated session info
*/
fetch() {
let ref = this.get('firebase');
let authData = ref.getAuth();
if (!authData) {
return Ember.RSVP.Promise.reject(new Error('No Firebase session found'));
}
return this._findOrCreateUser(authData)
.then((user) => {
return { currentUser: user };
});
},
/**
* Teardown a session. Remove the `session.currentUser`.
*
* @return {Promise<Object>} Updated session info
*/
close() {
this.get('firebase').unauth();
return Ember.RSVP.Promise.resolve({ currentUser: null });
},
/**
* Find the user with the given `authData`, create if not found
*
* @param {Object} authData
* @return {Promise<Object>} The user
*/
_findOrCreateUser(authData) {
let store = this.get('store');
return store.find('user', authData.uid)
.catch(() => {
let newUser = store.createRecord('user', this.extractUserProperties(authData));
return newUser.save();
});
},
/**
* Extract the user properties from `authData` that you care about.
*
* @param {Object} authData
* @return {Object} An updated property hash
*/
extractUserProperties(authData) {
var name = 'Unknown';
var provider = authData.provider;
var userData = authData[provider];
if (userData.displayName) {
name = userData.displayName;
} else if (userData.username) {
name = userData.username;
}
return {
id: authData.uid,
name: name,
email: userData.email || null
};
}
});
您需要做的就是更新
extractUserProperties
方法,以将您关心的属性放到用户模型中的正确位置-每个人实现其用户模型的方式都不同。现在,您应该可以查找
session.currentUser
,它将返回与登录用户相对应的Ember Data模型。希望能有所帮助。我们正在将其添加到网站文档中,并将尝试找到一种将其添加到EmberFire提供的ToriiFirebaseAdapter中的方法。
关于ember.js - EmberFire身份验证和ToriiFirebaseAdapter,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32023653/