5c2a08de6d
* 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>
129 lines
3.5 KiB
JavaScript
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;
|
|
});
|
|
},
|
|
});
|