2023-01-24 00:49:16 +00:00
|
|
|
import { parsePkiCert } from 'vault/utils/parse-pki-cert';
|
2018-04-03 14:16:57 +00:00
|
|
|
import ApplicationAdapter from './application';
|
|
|
|
|
|
|
|
export default ApplicationAdapter.extend({
|
|
|
|
namespace: 'v1',
|
|
|
|
|
|
|
|
url(snapshot, action) {
|
|
|
|
const { backend, caType, type } = snapshot.attributes();
|
|
|
|
if (action === 'sign-intermediate') {
|
|
|
|
return `/v1/${backend}/root/sign-intermediate`;
|
|
|
|
}
|
|
|
|
if (action === 'set-signed-intermediate') {
|
|
|
|
return `/v1/${backend}/intermediate/set-signed`;
|
|
|
|
}
|
|
|
|
if (action === 'upload') {
|
|
|
|
return `/v1/${backend}/config/ca`;
|
|
|
|
}
|
|
|
|
return `/v1/${backend}/${caType}/generate/${type}`;
|
|
|
|
},
|
|
|
|
|
|
|
|
createRecordOrUpdate(store, type, snapshot, requestType) {
|
2018-09-25 16:28:26 +00:00
|
|
|
const serializer = store.serializerFor('application');
|
2018-04-03 14:16:57 +00:00
|
|
|
const isUpload = snapshot.attr('uploadPemBundle');
|
|
|
|
const isSetSignedIntermediate = snapshot.adapterOptions.method === 'setSignedIntermediate';
|
|
|
|
let action = snapshot.adapterOptions.method === 'signIntermediate' ? 'sign-intermediate' : null;
|
|
|
|
let data;
|
|
|
|
if (isUpload) {
|
|
|
|
action = 'upload';
|
|
|
|
data = { pem_bundle: snapshot.attr('pemBundle') };
|
|
|
|
} else if (isSetSignedIntermediate) {
|
|
|
|
action = 'set-signed-intermediate';
|
|
|
|
data = { certificate: snapshot.attr('certificate') };
|
|
|
|
} else {
|
|
|
|
data = serializer.serialize(snapshot, requestType);
|
2022-05-12 20:28:47 +00:00
|
|
|
|
|
|
|
// The type parameter is serialized but is part of the URL. This means
|
|
|
|
// we'll get an unknown parameter warning back from the server if we
|
|
|
|
// send it. Remove it instead.
|
|
|
|
delete data.type;
|
2018-04-03 14:16:57 +00:00
|
|
|
}
|
|
|
|
|
2021-12-17 03:44:29 +00:00
|
|
|
return this.ajax(this.url(snapshot, action), 'POST', { data }).then((response) => {
|
2018-04-03 14:16:57 +00:00
|
|
|
// uploading CA, setting signed intermediate cert, and attempting to generate
|
|
|
|
// a new CA if one exists, all return a 204
|
|
|
|
if (!response) {
|
|
|
|
response = {};
|
|
|
|
}
|
|
|
|
response.id = snapshot.id;
|
|
|
|
response.modelName = type.modelName;
|
2021-10-04 21:31:36 +00:00
|
|
|
// only parse if certificate is attached to response
|
|
|
|
if (response.data && response.data.certificate) {
|
2023-01-24 00:49:16 +00:00
|
|
|
const caCertMetadata = parsePkiCert(response.data);
|
2021-10-04 21:31:36 +00:00
|
|
|
const transformedResponse = { ...response, ...caCertMetadata };
|
|
|
|
store.pushPayload(type.modelName, transformedResponse);
|
|
|
|
} else {
|
|
|
|
store.pushPayload(type.modelName, response);
|
|
|
|
}
|
2018-04-03 14:16:57 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
createRecord() {
|
|
|
|
return this.createRecordOrUpdate(...arguments);
|
|
|
|
},
|
|
|
|
|
|
|
|
updateRecord() {
|
|
|
|
return this.createRecordOrUpdate(...arguments);
|
|
|
|
},
|
|
|
|
});
|