52fe56ec87
* adds prefer-const to eslint config and runs fixer * reverts unintended change
67 lines
1.8 KiB
JavaScript
67 lines
1.8 KiB
JavaScript
import { inject as service } from '@ember/service';
|
|
import Component from '@ember/component';
|
|
import { task } from 'ember-concurrency';
|
|
import { underscore } from 'vault/helpers/underscore';
|
|
|
|
export default Component.extend({
|
|
store: service(),
|
|
flashMessages: service(),
|
|
router: service(),
|
|
|
|
// Public API - either 'entity' or 'group'
|
|
// this will determine which adapter is used to make the lookup call
|
|
type: 'entity',
|
|
|
|
param: 'alias name',
|
|
paramValue: null,
|
|
aliasMountAccessor: null,
|
|
|
|
authMethods: null,
|
|
|
|
init() {
|
|
this._super(...arguments);
|
|
this.store.findAll('auth-method').then((methods) => {
|
|
this.set('authMethods', methods);
|
|
this.set('aliasMountAccessor', methods.get('firstObject.accessor'));
|
|
});
|
|
},
|
|
|
|
adapter() {
|
|
const type = this.type;
|
|
const store = this.store;
|
|
return store.adapterFor(`identity/${type}`);
|
|
},
|
|
|
|
data() {
|
|
const { param, paramValue, aliasMountAccessor } = this;
|
|
const data = {};
|
|
|
|
data[underscore([param])] = paramValue;
|
|
if (param === 'alias name') {
|
|
data.alias_mount_accessor = aliasMountAccessor;
|
|
}
|
|
return data;
|
|
},
|
|
|
|
lookup: task(function* () {
|
|
const flash = this.flashMessages;
|
|
const type = this.type;
|
|
const store = this.store;
|
|
const { param, paramValue } = this;
|
|
let response;
|
|
try {
|
|
response = yield this.adapter().lookup(store, this.data());
|
|
} catch (err) {
|
|
flash.danger(
|
|
`We encountered an error attempting the ${type} lookup: ${err.message || err.errors.join('')}.`
|
|
);
|
|
return;
|
|
}
|
|
if (response) {
|
|
return this.router.transitionTo('vault.cluster.access.identity.show', response.id, 'details');
|
|
} else {
|
|
flash.danger(`We were unable to find an identity ${type} with a "${param}" of "${paramValue}".`);
|
|
}
|
|
}),
|
|
});
|