open-vault/ui/app/services/namespace.js
Jordan Reimer 52fe56ec87
Eslint prefer-const (#17864)
* adds prefer-const to eslint config and runs fixer

* reverts unintended change
2022-11-09 15:15:31 -08:00

64 lines
1.8 KiB
JavaScript

import { alias, equal } from '@ember/object/computed';
import Service, { inject as service } from '@ember/service';
import { task } from 'ember-concurrency';
const ROOT_NAMESPACE = '';
export default Service.extend({
store: service(),
auth: service(),
userRootNamespace: alias('auth.authData.userRootNamespace'),
//populated by the query param on the cluster route
path: '',
// list of namespaces available to the current user under the
// current namespace
accessibleNamespaces: null,
inRootNamespace: equal('path', ROOT_NAMESPACE),
setNamespace(path) {
if (!path) {
this.set('path', '');
return;
}
this.set('path', path);
},
findNamespacesForUser: task(function* () {
// uses the adapter and the raw response here since
// models get wiped when switching namespaces and we
// want to keep track of these separately
const store = this.store;
const adapter = store.adapterFor('namespace');
const userRoot = this.auth.authData.userRootNamespace;
try {
const ns = yield adapter.findAll(store, 'namespace', null, {
adapterOptions: {
forUser: true,
namespace: userRoot,
},
});
const keys = ns.data.keys || [];
this.set(
'accessibleNamespaces',
keys.map((n) => {
let fullNS = n;
// if the user's root isn't '', then we need to construct
// the paths so they connect to the user root to the list
// otherwise using the current ns to grab the correct leaf
// node in the graph doesn't work
if (userRoot) {
fullNS = `${userRoot}/${n}`;
}
return fullNS.replace(/\/$/, '');
})
);
} catch (e) {
//do nothing here
}
}).drop(),
reset() {
this.set('accessibleNamespaces', null);
},
});