open-vault/ui/app/adapters/pki-config.js
Jordan Reimer 5c2a08de6d
Ember Upgrade to 3.24 (#13443)
* Update browserslist

* Add browserslistrc

* ember-cli-update --to 3.26, fix conflicts

* Run codemodes that start with ember-*

* More codemods - before cp*

* More codemods (curly data-test-*)

* WIP ember-basic-dropdown template errors

* updates ember-basic-dropdown and related deps to fix build issues

* updates basic dropdown instances to new version API

* updates more deps -- ember-template-lint is working again

* runs no-implicit-this codemod

* creates and runs no-quoteless-attributes codemod

* runs angle brackets codemod

* updates lint:hbs globs to only touch hbs files

* removes yield only templates

* creates and runs deprecated args transform

* supresses lint error for invokeAction on LinkTo component

* resolves remaining ambiguous path lint errors

* resolves simple-unless lint errors

* adds warnings for deprecated tagName arg on LinkTo components

* adds warnings for remaining curly component invocation

* updates global template lint rules

* resolves remaining template lint errors

* disables some ember specfic lint rules that target pre octane patterns

* js lint fix run

* resolves remaining js lint errors

* fixes test run

* adds npm-run-all dep

* fixes test attribute issues

* fixes console acceptance tests

* fixes tests

* adds yield only wizard/tutorial-active template

* fixes more tests

* attempts to fix more flaky tests

* removes commented out settled in transit test

* updates deprecations workflow and adds initializer to filter by version

* updates flaky policies acl old test

* updates to flaky transit test

* bumps ember deps down to LTS version

* runs linters after main merge

* fixes client count tests after bad merge conflict fixes

* fixes client count history test

* more updates to lint config

* another round of hbs lint fixes after extending stylistic rule

* updates lint-staged commands

* removes indent eslint rule since it seems to break things

* fixes bad attribute in transform-edit-form template

* test fixes

* fixes enterprise tests

* adds changelog

* removes deprecated ember-concurrency-test-waiters dep and adds @ember/test-waiters

* flaky test fix

Co-authored-by: hashishaw <cshaw@hashicorp.com>
2021-12-16 20:44:29 -07:00

129 lines
3.5 KiB
JavaScript

import AdapterError from '@ember-data/adapter/error';
import { hash, resolve } from 'rsvp';
import { capitalize } from '@ember/string';
import { set } from '@ember/object';
import ApplicationAdapter from './application';
export default ApplicationAdapter.extend({
namespace: 'v1',
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(type.modelName);
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 }).then((resp) => {
let response = resp || {};
response.id = `${snapshot.record.get('backend')}-${snapshot.adapterOptions.method}`;
return response;
});
},
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 AdapterError();
set(error, 'httpStatus', 404);
throw error;
}
return this[`fetch${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 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 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 resolve({ id, backend: backendPath });
},
queryRecord(store, type, query) {
const { backend, section } = query;
return this.fetchSection(backend, section).then((resp) => {
resp.backend = backend;
return resp;
});
},
});