3

我正在尝试使用我自己的 OAuth 流程和 Ember-Simple-Auth 设置 Torii。我可以获得成功的身份验证事件,但在我进行身份验证后,invalidateSession触发器立即被触发,导致我的会话结束。我可以通过拦截(其中有)sessionInvalidated()来看到这一点。/app/routes/application.jsApplicationRouteMixin

你们有人遇到过这个吗?是否有一些特殊的东西会导致立即进行会话验证?任何建议将不胜感激。

编辑:我认为这与 torii 弹出代码有关,因为第一个返回有效,但第二个无效。有什么想法吗?

import OAuth2 from 'torii/providers/oauth2-code';
import {configurable} from 'torii/configuration';

export default OAuth2.extend({
  name: 'api',
  init() { this.set('clientID', this.get('apiKey')); },

  baseUrl: configurable('baseUrl'),

  redirectUri: configurable('redirectUri'),
  responseParams: ['access_token', 'user_id', 'first_name'],

  requiredUrlParams: ['client_id', 'redirect_uri', 'response_type'],

  open() {
    let name        = this.get('name');
    let url         = this.buildUrl();
    let redirectUri = this.get('redirectUri');
    let responseParams = this.get('responseParams');

    // this return works
    return { 'yes' : 'no' }

    // this return causes the immediate invalidation
    return this.get('popup').open(url, responseParams).then((authData) => {
      var missingResponseParams = [];

      responseParams.forEach(function(param){
        if (authData[param] === undefined) {
          missingResponseParams.push(param);
        }
      });

      if (missingResponseParams.length){
        throw new Error("The response from the provider is missing " +
              "these required response params: " + missingResponseParams.join(', '));
      }

      return {
        access_token: authData.access_token,
        first_name: authData.first_name,
        user_id: authData.user_id,
        provider: name,
        redirectUri: redirectUri
      };
    });
  }
});
4

2 回答 2

3

真正的答案是使用这个分叉:https ://github.com/simplabs/ember-simple-auth/pull/931 (希望它很快就会成为master)。

于 2016-03-17T00:46:34.070 回答
2

你可能有什么this.get('session').invalidate();地方。可能在您的控制器操作属性之一中。您通常会将其放在注销按钮的操作中。也许您不小心复制并粘贴了它。如果您发布一些代码,我可能会再看一些

于 2016-03-04T01:56:03.177 回答