mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Added role to identity token
Right now identity tokens can only be fetched by the Owner, which means they implicitly have the Owner role, but we want to expand that. The first step is adding the role to the token, and then we need to update each place which uses the token and add an assertion that the role is correct.
This commit is contained in:
parent
bfd3ee1209
commit
b3b9c89544
2 changed files with 17 additions and 2 deletions
|
@ -1,3 +1,4 @@
|
|||
const logging = require('@tryghost/logging');
|
||||
const settings = require('../../../shared/settings-cache');
|
||||
const urlUtils = require('../../../shared/url-utils');
|
||||
const jwt = require('jsonwebtoken');
|
||||
|
@ -13,7 +14,7 @@ const getKeyID = async () => {
|
|||
return key.kid;
|
||||
};
|
||||
|
||||
const sign = async (claims, options) => {
|
||||
const sign = async (claims, options = {}) => {
|
||||
const kid = await getKeyID();
|
||||
return jwt.sign(claims, dangerousPrivateKey, Object.assign({
|
||||
issuer,
|
||||
|
@ -32,7 +33,20 @@ const controller = {
|
|||
},
|
||||
permissions: true,
|
||||
async query(frame) {
|
||||
const token = await sign({sub: frame.user.get('email')});
|
||||
let role = null;
|
||||
try {
|
||||
await frame.user.load(['roles']);
|
||||
role = frame.user.relations.roles.toJSON()[0].name;
|
||||
} catch (err) {
|
||||
logging.warn('Could not load role for identity');
|
||||
}
|
||||
const claims = {
|
||||
sub: frame.user.get('email')
|
||||
};
|
||||
if (typeof role === 'string') {
|
||||
claims.role = role;
|
||||
}
|
||||
const token = await sign(claims);
|
||||
return {token};
|
||||
}
|
||||
}
|
||||
|
|
|
@ -60,6 +60,7 @@ describe('Identities API', function () {
|
|||
})
|
||||
.then((decoded) => {
|
||||
decoded.sub.should.equal('jbloggs@example.com');
|
||||
decoded.role.should.equal('Owner');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Add table
Reference in a new issue