open-vault/ui/app/routes/application.js
Chelsea Shaw 5a05a1b39f
UI: Fix shape of response anticipated from feature-flags endpoint (#10684)
* Fix shape of response anticipated from feature-flags endpoint

* Add changelog
2021-01-11 14:44:52 -06:00

97 lines
3 KiB
JavaScript

import { inject as service } from '@ember/service';
import { next } from '@ember/runloop';
import Route from '@ember/routing/route';
import ControlGroupError from 'vault/lib/control-group-error';
export default Route.extend({
controlGroup: service(),
routing: service('router'),
wizard: service(),
namespaceService: service('namespace'),
featureFlagService: service('featureFlag'),
actions: {
willTransition() {
window.scrollTo(0, 0);
},
error(error, transition) {
let controlGroup = this.controlGroup;
if (error instanceof ControlGroupError) {
return controlGroup.handleError(error, transition);
}
if (error.path === '/v1/sys/wrapping/unwrap') {
controlGroup.unmarkTokenForUnwrap();
}
let router = this.routing;
//FIXME transition.intent likely needs to be replaced
let errorURL = transition.intent.url;
let { name, contexts, queryParams } = transition.intent;
// If the transition is internal to Ember, we need to generate the URL
// from the route parameters ourselves
if (!errorURL) {
try {
errorURL = router.urlFor(name, ...(contexts || []), { queryParams });
} catch (e) {
// If this fails, something weird is happening with URL transitions
errorURL = null;
}
}
// because we're using rootURL, we need to trim this from the front to get
// the ember-routeable url
if (errorURL) {
errorURL = errorURL.replace('/ui', '');
}
error.errorURL = errorURL;
// if we have queryParams, update the namespace so that the observer can fire on the controller
if (queryParams) {
this.controllerFor('vault.cluster').set('namespaceQueryParam', queryParams.namespace || '');
}
// Assuming we have a URL, push it into browser history and update the
// location bar for the user
if (errorURL) {
router.get('location').setURL(errorURL);
}
return true;
},
didTransition() {
let wizard = this.wizard;
if (wizard.get('currentState') !== 'active.feature') {
return true;
}
next(() => {
let applicationURL = this.routing.currentURL;
let activeRoute = this.routing.currentRouteName;
if (this.wizard.setURLAfterTransition) {
this.set('wizard.setURLAfterTransition', false);
this.set('wizard.expectedURL', applicationURL);
this.set('wizard.expectedRouteName', activeRoute);
}
let expectedRouteName = this.wizard.expectedRouteName;
if (this.routing.isActive(expectedRouteName) === false) {
wizard.transitionTutorialMachine(wizard.get('currentState'), 'PAUSE');
}
});
return true;
},
},
async beforeModel() {
const result = await fetch('/v1/sys/internal/ui/feature-flags', {
method: 'GET',
});
if (result.status === 200) {
const body = await result.json();
const flags = body.feature_flags || [];
this.featureFlagService.setFeatureFlags(flags);
}
},
});