MDL-80241 grade: update user filtering by matched properties.

Invert the previous logic, which maintained a "banned" list of
fields, to instead only try to filter on those fields that are
explicitly defined to support that.
This commit is contained in:
Paul Holden 2024-01-18 19:57:56 +00:00
parent d3ad77e476
commit 0a66e9a3f8
No known key found for this signature in database
GPG Key ID: A81A96D6045F6164
3 changed files with 9 additions and 7 deletions

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -30,7 +30,6 @@ export default class UserSearch extends search_combobox {
courseID; courseID;
groupID; groupID;
bannedFilterFields = ['profileimageurlsmall', 'profileimageurl', 'id', 'link', 'matchingField', 'matchingFieldName'];
// A map of user profile field names that is human-readable. // A map of user profile field names that is human-readable.
profilestringmap = null; profilestringmap = null;
@ -118,8 +117,9 @@ export default class UserSearch extends search_combobox {
* @returns {Array} The users that match the given criteria. * @returns {Array} The users that match the given criteria.
*/ */
async filterDataset(filterableData) { async filterDataset(filterableData) {
const stringMap = await this.getStringMap();
return filterableData.filter((user) => Object.keys(user).some((key) => { return filterableData.filter((user) => Object.keys(user).some((key) => {
if (user[key] === "" || user[key] === null || this.bannedFilterFields.includes(key)) { if (user[key] === "" || user[key] === null || !stringMap.get(key)) {
return false; return false;
} }
return user[key].toString().toLowerCase().includes(this.getPreppedSearchTerm()); return user[key].toString().toLowerCase().includes(this.getPreppedSearchTerm());
@ -145,9 +145,10 @@ export default class UserSearch extends search_combobox {
const preppedSearchTerm = this.getPreppedSearchTerm(); const preppedSearchTerm = this.getPreppedSearchTerm();
const searchTerm = this.getSearchTerm(); const searchTerm = this.getSearchTerm();
if (valueString.includes(preppedSearchTerm) && !this.bannedFilterFields.includes(key)) { // Ensure we match only on expected keys.
// Ensure we have a good string, otherwise fallback to the key. const matchingFieldName = stringMap.get(key);
user.matchingFieldName = stringMap.get(key) ?? key; if (matchingFieldName && valueString.includes(preppedSearchTerm)) {
user.matchingFieldName = matchingFieldName;
// Safely prepare our matching results. // Safely prepare our matching results.
const escapedValueString = valueString.replace(/</g, '&lt;'); const escapedValueString = valueString.replace(/</g, '&lt;');
@ -282,6 +283,7 @@ export default class UserSearch extends search_combobox {
if (!this.profilestringmap) { if (!this.profilestringmap) {
const requiredStrings = [ const requiredStrings = [
'username', 'username',
'fullname',
'firstname', 'firstname',
'lastname', 'lastname',
'email', 'email',