open-vault/ui/app/routes/vault/cluster/settings/auth/configure/section.js

81 lines
2.2 KiB
JavaScript
Raw Normal View History

2018-04-03 14:16:57 +00:00
import Ember from 'ember';
import DS from 'ember-data';
import UnloadModelRoute from 'vault/mixins/unload-model-route';
const { RSVP } = Ember;
export default Ember.Route.extend(UnloadModelRoute, {
modelPath: 'model.model',
modelType(backendType, section) {
const MODELS = {
'aws-client': 'auth-config/aws/client',
'aws-identity-whitelist': 'auth-config/aws/identity-whitelist',
'aws-roletag-blacklist': 'auth-config/aws/roletag-blacklist',
'github-configuration': 'auth-config/github',
'gcp-configuration': 'auth-config/gcp',
'kubernetes-configuration': 'auth-config/kubernetes',
'ldap-configuration': 'auth-config/ldap',
'okta-configuration': 'auth-config/okta',
'radius-configuration': 'auth-config/radius',
};
return MODELS[`${backendType}-${section}`];
},
model(params) {
const backend = this.modelFor('vault.cluster.settings.auth.configure');
const { section_name: section } = params;
if (section === 'options') {
return RSVP.hash({
model: backend,
section,
});
}
const modelType = this.modelType(backend.get('type'), section);
if (!modelType) {
const error = new DS.AdapterError();
Ember.set(error, 'httpStatus', 404);
throw error;
}
const model = this.store.peekRecord(modelType, backend.id);
if (model) {
return RSVP.hash({
model,
section,
});
}
return this.store
.findRecord(modelType, backend.id)
.then(config => {
config.set('backend', backend);
return RSVP.hash({
model: config,
section,
});
})
.catch(e => {
let config;
// if you haven't saved a config, the API 404s, so create one here to edit and return it
if (e.httpStatus === 404) {
config = this.store.createRecord(modelType, {
id: backend.id,
});
config.set('backend', backend);
return RSVP.hash({
model: config,
section,
});
}
throw e;
});
},
actions: {
willTransition() {
if (this.currentModel.model.constructor.modelName !== 'auth-method') {
this.unloadModel();
return true;
}
},
},
});