1
私はcookie認証でember-simple-auth 1.1.0を使用しています。カスタムオーセンティケータの機能(復元、認証、無効化) 。
私はajaxErrorイベントにバインドするので、エラーを捕捉できます。たとえば、サーバー応答401が許可されていないルートへのアクセス。セッションを無効にして、ユーザーをログインページにリダイレクトしたいと思います。Emberjs:カスタム認証初期設定でセッションを無効にする方法
現時点では、イニシャライザでember-simple-authのデフォルトセッションを取得できないため、セッションを無効にすることができます。私は自分のアプリケーションのカスタムセッションを作成しませんでした。
これを行うにはどのような方法が最適ですか?
イニシャライザでイベントをトリガし、そのイベントをルートで捕捉する方が良いでしょうか?私たちはこれをどうやって行えるの?
マイカスタム初期化子は、次のようになります。
import BasicAuthenticator from '../authenticators/basic';
export default {
before: 'ember-simple-auth',
name: 'basic-authenticator',
initialize(application) {
application.register('authenticator:basic', BasicAuthenticator);
Ember.$(document).ajaxError((event, jqxhr, settings, reason) => {
if (jqxhr.status === 401) {
}
});
}
};
マイカスタム認証:
import Ember from 'ember';
import Base from 'ember-simple-auth/authenticators/base';
export default Base.extend({
restore() {
return new Ember.RSVP.Promise(function(resolve, reject) {
let sessionCookie = window.Cookies.get('beaker.session.id');
if(!window.isUndefined(sessionCookie)) {
resolve(true);
}else{
reject();
}
});
},
authenticate(data) {
return new Ember.RSVP.Promise(function (resolve, reject) {
Ember.$.ajax({
type: 'post',
url: '/core/authentication/basic/login',
data: data
}).then((response) => {
resolve({
responseText: response
});
}, (error) => {
reject(error);
});
});
},
invalidate() {
return new Ember.RSVP.Promise(function (resolve, reject) {
Ember.$.ajax({
type: 'post',
url: '/core/authentication/basic/logout'
}).then(() => {
resolve(true);
},() => {
reject();
});
});
}
});