如何将 session 存储在 Ember-Simple-Auth session 中?
How can I get the session stored in a Ember-Simple-Auth session?
我正在使用 ember-simple-auth 来管理我的应用程序身份验证。
我已经实现了自己的验证器、授权器和适配器。
源代码
身份验证器
import Ember from 'ember';
import Base from 'ember-simple-auth/authenticators/base';
export default Base.extend({
tokenEndpoint: 'http://localhost:9000/0/auth/',
restore: function(data) {
console.log("restore");
console.log(data);
return new Ember.RSVP.Promise(function(resolve, reject) {
if (!Ember.isEmpty(data.token)) {
resolve(data);
} else {
reject();
}
});
},
authenticate: function(options) {
return new Ember.RSVP.Promise((resolve, reject) => {
Ember.$.ajax({
url: this.tokenEndpoint + options.method,
type: 'POST',
data: JSON.stringify(options.data),
contentType: 'application/json',
dataType: 'json'
}).then(function(response) {
console.log("OK!");
console.log(response);
Ember.run(function() {
console.log("resolve: "+response.data.encodedToken);
resolve({
token: response.data.encodedToken
});
});
}, function(xhr, status, error) {
var response = xhr.responseText;
console.log("ERROR");
console.log(response);
Ember.run(function() {
reject(response);
});
});
});
},
invalidate: function() {
console.log('invalidate...');
//return Ember.RSVP.resolve();
Ember.$.ajax({
type: 'POST',
url: this.tokenEndpoint + 'logout',
}).then(() => {
resolve(true);
}, () => {
reject();
});
}
});
授权人
import Ember from 'ember';
import Base from 'ember-simple-auth/authorizers/base';
export default Base.extend({
authorize: function(jqXHR, requestOptions) {
console.log(requestOptions);
console.log("---- Authorize ----");
var accessToken = this.get('session.content.secure.token');
console.log(this.get('session'));
if (this.get('session.isAuthenticated') && !Ember.isEmpty(accessToken)) {
jqXHR.setRequestHeader('Authorization', accessToken);
}
}
});
适配器
import Ember from 'ember';
import JSONAPIAdapter from 'ember-data/adapters/json-api';
import singularize from 'ember-inflector';
export default JSONAPIAdapter.extend({
namespace: '0',
host: 'http://localhost:9000',
session: Ember.inject.service('session'),
headers: Ember.computed('session.token', function() {
console.log("Sending header...");
return {
'Authorization': 'MYTOKEN'
};
}),
pathForType: function(type) {
return Ember.String.underscore(type);
//return singularize(type);
},
});
问题
我想知道如何在身份验证过程中获取存储的令牌,在适配器内部将编码的令牌注入 header Authorization
。
还有一个问题,什么时候叫授权人?
我假设您使用的是 ESA 1.0 或更高版本。然后,您不会在授权方的 authorize
方法中获得 jqXHR
,而是获得会话数据以及回调。
查看 DataAdapterMixin
and BaseAuthorizer
as well as the README 的文档以获取更多信息。
我正在使用 ember-simple-auth 来管理我的应用程序身份验证。
我已经实现了自己的验证器、授权器和适配器。
源代码
身份验证器
import Ember from 'ember';
import Base from 'ember-simple-auth/authenticators/base';
export default Base.extend({
tokenEndpoint: 'http://localhost:9000/0/auth/',
restore: function(data) {
console.log("restore");
console.log(data);
return new Ember.RSVP.Promise(function(resolve, reject) {
if (!Ember.isEmpty(data.token)) {
resolve(data);
} else {
reject();
}
});
},
authenticate: function(options) {
return new Ember.RSVP.Promise((resolve, reject) => {
Ember.$.ajax({
url: this.tokenEndpoint + options.method,
type: 'POST',
data: JSON.stringify(options.data),
contentType: 'application/json',
dataType: 'json'
}).then(function(response) {
console.log("OK!");
console.log(response);
Ember.run(function() {
console.log("resolve: "+response.data.encodedToken);
resolve({
token: response.data.encodedToken
});
});
}, function(xhr, status, error) {
var response = xhr.responseText;
console.log("ERROR");
console.log(response);
Ember.run(function() {
reject(response);
});
});
});
},
invalidate: function() {
console.log('invalidate...');
//return Ember.RSVP.resolve();
Ember.$.ajax({
type: 'POST',
url: this.tokenEndpoint + 'logout',
}).then(() => {
resolve(true);
}, () => {
reject();
});
}
});
授权人
import Ember from 'ember';
import Base from 'ember-simple-auth/authorizers/base';
export default Base.extend({
authorize: function(jqXHR, requestOptions) {
console.log(requestOptions);
console.log("---- Authorize ----");
var accessToken = this.get('session.content.secure.token');
console.log(this.get('session'));
if (this.get('session.isAuthenticated') && !Ember.isEmpty(accessToken)) {
jqXHR.setRequestHeader('Authorization', accessToken);
}
}
});
适配器
import Ember from 'ember';
import JSONAPIAdapter from 'ember-data/adapters/json-api';
import singularize from 'ember-inflector';
export default JSONAPIAdapter.extend({
namespace: '0',
host: 'http://localhost:9000',
session: Ember.inject.service('session'),
headers: Ember.computed('session.token', function() {
console.log("Sending header...");
return {
'Authorization': 'MYTOKEN'
};
}),
pathForType: function(type) {
return Ember.String.underscore(type);
//return singularize(type);
},
});
问题
我想知道如何在身份验证过程中获取存储的令牌,在适配器内部将编码的令牌注入 header Authorization
。
还有一个问题,什么时候叫授权人?
我假设您使用的是 ESA 1.0 或更高版本。然后,您不会在授权方的 authorize
方法中获得 jqXHR
,而是获得会话数据以及回调。
查看 DataAdapterMixin
and BaseAuthorizer
as well as the README 的文档以获取更多信息。