5a05a1b39f
* Fix shape of response anticipated from feature-flags endpoint * Add changelog
97 lines
3 KiB
JavaScript
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);
|
|
}
|
|
},
|
|
});
|