1
0
Fork 0
mirror of https://github.com/portainer/portainer.git synced 2025-07-22 06:49:40 +02:00
portainer/app/react/edge/edge-stacks/ItemView/EnvironmentsDatatable/useLogsStatus.ts
Chaim Lev-Ari 1032b462b4
Some checks are pending
ci / build_images (map[arch:amd64 platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:amd64 platform:windows version:1809]) (push) Waiting to run
ci / build_images (map[arch:amd64 platform:windows version:ltsc2022]) (push) Waiting to run
ci / build_images (map[arch:arm platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:arm64 platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:ppc64le platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:s390x platform:linux version:]) (push) Waiting to run
ci / build_manifests (push) Blocked by required conditions
/ triage (push) Waiting to run
Lint / Run linters (push) Waiting to run
Test / test-server (map[arch:amd64 platform:windows version:ltsc2022]) (push) Waiting to run
Test / test-server (map[arch:arm64 platform:linux]) (push) Waiting to run
Test / test-client (push) Waiting to run
Test / test-server (map[arch:amd64 platform:linux]) (push) Waiting to run
Test / test-server (map[arch:amd64 platform:windows version:1809]) (push) Waiting to run
chore(deps): upgrade react-query to v4 [EE-6638] (#11041)
2024-04-14 17:54:25 +03:00

51 lines
1.3 KiB
TypeScript

import { useQuery } from '@tanstack/react-query';
import { EnvironmentId } from '@/react/portainer/environments/types';
import axios, { parseAxiosError } from '@/portainer/services/axios';
import { EdgeStack } from '@/react/edge/edge-stacks/types';
import { queryKeys } from '../../queries/query-keys';
export function logsStatusQueryKey(
edgeStackId: EdgeStack['Id'],
environmentId: EnvironmentId
) {
return [...queryKeys.item(edgeStackId), 'logs', environmentId] as const;
}
export function useLogsStatus(
edgeStackId: EdgeStack['Id'],
environmentId: EnvironmentId
) {
return useQuery(
logsStatusQueryKey(edgeStackId, environmentId),
() => getLogsStatus(edgeStackId, environmentId),
{
refetchInterval(status) {
if (status === 'pending') {
return 30 * 1000;
}
return false;
},
}
);
}
interface LogsStatusResponse {
status: 'collected' | 'idle' | 'pending';
}
async function getLogsStatus(
edgeStackId: EdgeStack['Id'],
environmentId: EnvironmentId
) {
try {
const { data } = await axios.get<LogsStatusResponse>(
`/edge_stacks/${edgeStackId}/logs/${environmentId}`
);
return data.status;
} catch (error) {
throw parseAxiosError(error as Error, 'Unable to retrieve logs status');
}
}