mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-26 17:26:23 +02:00
refactor podcast api calls
This commit is contained in:
parent
7223a7b04d
commit
5361290315
10 changed files with 288 additions and 377 deletions
|
|
@ -1,68 +1,58 @@
|
|||
import { baseApiService } from "./base-api.service";
|
||||
import {
|
||||
GeneratePodcastRequest,
|
||||
generatePodcastRequest,
|
||||
getPodcastByChatIdRequest,
|
||||
GetPodcastByChatIdRequest,
|
||||
Podcast,
|
||||
podcast,
|
||||
type GeneratePodcastRequest,
|
||||
type GetPodcastByChatIdRequest,
|
||||
generatePodcastRequest,
|
||||
getPodcastByChatIdRequest,
|
||||
type Podcast,
|
||||
podcast,
|
||||
} from "@/contracts/types/podcast.types";
|
||||
import { ValidationError } from "../error";
|
||||
import { baseApiService } from "./base-api.service";
|
||||
|
||||
class PodcastsApiService {
|
||||
getPodcastByChatId = async (request: GetPodcastByChatIdRequest) => {
|
||||
// Validate the request
|
||||
const parsedRequest = getPodcastByChatIdRequest.safeParse(request);
|
||||
getPodcastByChatId = async (request: GetPodcastByChatIdRequest) => {
|
||||
// Validate the request
|
||||
const parsedRequest = getPodcastByChatIdRequest.safeParse(request);
|
||||
|
||||
if (!parsedRequest.success) {
|
||||
console.error("Invalid request:", parsedRequest.error);
|
||||
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}`);
|
||||
}
|
||||
// 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
|
||||
);
|
||||
};
|
||||
return baseApiService.get(`/api/v1/podcasts/by-chat/${request.chat_id}`, podcast);
|
||||
};
|
||||
|
||||
generatePodcast = async (request: GeneratePodcastRequest) => {
|
||||
// Validate the request
|
||||
const parsedRequest = generatePodcastRequest.safeParse(request);
|
||||
generatePodcast = async (request: GeneratePodcastRequest) => {
|
||||
// Validate the request
|
||||
const parsedRequest = generatePodcastRequest.safeParse(request);
|
||||
|
||||
if (!parsedRequest.success) {
|
||||
console.error("Invalid request:", parsedRequest.error);
|
||||
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}`);
|
||||
}
|
||||
// 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,
|
||||
});
|
||||
};
|
||||
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,
|
||||
}
|
||||
);
|
||||
};
|
||||
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