首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EmberFire认证与ToriiFirebaseAdapter

EmberFire认证与ToriiFirebaseAdapter
EN

Stack Overflow用户
提问于 2015-08-15 10:05:28
回答 2查看 1K关注 0票数 2

我遵循EmberFire 指南设置了torii提供程序的身份验证,它运行得很好。我希望在用户通过身份验证后将用户数据存储在防火墙中,并在整个应用程序中访问用户对象。

我以前做过这与恩伯一段时间前,但我不知道如何使用新的托里供应商。

我想我应该测试用户是否已经被存储在一个初始化函数中,然后将用户注入控制器/路由。

任何帮助我的正确方向将是有帮助的,或一些示例代码。

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-08-18 18:17:39

您需要一个实现openfetch并对应用程序特定的用户模型执行find/save的Torii适配器。我们的ToriiFirebaseAdapter还没有做到这一点。我已经为你准备了一个有用的:

代码语言:javascript
复制
// 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数据模型。

希望这能有所帮助。我们正在将其添加到网站文档中,并将设法将其滚动到EmberFire提供的ToriiFirebaseAdapter中。

票数 5
EN

Stack Overflow用户

发布于 2016-02-06 19:49:52

我建议你总是看看基座适配器

在这里,您可以发现唯一需要覆盖的方法是open

我的解决方案并不完美,但你也可以看看这个(它在google中运行得很好)。

代码语言:javascript
复制
import Ember from 'ember';
import ToriiFirebaseAdapter from 'emberfire/torii-adapters/firebase';

export default ToriiFirebaseAdapter.extend({
  firebase: Ember.inject.service(),
  store: Ember.inject.service(),

  open(authentication) {
    return this._findOrCreateUser(authentication.uid, authentication[authentication.provider])
      .then(user => Ember.RSVP.resolve({
        provider: authentication.provider,
        uid: authentication.uid,
        currentUser: user
      }));
  },

  _findOrCreateUser(uid, userData) {
    let store = this.get('store');
    return store.findRecord('user', uid).then(
      function (user) {
        user.set('name', userData.displayName);
        user.set('imageUrl', userData.profileImageURL);
        user.save();
        return user;
      },
      function () {
        let user = store.createRecord('user', {
          id: uid,
          name: userData.displayName,
          imageUrl: userData.profileImageURL
        });
        user.save();
        return user;
      }
    );
  },
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32023653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档