Skip to content

Commit

Permalink
Change ability to check capabilities, not policy
Browse files Browse the repository at this point in the history
The API change in #6017 returns JSON that contains the
expanded policy, including all capabilities implied
by a policy. So even if you set `policy="write"`, you
get back a list of capabilities that includes `submit-job`.
There’s therefore no reason to examine the returned policy.
  • Loading branch information
backspace committed Aug 29, 2019
1 parent cb91553 commit 2a5e084
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 23 deletions.
7 changes: 1 addition & 6 deletions ui/app/abilities/job.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,8 @@ export default Ability.extend({
'[email protected]',
function() {
return this.rulesForActiveNamespace.some(rules => {
// TODO given that the API returns a fully-expanded set of rules,
// where just a policy word turns into an array of capabilities,
// maybe checking capabilities is the only necessity?
const policy = rules.Policy;
const capabilities = getWithDefault(rules, 'Capabilities', []);

return policy == 'write' || capabilities.includes('submit-job');
return capabilities.includes('submit-job');
});
}
),
Expand Down
8 changes: 4 additions & 4 deletions ui/tests/acceptance/jobs-list-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ module('Acceptance | jobs list', function(hooks) {
name: 'something',
rules: `
namespace "${job1.namespaceId}" {
policy = "write"
capabilities = ["list-jobs", "submit-job"]
}
namespace "${job2.namespaceId}" {
Expand All @@ -111,7 +111,7 @@ module('Acceptance | jobs list', function(hooks) {
Namespaces: [
{
Name: job1.namespaceId,
Policy: 'write',
Capabilities: ['list-jobs', 'submit-job'],
},
{
Name: job2.namespaceId,
Expand Down Expand Up @@ -141,7 +141,7 @@ module('Acceptance | jobs list', function(hooks) {
name: 'anonymous',
rules: `
namespace "default" {
policy = "write"
capabilities = ["list-jobs", "submit-job"]
}
node {
Expand All @@ -151,7 +151,7 @@ module('Acceptance | jobs list', function(hooks) {
Namespaces: [
{
Name: 'default',
Policy: 'write',
Capabilities: ['list-jobs', 'submit-job'],
},
],
},
Expand Down
26 changes: 13 additions & 13 deletions ui/tests/unit/abilities/job-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
assert.ok(jobAbility.canRun);
});

test('it permits job run for client tokens with a policy that has namespace write', function(assert) {
test('it permits job run for client tokens with a policy that has namespace submit-job', function(assert) {
const mockSystem = Service.extend({
activeNamespace: {
name: 'aNamespace',
Expand All @@ -31,7 +31,7 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
Namespaces: [
{
Name: 'aNamespace',
Policy: 'write',
Capabilities: ['submit-job'],
},
],
},
Expand All @@ -46,7 +46,7 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
assert.ok(jobAbility.canRun);
});

test('it permits job run for client tokens with a policy that has default namespace write and no policy for active namespace', function(assert) {
test('it permits job run for client tokens with a policy that has default namespace submit-job and no capabilities for active namespace', function(assert) {
const mockSystem = Service.extend({
activeNamespace: {
name: 'anotherNamespace',
Expand All @@ -61,11 +61,11 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
Namespaces: [
{
Name: 'aNamespace',
Policy: 'read',
Capabilities: [],
},
{
Name: 'default',
Policy: 'write',
Capabilities: ['submit-job'],
},
],
},
Expand All @@ -80,7 +80,7 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
assert.ok(jobAbility.canRun);
});

test('it blocks job run for client tokens with a policy that has namespace read', function(assert) {
test('it blocks job run for client tokens with a policy that has no submit-job capability', function(assert) {
const mockSystem = Service.extend({
activeNamespace: {
name: 'aNamespace',
Expand All @@ -95,7 +95,7 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
Namespaces: [
{
Name: 'aNamespace',
Policy: 'read',
Capabilities: ['list-jobs'],
},
],
},
Expand Down Expand Up @@ -125,27 +125,27 @@ module('Unit | Ability | job run FIXME just for ease of filtering', function(hoo
Namespaces: [
{
Name: 'production-*',
Policy: 'write',
Capabilities: ['submit-job'],
},
{
Name: 'production-api',
Policy: 'write',
Capabilities: ['submit-job'],
},
{
Name: 'production-web',
Policy: 'deny',
Capabilities: [],
},
{
Name: '*-suffixed',
Policy: 'write',
Capabilities: ['submit-job'],
},
{
Name: '*-more-suffixed',
Policy: 'deny',
Capabilities: [],
},
{
Name: '*-abc-*',
Policy: 'write',
Capabilities: ['submit-job'],
},
],
},
Expand Down

0 comments on commit 2a5e084

Please sign in to comment.