3172e74d7e
* KMSE: Key Model / Adapter / Serializer setup (#13638) * First pass model * KMS key adapter (create/update), serializer, model * Add last rotated and provider to key * KeyEdit secret-edit component, and more key model stuff * add formatDate param support to infotablerow * Add keymgmt key to routes and options-for-backend * Rename keymgmt-key to keymgmt/key * Add test, cleanup * Add mirage handler for kms * Address PR comments * KMS Providers (#13797) * adds pagination-controls component * adds kms provider model, adapter and serializer * adds kms provider-edit component * updates secrets routes to handle itemType query param for kms * updates kms key adapter to query by provider * adds tests for provider-edit component * refactors kms provider adapter to account for dynamic path * adds model-validations-helper util * removes keymgmt from supported-secret-backends * fixes issue generating url for fetching keys for a provider * updates modelType method on secret-edit route to accept options object as arg rather than transition * adds additional checks to ensure queryParams are defined in options object for modelType method * UI/keymgmt distribute key (#13840) * Add distribution details on key page, and empty states if no permissions * Allow search-select component to return object so parent can tell when new item was created * Add stringarray transform * Distribute component first pass * Refactor distribute component for use with internal object rather than ember-data model * Specific permission denied errors on key edit * Allow inline errors on search-select component * Style updates for form errors * Styling and error messages on distribute component * Allow block template on inline alert so we can add doc links * Add distribute action, flash messages, cleanup * Cleanup & Add tests * More cleanup * Address PR comments * Move disable operations logic to commponent class * KMSE Enable/Config (#14835) * adds keymgmt secrets engine as supported backend * adds comment to check on keymgmt as member of adp module * updates kms provider to use model-validations decorator * fixes lint errors and tests Co-authored-by: Chelsea Shaw <82459713+hashishaw@users.noreply.github.com>
64 lines
2.2 KiB
JavaScript
64 lines
2.2 KiB
JavaScript
import ApplicationAdapter from '../application';
|
|
import { all } from 'rsvp';
|
|
|
|
export default class KeymgmtKeyAdapter extends ApplicationAdapter {
|
|
namespace = 'v1';
|
|
listPayload = { data: { list: true } };
|
|
|
|
pathForType() {
|
|
// backend name prepended in buildURL method
|
|
return 'kms';
|
|
}
|
|
buildURL(modelName, id, snapshot, requestType, query) {
|
|
let url = super.buildURL(...arguments);
|
|
if (snapshot) {
|
|
url = url.replace('kms', `${snapshot.attr('backend')}/kms`);
|
|
} else if (query) {
|
|
url = url.replace('kms', `${query.backend}/kms`);
|
|
}
|
|
return url;
|
|
}
|
|
buildKeysURL(query) {
|
|
const url = this.buildURL('keymgmt/provider', null, null, 'query', query);
|
|
return `${url}/${query.provider}/key`;
|
|
}
|
|
async createRecord(store, { modelName }, snapshot) {
|
|
// create uses PUT instead of POST
|
|
const data = store.serializerFor(modelName).serialize(snapshot);
|
|
const url = this.buildURL(modelName, snapshot.attr('name'), snapshot, 'updateRecord');
|
|
return this.ajax(url, 'PUT', { data }).then(() => data);
|
|
}
|
|
findRecord(store, type, name) {
|
|
return super.findRecord(...arguments).then((resp) => {
|
|
resp.data = { ...resp.data, name };
|
|
return resp;
|
|
});
|
|
}
|
|
async query(store, type, query) {
|
|
const url = this.buildURL(type.modelName, null, null, 'query', query);
|
|
return this.ajax(url, 'GET', this.listPayload).then(async (resp) => {
|
|
// additional data is needed to fullfil the list view requirements
|
|
// pull in full record for listed items
|
|
const records = await all(
|
|
resp.data.keys.map((name) => this.findRecord(store, type, name, this._mockSnapshot(query.backend)))
|
|
);
|
|
resp.data.keys = records.map((record) => record.data);
|
|
return resp;
|
|
});
|
|
}
|
|
async queryRecord(store, type, query) {
|
|
return this.findRecord(store, type, query.id, this._mockSnapshot(query.backend));
|
|
}
|
|
|
|
// when using find in query or queryRecord overrides snapshot is not available
|
|
// ultimately buildURL requires the snapshot to pull the backend name for the dynamic segment
|
|
// since we have the backend value from the query generate a mock snapshot
|
|
_mockSnapshot(backend) {
|
|
return {
|
|
attr(prop) {
|
|
return prop === 'backend' ? backend : null;
|
|
},
|
|
};
|
|
}
|
|
}
|