21af204683
* add namespace sidebar item * depend on ember-inflector directly * list-view and list-item components * fill out components and render empty namespaces page * list namespaces in access * add menu contextual component to list item * popup contextual component * full crud for namespaces * add namespaces service and picker component * split application and vault.cluster templates and controllers, add namespace query param, add namespace-picker to vault.namespace template * remove usage of href-to * remove ember-href-to from deps * add ember-responsive * start styling the picker and link to appropriate namespaces, use ember-responsive to render picker in different places based on the breakpoint * get query param working and save ns to authdata when authenticating, feed through ns in application adapter * move to observer on the controller for setting state on the service * set state in the beforeModel hook and clear the ember data model cache * nav to secrets on change and make error handling more resilient utilizing the method that atlas does to eagerly update URLs * add a list of sys endpoints in a helper * hide header elements if not in the root namespace * debounce namespace input on auth, fix 404 for auth method fetch, move auth method fetch to a task on the auth-form component and refretch on namespace change * fix display of supported engines and exclusion of sys and identity engines * don't fetch replication status if you're in a non-root namespace * hide seal sub-menu if not in the root namespace * don't autocomplete auth form inputs * always send some requests to the root namespace * use methodType and engineType instead of type in case there it is ns_ prefixed * use sys/internal/ui/namespaces to fetch the list in the dropdown * don't use model for namespace picker and always make the request to the token namespace * fix header handling for fetch calls * use namespace-reminder component on creation and edit forms throughout the application * add namespace-reminder to the console * add flat * add deepmerge for creating the tree in the menu * delayed rendering for animation timing * design and code feedback on the first round * white text in the namespace picker * fix namespace picker issues with root keys * separate path-to-tree * add tests for path-to-tree util * hide picker if you're in the root ns and you can't access other namespaces * show error message if you enter invalid characters for namespace path * return a different model if we dont have the namespaces feature and show upgrade page * if a token has a namespace_path, use that as the root user namespace and transition them there on login * use token namespace for user, but use specified namespace to log in * always renew tokens in the token namespace * fix edition-badge test
123 lines
3.3 KiB
JavaScript
123 lines
3.3 KiB
JavaScript
import ApplicationAdapter from './application';
|
|
import DS from 'ember-data';
|
|
import Ember from 'ember';
|
|
|
|
export default ApplicationAdapter.extend({
|
|
namespace: 'v1',
|
|
|
|
defaultSerializer: 'config',
|
|
|
|
urlFor(backend, section) {
|
|
const urls = {
|
|
tidy: `/v1/${backend}/tidy`,
|
|
urls: `/v1/${backend}/config/urls`,
|
|
crl: `/v1/${backend}/config/crl`,
|
|
};
|
|
return urls[section];
|
|
},
|
|
|
|
createOrUpdate(store, type, snapshot) {
|
|
const url = this.urlFor(snapshot.record.get('backend'), snapshot.adapterOptions.method);
|
|
const serializer = store.serializerFor(this.get('defaultSerializer'));
|
|
if (!url) {
|
|
return;
|
|
}
|
|
const data = snapshot.adapterOptions.fields.reduce((data, field) => {
|
|
let attr = snapshot.attr(field);
|
|
if (attr) {
|
|
serializer.serializeAttribute(snapshot, data, field, attr);
|
|
} else {
|
|
data[serializer.keyForAttribute(field)] = attr;
|
|
}
|
|
return data;
|
|
}, {});
|
|
return this.ajax(url, 'POST', { data });
|
|
},
|
|
|
|
createRecord() {
|
|
return this.createOrUpdate(...arguments);
|
|
},
|
|
|
|
updateRecord() {
|
|
return this.createOrUpdate(...arguments, 'update');
|
|
},
|
|
|
|
fetchSection(backendPath, section) {
|
|
const sections = ['cert', 'urls', 'crl', 'tidy'];
|
|
if (!section || !sections.includes(section)) {
|
|
const error = new DS.AdapterError();
|
|
Ember.set(error, 'httpStatus', 404);
|
|
throw error;
|
|
}
|
|
return this[`fetch${Ember.String.capitalize(section)}`](backendPath);
|
|
},
|
|
|
|
id(backendPath) {
|
|
return backendPath + '-config-ca';
|
|
},
|
|
|
|
fetchCert(backendPath) {
|
|
// these are all un-authed so using `fetch` directly works
|
|
const derURL = `/v1/${backendPath}/ca`;
|
|
const pemURL = `${derURL}/pem`;
|
|
const chainURL = `${derURL}_chain`;
|
|
|
|
return Ember.RSVP.hash({
|
|
backend: backendPath,
|
|
id: this.id(backendPath),
|
|
der: this.rawRequest(derURL, 'GET', { unauthenticated: true }).then(response => response.blob()),
|
|
pem: this.rawRequest(pemURL, 'GET', { unauthenticated: true }).then(response => response.text()),
|
|
ca_chain: this.rawRequest(chainURL, 'GET', { unauthenticated: true }).then(response => response.text()),
|
|
});
|
|
},
|
|
|
|
fetchUrls(backendPath) {
|
|
const url = `/v1/${backendPath}/config/urls`;
|
|
const id = this.id(backendPath);
|
|
return this.ajax(url, 'GET')
|
|
.then(resp => {
|
|
resp.id = id;
|
|
resp.backend = backendPath;
|
|
return resp;
|
|
})
|
|
.catch(e => {
|
|
if (e.httpStatus === 404) {
|
|
return Ember.RSVP.resolve({ id });
|
|
} else {
|
|
throw e;
|
|
}
|
|
});
|
|
},
|
|
|
|
fetchCrl(backendPath) {
|
|
const url = `/v1/${backendPath}/config/crl`;
|
|
const id = this.id(backendPath);
|
|
return this.ajax(url, 'GET')
|
|
.then(resp => {
|
|
resp.id = id;
|
|
resp.backend = backendPath;
|
|
return resp;
|
|
})
|
|
.catch(e => {
|
|
if (e.httpStatus === 404) {
|
|
return { id };
|
|
} else {
|
|
throw e;
|
|
}
|
|
});
|
|
},
|
|
|
|
fetchTidy(backendPath) {
|
|
const id = this.id(backendPath);
|
|
return Ember.RSVP.resolve({ id, backend: backendPath });
|
|
},
|
|
|
|
queryRecord(store, type, query) {
|
|
const { backend, section } = query;
|
|
return this.fetchSection(backend, section).then(resp => {
|
|
resp.backend = backend;
|
|
return resp;
|
|
});
|
|
},
|
|
});
|