-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Filter Auth methods by name or type #20747
Changes from 6 commits
86145eb
2020f62
cd1fcf3
b611987
a42301b
3494668
c0c24ed
75f6420
9234e82
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
```release-note:improvement | ||
ui: Add filtering by auth type and auth name to the Authentication Method list view. | ||
``` |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,22 +4,72 @@ | |
*/ | ||
|
||
import Controller from '@ember/controller'; | ||
import { task } from 'ember-concurrency'; | ||
import { dropTask } from 'ember-concurrency'; | ||
import { inject as service } from '@ember/service'; | ||
import { action } from '@ember/object'; | ||
import { tracked } from '@glimmer/tracking'; | ||
|
||
export default Controller.extend({ | ||
flashMessages: service(), | ||
export default class VaultClusterAccessMethodsController extends Controller { | ||
@service flashMessages; | ||
|
||
queryParams: { | ||
page: 'page', | ||
pageFilter: 'pageFilter', | ||
}, | ||
@tracked authMethodOptions = []; | ||
@tracked selectedAuthType = null; | ||
@tracked selectedAuthName = null; | ||
|
||
page: 1, | ||
pageFilter: null, | ||
filter: null, | ||
queryParams = ['page, pageFilter']; | ||
|
||
disableMethod: task(function* (method) { | ||
page = 1; | ||
pageFilter = null; | ||
filter = null; | ||
|
||
get authMethodList() { | ||
// return an options list to filter by engine type, ex: 'kv' | ||
if (this.selectedAuthType) { | ||
// check first if the user has also filtered by name. | ||
if (this.selectedAuthName) { | ||
return this.model.filter((method) => this.selectedAuthName === method.id); | ||
} | ||
// otherwise filter by auth type | ||
return this.model.filter((method) => this.selectedAuthType === method.type); | ||
} | ||
// return an options list to filter by auth name, ex: 'my-userpass' | ||
if (this.selectedAuthName) { | ||
return this.model.filter((method) => this.selectedAuthName === method.id); | ||
} | ||
// no filters, return full sorted list. | ||
return this.model; | ||
} | ||
|
||
get authMethodArrayByType() { | ||
const arrayOfAllAuthTypes = this.authMethodList.map((modelObject) => modelObject.type); | ||
// filter out repeated auth types (e.g. [userpass, userpass] => [userpass]) | ||
const arrayOfUniqueAuthTypes = [...new Set(arrayOfAllAuthTypes)]; | ||
|
||
return arrayOfUniqueAuthTypes.map((authType) => ({ | ||
name: authType, | ||
id: authType, | ||
})); | ||
} | ||
|
||
get authMethodArrayByName() { | ||
return this.authMethodList.map((modelObject) => ({ | ||
name: modelObject.id, | ||
id: modelObject.id, | ||
})); | ||
} | ||
|
||
@action | ||
filterAuthType([type]) { | ||
this.selectedAuthType = type; | ||
} | ||
|
||
@action | ||
filterAuthName([name]) { | ||
this.selectedAuthName = name; | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Not a blocker but it seems like some of this filtering logic could be moved to a decorator or utility so that it can be shared since this is the second instance of this functionality. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good thought. The only issue is that the sorted list that is passed around is pretty unique. For KV we need to combine and filter two lists (supported and unsupported) and here we're just using the this.model and filtering there. With KV the unique list situation meant a couple of extra lines of code not seen here. But it's a great consideration. I'll think about this with the KV work as the new models may allow us to standardize the list. |
||
|
||
@dropTask | ||
*disableMethod(method) { | ||
const { type, path } = method; | ||
try { | ||
yield method.destroyRecord(); | ||
|
@@ -29,5 +79,5 @@ export default Controller.extend({ | |
`There was an error disabling Auth Method at ${path}: ${err.errors.join(' ')}.` | ||
); | ||
} | ||
}).drop(), | ||
}); | ||
} | ||
} |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ✨ There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. couldn't help myself. I opened the file and had to glimmerize. |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Noticed I needed to clean this up from my last test writing for the secret engine filtering. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm curious if we should be filtering by both type and name if they are both set? I think there could be a case where the same name is used for different types.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For secret engines you can't have the same name as used by another secret engine. We do some validation work on that and say as much. And if they passed validation, then the API would return the same error.
But great question for auth methods. I had to check if this was the same. Turns out it is. We don't do any validation but we do return the API error.
So names are individualized across all auth methods. Which I believes answers your question?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok good to know thanks! Maybe nice to add a comment in there stating as much so it's clear why type is ignored if name is set.