2024-12-15 15:53:02 +01:00
|
|
|
import dayjs from "dayjs";
|
|
|
|
|
|
|
|
|
|
import type { IntegrationKindByCategory } from "@homarr/definitions";
|
2025-03-04 21:17:35 +01:00
|
|
|
import { createIntegrationAsync } from "@homarr/integrations";
|
2024-12-15 15:53:02 +01:00
|
|
|
import type { TdarrQueue, TdarrStatistics, TdarrWorker } from "@homarr/integrations";
|
|
|
|
|
|
|
|
|
|
import { createCachedIntegrationRequestHandler } from "./lib/cached-integration-request-handler";
|
|
|
|
|
|
|
|
|
|
export const mediaTranscodingRequestHandler = createCachedIntegrationRequestHandler<
|
|
|
|
|
{ queue: TdarrQueue; workers: TdarrWorker[]; statistics: TdarrStatistics },
|
|
|
|
|
IntegrationKindByCategory<"mediaTranscoding">,
|
|
|
|
|
{ pageOffset: number; pageSize: number }
|
|
|
|
|
>({
|
|
|
|
|
queryKey: "mediaTranscoding",
|
|
|
|
|
cacheDuration: dayjs.duration(5, "minutes"),
|
|
|
|
|
async requestAsync(integration, input) {
|
2025-03-04 21:17:35 +01:00
|
|
|
const integrationInstance = await createIntegrationAsync(integration);
|
2024-12-15 15:53:02 +01:00
|
|
|
return {
|
|
|
|
|
queue: await integrationInstance.getQueueAsync(input.pageOffset, input.pageSize),
|
|
|
|
|
workers: await integrationInstance.getWorkersAsync(),
|
|
|
|
|
statistics: await integrationInstance.getStatisticsAsync(),
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
});
|