mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-27 09:46:25 +02:00
add podcast api service
This commit is contained in:
parent
b2da1aa8e9
commit
de443ccee7
1 changed files with 68 additions and 0 deletions
68
surfsense_web/lib/apis/podcasts-api.service.ts
Normal file
68
surfsense_web/lib/apis/podcasts-api.service.ts
Normal file
|
|
@ -0,0 +1,68 @@
|
|||
import { baseApiService } from "./base-api.service";
|
||||
import {
|
||||
GeneratePodcastRequest,
|
||||
generatePodcastRequest,
|
||||
getPodcastByChatIdRequest,
|
||||
GetPodcastByChatIdRequest,
|
||||
Podcast,
|
||||
podcast,
|
||||
} from "@/contracts/types/podcast.types";
|
||||
import { ValidationError } from "../error";
|
||||
|
||||
class PodcastsApiService {
|
||||
getPodcastByChatId = async (request: GetPodcastByChatIdRequest) => {
|
||||
// Validate the request
|
||||
const parsedRequest = getPodcastByChatIdRequest.safeParse(request);
|
||||
|
||||
if (!parsedRequest.success) {
|
||||
console.error("Invalid request:", parsedRequest.error);
|
||||
|
||||
// Format a user frendly error message
|
||||
const errorMessage = parsedRequest.error.errors
|
||||
.map((err) => err.message)
|
||||
.join(", ");
|
||||
throw new ValidationError(`Invalid request: ${errorMessage}`);
|
||||
}
|
||||
|
||||
return baseApiService.get(
|
||||
`/api/v1/podcasts/by-chat/${request.chat_id}`,
|
||||
podcast
|
||||
);
|
||||
};
|
||||
|
||||
generatePodcast = async (request: GeneratePodcastRequest) => {
|
||||
// Validate the request
|
||||
const parsedRequest = generatePodcastRequest.safeParse(request);
|
||||
|
||||
if (!parsedRequest.success) {
|
||||
console.error("Invalid request:", parsedRequest.error);
|
||||
|
||||
// Format a user frendly error message
|
||||
const errorMessage = parsedRequest.error.errors
|
||||
.map((err) => err.message)
|
||||
.join(", ");
|
||||
throw new ValidationError(`Invalid request: ${errorMessage}`);
|
||||
}
|
||||
|
||||
return baseApiService.post(`/api/v1/podcasts/generate`, undefined, {
|
||||
body: request,
|
||||
});
|
||||
};
|
||||
|
||||
loadPodcast = async ({
|
||||
podcast,
|
||||
controller,
|
||||
}: {
|
||||
podcast: Podcast;
|
||||
controller?: AbortController;
|
||||
}) => {
|
||||
return await baseApiService.getBlob(
|
||||
`/api/v1/podcasts/${podcast.id}/stream`,
|
||||
{
|
||||
signal: controller?.signal,
|
||||
}
|
||||
);
|
||||
};
|
||||
}
|
||||
|
||||
export const podcastsApiService = new PodcastsApiService();
|
||||
Loading…
Add table
Add a link
Reference in a new issue