Skip to content

Commit

Permalink
Connect: fix access request searching logic
Browse files Browse the repository at this point in the history
  • Loading branch information
kimlisa committed Jun 18, 2024
1 parent 5af7106 commit 13b6f35
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 18 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
/**
* Teleport
* Copyright (C) 2024 Gravitational, Inc.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/

import { AccessRequest, Resource } from 'shared/services/accessRequests';

export function requestMatcher(
targetValue: any,
searchValue: string,
propName: keyof AccessRequest & string
) {
if (propName === 'roles') {
return targetValue.some((role: string) =>
role.toUpperCase().includes(searchValue)
);
}

if (propName === 'resources') {
return targetValue.some((r: Resource) =>
Object.values(r.id)
.concat(Object.values(r.details.hostname || {}))
.concat(Object.values(r.details.friendlyName || {}))
.some(v => v.toUpperCase().includes(searchValue))
);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ import {
BlockedByStartTimeButton,
ButtonPromotedInfo,
} from 'shared/components/AccessRequests/Shared/Shared';
import { requestMatcher } from 'shared/components/AccessRequests/NewRequest/matcher';

export function RequestList({
attempt,
Expand Down Expand Up @@ -142,24 +143,6 @@ export function RequestList({
);
}

function requestMatcher(
targetValue: any,
searchValue: string,
propName: keyof AccessRequest & string
) {
if (propName === 'roles') {
return targetValue.some((role: string) =>
role.toUpperCase().includes(searchValue)
);
}

if (propName === 'resources') {
return targetValue.some((r: any) =>
Object.keys(r).some(k => r[k].toUpperCase().includes(searchValue))
);
}
}

const renderActionCell = (
request: AccessRequest,
flags: RequestFlags,
Expand Down

0 comments on commit 13b6f35

Please sign in to comment.