#oauth-2.0 #ember-simple-auth
#oauth-2.0 #ember-simple-auth
Вопрос:
Я читал, что восстановление сеанса должно работать «из коробки», но это не для меня, и я не могу найти, что я сделал не так.
authenticators/oauth2.js :
import OAuth2PasswordGrant from 'ember-simple-auth/authenticators/oauth2-password-grant';
export default OAuth2PasswordGrant.extend({
serverTokenEndpoint: '/oauth/token'
});
routes/application.js :
import Route from '@ember/routing/route';
import { inject as service } from '@ember/service';
import ApplicationRouteMixin from 'ember-simple-auth/mixins/application-route-mixin';
export default Route.extend(ApplicationRouteMixin, {
currentUser: service(),
beforeModel() {
return this._loadCurrentUser();
},
sessionAuthenticated() {
this._super(...arguments);
this._loadCurrentUser();
},
_loadCurrentUser() {
return this.get('currentUser').load().catch(() => this.get('session').invalidate());
}
});
services/current-user.js :
import Service from '@ember/service';
import { inject as service } from '@ember/service';
import RSVP from 'rsvp';
export default Service.extend({
session: service('session'),
store: service(),
load() {
if (this.get('session.isAuthenticated')) {
return this.get('store').queryRecord('user', { me: true }).then((user) => {
this.set('user', user);
});
} else {
return RSVP.resolve();
}
}
});
Ответ №1:
Простой способ — реализовать restore
метод или просто перезаписать restore()
его с помощью пользовательского средства аутентификации. Надеюсь, это полезно.
вы также можете перейти по ссылке https://github.com/simplabs/ember-simple-auth#implementing-a-custom-authenticator
Здесь показаны варианты, как вы можете это сделать.
Я также приведу вам пример:
// app/authenticators/yours.js
restore() {
return new RSVP.Promise(res, rej){
return resolve(data);
}
}
Это сохранит ваш сеанс, если вы уже вошли в систему