2023-06-25 05:38:43 +00:00
|
|
|
import { useQuery } from 'react-query';
|
|
|
|
|
|
|
|
import { withError } from '@/react-tools/react-query';
|
|
|
|
import axios, { parseAxiosError } from '@/portainer/services/axios';
|
|
|
|
|
|
|
|
import { EdgeStack } from '../types';
|
|
|
|
|
|
|
|
import { buildUrl } from './buildUrl';
|
|
|
|
import { queryKeys } from './query-keys';
|
|
|
|
|
2023-07-13 20:55:52 +00:00
|
|
|
export function useEdgeStack(
|
|
|
|
id?: EdgeStack['Id'],
|
|
|
|
{
|
|
|
|
refetchInterval,
|
|
|
|
}: {
|
|
|
|
/**
|
|
|
|
* If set to a number, the query will continuously refetch at this frequency in milliseconds. If set to a function, the function will be executed with the latest data and query to compute a frequency Defaults to false.
|
|
|
|
*/
|
|
|
|
refetchInterval?:
|
|
|
|
| number
|
|
|
|
| false
|
|
|
|
| ((data?: Awaited<ReturnType<typeof getEdgeStack>>) => false | number);
|
|
|
|
} = {}
|
|
|
|
) {
|
2023-06-25 05:38:43 +00:00
|
|
|
return useQuery(id ? queryKeys.item(id) : [], () => getEdgeStack(id), {
|
|
|
|
...withError('Failed loading Edge stack'),
|
|
|
|
enabled: !!id,
|
2023-07-13 20:55:52 +00:00
|
|
|
refetchInterval,
|
2023-06-25 05:38:43 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function getEdgeStack(id?: EdgeStack['Id']) {
|
|
|
|
if (!id) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
const { data } = await axios.get<EdgeStack>(buildUrl(id));
|
|
|
|
return data;
|
|
|
|
} catch (e) {
|
|
|
|
throw parseAxiosError(e as Error);
|
|
|
|
}
|
|
|
|
}
|