open-vault/ui/app/components/wizard/features-selection.js

151 lines
4.3 KiB
JavaScript

import { inject as service } from '@ember/service';
import Component from '@ember/component';
import { computed } from '@ember/object';
import { FEATURE_MACHINE_TIME } from 'vault/helpers/wizard-constants';
import { htmlSafe } from '@ember/template';
export default Component.extend({
wizard: service(),
version: service(),
permissions: service(),
init() {
this._super(...arguments);
this.maybeHideFeatures();
},
maybeHideFeatures() {
let features = this.get('allFeatures');
features.forEach(feat => {
feat.disabled = this.doesNotHavePermission(feat.requiredPermissions);
});
if (this.get('showReplication') === false) {
let feature = this.get('allFeatures').findBy('key', 'replication');
feature.show = false;
}
},
doesNotHavePermission(requiredPermissions) {
// requiredPermissions is an object of paths and capabilities defined within allFeatures.
// the expected shape is:
// {
// 'example/path': ['capability'],
// 'second/example/path': ['update', 'sudo'],
// }
return !Object.keys(requiredPermissions).every(path => {
return this.permissions.hasPermission(path, requiredPermissions[path]);
});
},
estimatedTime: computed('selectedFeatures', function() {
let time = 0;
for (let feature of Object.keys(FEATURE_MACHINE_TIME)) {
if (this.selectedFeatures.includes(feature)) {
time += FEATURE_MACHINE_TIME[feature];
}
}
return time;
}),
selectProgress: computed('selectedFeatures', function() {
let bar = this.selectedFeatures.map(feature => {
return { style: htmlSafe('width:0%;'), completed: false, showIcon: true, feature: feature };
});
if (bar.length === 0) {
bar = [{ style: htmlSafe('width:0%;'), showIcon: false }];
}
return bar;
}),
allFeatures: computed(function() {
return [
{
key: 'secrets',
name: 'Secrets',
steps: ['Enabling a Secrets Engine', 'Adding a secret'],
selected: false,
show: true,
disabled: false,
requiredPermissions: {
'sys/mounts/example': ['update'],
},
},
{
key: 'authentication',
name: 'Authentication',
steps: ['Enabling an Auth Method', 'Managing your Auth Method'],
selected: false,
show: true,
disabled: false,
requiredPermissions: {
'sys/auth': ['read'],
'sys/auth/foo': ['update', 'sudo'],
},
},
{
key: 'policies',
name: 'Policies',
steps: [
'Choosing a policy type',
'Creating a policy',
'Deleting your policy',
'Other types of policies',
],
selected: false,
show: true,
disabled: false,
requiredPermissions: {
'sys/policies/acl': ['list'],
},
},
{
key: 'replication',
name: 'Replication',
steps: ['Setting up replication', 'Your cluster information'],
selected: false,
show: true,
disabled: false,
requiredPermissions: {
'sys/replication/performance/primary/enable': ['update'],
'sys/replication/dr/primary/enable': ['update'],
},
},
{
key: 'tools',
name: 'Tools',
steps: ['Wrapping data', 'Lookup wrapped data', 'Rewrapping your data', 'Unwrapping your data'],
selected: false,
show: true,
disabled: false,
requiredPermissions: {
'sys/wrapping/wrap': ['update'],
'sys/wrapping/lookup': ['update'],
'sys/wrapping/unwrap': ['update'],
'sys/wrapping/rewrap': ['update'],
},
},
];
}),
showReplication: computed('version.{hasPerfReplication,hasDRReplication}', function() {
return this.get('version.hasPerfReplication') || this.get('version.hasDRReplication');
}),
selectedFeatures: computed('allFeatures.@each.selected', function() {
return this.get('allFeatures')
.filterBy('selected')
.mapBy('key');
}),
cannotStartWizard: computed('selectedFeatures', function() {
return !this.get('selectedFeatures').length;
}),
actions: {
saveFeatures() {
let wizard = this.get('wizard');
wizard.saveFeatures(this.get('selectedFeatures'));
wizard.transitionTutorialMachine('active.select', 'CONTINUE');
},
},
});