From 01ab2b15e7f87ab15b854c1cfe383af32118d41d Mon Sep 17 00:00:00 2001 From: Ming Wang Date: Fri, 16 Feb 2024 14:29:41 -0500 Subject: [PATCH 1/4] add archives error page --- .../AllTargetsArchivedRecordingsTable.tsx | 37 +++++++++++++++++-- 1 file changed, 34 insertions(+), 3 deletions(-) diff --git a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx index df4d1b8bf..ebdf50248 100644 --- a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx +++ b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx @@ -13,6 +13,8 @@ * See the License for the specific language governing permissions and * limitations under the License. */ +import { ErrorView } from '@app/ErrorView/ErrorView'; +import { isAuthFail } from '@app/ErrorView/types'; import { ArchivedRecordingsTable } from '@app/Recordings/ArchivedRecordingsTable'; import { LoadingView } from '@app/Shared/Components/LoadingView'; import { Target, TargetDiscoveryEvent, NotificationCategory } from '@app/Shared/Services/api.types'; @@ -82,6 +84,7 @@ export const AllTargetsArchivedRecordingsTable: React.FC([]); const [expandedTargets, setExpandedTargets] = React.useState([] as Target[]); const [hideEmptyTargets, setHideEmptyTargets] = React.useState(true); + const [errorMessage, setErrorMessage] = React.useState(''); const [isLoading, setIsLoading] = React.useState(false); const addSubscription = useSubscriptions(); const [sortBy, getSortParams] = useSort(); @@ -122,6 +125,14 @@ export const AllTargetsArchivedRecordingsTable: React.FC { + setIsLoading(false); + setErrorMessage(error.message); + }, + [setIsLoading, setErrorMessage], + ); + /* eslint-disable @typescript-eslint/no-explicit-any */ const refreshArchivesForTargets = React.useCallback(() => { setIsLoading(true); @@ -145,9 +156,12 @@ export const AllTargetsArchivedRecordingsTable: React.FC v.data.targetNodes)) - .subscribe(handleArchivesForTargets), + .subscribe({ + next: handleArchivesForTargets, + error: handleError, + }), ); - }, [addSubscription, context.api, setIsLoading, handleArchivesForTargets]); + }, [addSubscription, context.api, setIsLoading, handleArchivesForTargets, handleError]); /* eslint-disable @typescript-eslint/no-explicit-any */ const getCountForNewTarget = React.useCallback( @@ -374,7 +388,24 @@ export const AllTargetsArchivedRecordingsTable: React.FC { + context.target.setAuthRetry(); + }, [context.target]); + + const isError = React.useMemo(() => errorMessage != '', [errorMessage]); + + if (isError) { + view = ( + <> + + + ); + } else if (isLoading) { view = ; } else if (!searchedArchivesForTargets.length) { view = ( From f516e29625c852fa7d5946cd41e6ba7f0d2e48f6 Mon Sep 17 00:00:00 2001 From: Ming Wang Date: Mon, 26 Feb 2024 14:23:33 -0500 Subject: [PATCH 2/4] cleanup --- src/app/Archives/AllTargetsArchivedRecordingsTable.tsx | 8 ++++---- src/app/Shared/Services/Api.service.tsx | 1 - 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx index ebdf50248..19c305f19 100644 --- a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx +++ b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx @@ -351,7 +351,7 @@ export const AllTargetsArchivedRecordingsTable: React.FC + {archiveCount} @@ -392,16 +392,16 @@ export const AllTargetsArchivedRecordingsTable: React.FC { context.target.setAuthRetry(); }, [context.target]); - + const isError = React.useMemo(() => errorMessage != '', [errorMessage]); if (isError) { view = ( <> ); diff --git a/src/app/Shared/Services/Api.service.tsx b/src/app/Shared/Services/Api.service.tsx index 0583bb946..d689f23a8 100644 --- a/src/app/Shared/Services/Api.service.tsx +++ b/src/app/Shared/Services/Api.service.tsx @@ -36,7 +36,6 @@ import { EventProbe, EventProbesResponse, Recording, - AssetJwtResponse, EventTemplate, RuleResponse, ArchivedRecording, From 4a0f9a95b1ef5aa486c8fd11b253da33eede3e53 Mon Sep 17 00:00:00 2001 From: Ming Wang Date: Mon, 26 Feb 2024 17:58:07 -0500 Subject: [PATCH 3/4] add fix in all archives view --- .../Archives/AllArchivedRecordingsTable.tsx | 45 +++++++++++++++++-- .../AllTargetsArchivedRecordingsTable.tsx | 19 +++++--- 2 files changed, 56 insertions(+), 8 deletions(-) diff --git a/src/app/Archives/AllArchivedRecordingsTable.tsx b/src/app/Archives/AllArchivedRecordingsTable.tsx index 5d405a627..96d021975 100644 --- a/src/app/Archives/AllArchivedRecordingsTable.tsx +++ b/src/app/Archives/AllArchivedRecordingsTable.tsx @@ -13,6 +13,8 @@ * See the License for the specific language governing permissions and * limitations under the License. */ +import { ErrorView } from '@app/ErrorView/ErrorView'; +import { authFailMessage, isAuthFail } from '@app/ErrorView/types'; import { ArchivedRecordingsTable } from '@app/Recordings/ArchivedRecordingsTable'; import { LoadingView } from '@app/Shared/Components/LoadingView'; import { ArchivedRecording, RecordingDirectory, Target, NotificationCategory } from '@app/Shared/Services/api.types'; @@ -78,6 +80,7 @@ export const AllArchivedRecordingsTable: React.FC([]); const [searchText, setSearchText] = React.useState(''); const [expandedDirectories, setExpandedDirectories] = React.useState<_RecordingDirectory[]>([]); + const [errorMessage, setErrorMessage] = React.useState(''); const [isLoading, setIsLoading] = React.useState(false); const addSubscription = useSubscriptions(); const [sortBy, getSortParams] = useSort(); @@ -90,12 +93,23 @@ export const AllArchivedRecordingsTable: React.FC { + setIsLoading(false); + setErrorMessage(error.message); + }, + [setIsLoading, setErrorMessage], + ); + const refreshDirectoriesAndCounts = React.useCallback(() => { setIsLoading(true); addSubscription( - context.api.doGet('fs/recordings', 'beta').subscribe(handleDirectoriesAndCounts), + context.api.doGet('fs/recordings', 'beta').subscribe({ + next: handleDirectoriesAndCounts, + error: handleError, + }), ); - }, [addSubscription, context.api, setIsLoading, handleDirectoriesAndCounts]); + }, [addSubscription, context.api, setIsLoading, handleDirectoriesAndCounts, handleError]); const handleSearchInput = React.useCallback( (searchInput: string) => { @@ -134,6 +148,14 @@ export const AllArchivedRecordingsTable: React.FC { + addSubscription( + context.target.authFailure().subscribe(() => { + setErrorMessage(authFailMessage); + }), + ); + }, [context, context.target, setErrorMessage, addSubscription]); + React.useEffect(() => { if (!context.settings.autoRefreshEnabled()) { return; @@ -262,7 +284,24 @@ export const AllArchivedRecordingsTable: React.FC { + context.target.setAuthRetry(); + }, [context.target]); + + const isError = React.useMemo(() => errorMessage != '', [errorMessage]); + + if (isError) { + view = ( + <> + + + ); + } else if (isLoading) { view = ; } else if (!searchedDirectories.length) { view = ( diff --git a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx index 19c305f19..e07ce82ed 100644 --- a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx +++ b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx @@ -14,7 +14,7 @@ * limitations under the License. */ import { ErrorView } from '@app/ErrorView/ErrorView'; -import { isAuthFail } from '@app/ErrorView/types'; +import { authFailMessage , isAuthFail } from '@app/ErrorView/types'; import { ArchivedRecordingsTable } from '@app/Recordings/ArchivedRecordingsTable'; import { LoadingView } from '@app/Shared/Components/LoadingView'; import { Target, TargetDiscoveryEvent, NotificationCategory } from '@app/Shared/Services/api.types'; @@ -108,6 +108,7 @@ export const AllTargetsArchivedRecordingsTable: React.FC { setIsLoading(false); + setErrorMessage(''); setArchivesForTargets( targetNodes.map((node) => { const target: Target = { @@ -122,7 +123,7 @@ export const AllTargetsArchivedRecordingsTable: React.FC { + addSubscription( + context.target.authFailure().subscribe(() => { + setErrorMessage(authFailMessage); + }), + ); + }, [context, context.target, setErrorMessage, addSubscription]); + React.useEffect(() => { if (!context.settings.autoRefreshEnabled()) { return; @@ -351,7 +360,7 @@ export const AllTargetsArchivedRecordingsTable: React.FC + {archiveCount} @@ -399,9 +408,9 @@ export const AllTargetsArchivedRecordingsTable: React.FC ); From 59f6d3e828cb1cbc745be5d8022fd01eceec8e9b Mon Sep 17 00:00:00 2001 From: Ming Wang Date: Tue, 27 Feb 2024 10:20:47 -0500 Subject: [PATCH 4/4] clean up --- src/app/Archives/AllTargetsArchivedRecordingsTable.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx index e07ce82ed..32a7a16b8 100644 --- a/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx +++ b/src/app/Archives/AllTargetsArchivedRecordingsTable.tsx @@ -14,7 +14,7 @@ * limitations under the License. */ import { ErrorView } from '@app/ErrorView/ErrorView'; -import { authFailMessage , isAuthFail } from '@app/ErrorView/types'; +import { authFailMessage, isAuthFail } from '@app/ErrorView/types'; import { ArchivedRecordingsTable } from '@app/Recordings/ArchivedRecordingsTable'; import { LoadingView } from '@app/Shared/Components/LoadingView'; import { Target, TargetDiscoveryEvent, NotificationCategory } from '@app/Shared/Services/api.types';