mirror of
https://github.com/documenso/documenso.git
synced 2025-11-09 20:12:31 +10:00
40 lines
1.4 KiB
TypeScript
40 lines
1.4 KiB
TypeScript
import type { Context } from 'hono';
|
|
|
|
import { API_V2_BETA_URL, API_V2_URL } from '@documenso/lib/constants/app';
|
|
import { AppError, genericErrorCodeToTrpcErrorCodeMap } from '@documenso/lib/errors/app-error';
|
|
import { createTrpcContext } from '@documenso/trpc/server/context';
|
|
import { appRouter } from '@documenso/trpc/server/router';
|
|
import { createOpenApiFetchHandler } from '@documenso/trpc/utils/openapi-fetch-handler';
|
|
import { handleTrpcRouterError } from '@documenso/trpc/utils/trpc-error-handler';
|
|
|
|
type OpenApiTrpcServerHandlerOptions = {
|
|
isBeta: boolean;
|
|
};
|
|
|
|
export const openApiTrpcServerHandler = async (
|
|
c: Context,
|
|
{ isBeta }: OpenApiTrpcServerHandlerOptions,
|
|
) => {
|
|
return createOpenApiFetchHandler<typeof appRouter>({
|
|
endpoint: isBeta ? API_V2_BETA_URL : API_V2_URL,
|
|
router: appRouter,
|
|
createContext: async () => createTrpcContext({ c, requestSource: 'apiV2' }),
|
|
req: c.req.raw,
|
|
onError: (opts) => handleTrpcRouterError(opts, 'apiV2'),
|
|
// Not sure why we need to do this since we handle it in errorFormatter which runs after this.
|
|
responseMeta: (opts) => {
|
|
if (opts.errors[0]?.cause instanceof AppError) {
|
|
const appError = AppError.parseError(opts.errors[0].cause);
|
|
|
|
const httpStatus = genericErrorCodeToTrpcErrorCodeMap[appError.code]?.status ?? 400;
|
|
|
|
return {
|
|
status: httpStatus,
|
|
};
|
|
}
|
|
|
|
return {};
|
|
},
|
|
});
|
|
};
|