Skip to content

Commit

Permalink
Fix loading JWT when auth subject has no permissions (nightscout#7894)
Browse files Browse the repository at this point in the history
* Fix an issue reported by Milos, when a JWT is loaded with a subject that has no permissions

* Add unit test to cover this case
  • Loading branch information
sulkaharo authored Feb 18, 2023
1 parent 0f69153 commit 4e1f364
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 3 deletions.
2 changes: 1 addition & 1 deletion lib/authorization/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ function init (env, ctx) {
const token = env.enclave.signJWT({ accessToken: subject.accessToken });
const decoded = env.enclave.verifyJWT(token);

var roles = _.uniq(subject.roles.concat(defaultRoles));
var roles = subject.roles ? _.uniq(subject.roles.concat(defaultRoles)) : defaultRoles;

authorized = {
token
Expand Down
14 changes: 14 additions & 0 deletions tests/api.security.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,20 @@ describe('Security of REST API V1', function() {
});
});

it('Should return a JWT with default roles on broken role token', function(done) {
const now = Math.round(Date.now() / 1000) - 1;
request(self.app)
.get('/api/v2/authorization/request/' + self.token.noneSubject)
.expect(200)
.end(function(err, res) {
const decodedToken = jwt.decode(res.body.token);
decodedToken.accessToken.should.equal(self.token.noneSubject);
decodedToken.iat.should.be.aboveOrEqual(now);
decodedToken.exp.should.be.above(decodedToken.iat);
done();
});
});

it('Data load should succeed with API SECRET', function(done) {
request(self.app)
.get('/api/v1/entries.json')
Expand Down
9 changes: 7 additions & 2 deletions tests/fixtures/api3/authSubject.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ async function authSubject (authStorage) {
await createRole(authStorage, 'apiRead', 'api:*:read');
await createRole(authStorage, 'apiUpdate', 'api:*:update');
await createRole(authStorage, 'apiDelete', 'api:*:delete');
await createRole(authStorage, 'noneRole', '');

const subject = {
apiAll: await createTestSubject(authStorage, 'apiAll', ['apiAll']),
Expand All @@ -77,7 +78,9 @@ async function authSubject (authStorage) {
apiDelete: await createTestSubject(authStorage, 'apiDelete', ['apiDelete']),
admin: await createTestSubject(authStorage, 'admin', ['admin']),
readable: await createTestSubject(authStorage, 'readable', ['readable']),
denied: await createTestSubject(authStorage, 'denied', ['denied'])
denied: await createTestSubject(authStorage, 'denied', ['denied']),
noneSubject: await createTestSubject(authStorage, 'noneSubject', null),
noneRole: await createTestSubject(authStorage, 'noneRole', ['noneRole'])
};

const token = {
Expand All @@ -89,7 +92,9 @@ async function authSubject (authStorage) {
delete: subject.apiDelete.accessToken,
denied: subject.denied.accessToken,
adminAll: subject.admin.accessToken,
readable: subject.readable.accessToken
readable: subject.readable.accessToken,
noneSubject: subject.noneSubject.accessToken,
noneRole: subject.noneRole.accessToken
};

return {subject, token};
Expand Down

0 comments on commit 4e1f364

Please sign in to comment.