import { withSentryConfig } from "@sentry/nextjs"; import webpack from "webpack"; const mode = process.env.BUILD_MODE ?? "standalone"; console.log("[Next] build mode", mode); const disableChunk = !!process.env.DISABLE_CHUNK || mode === "export"; console.log("[Next] build with chunk: ", !disableChunk); /** @type {import('next').NextConfig} */ const nextConfig = { webpack(config) { config.module.rules.push({ test: /\.svg$/, use: ["@svgr/webpack"], }); if (disableChunk) { config.plugins.push( new webpack.optimize.LimitChunkCountPlugin({ maxChunks: 1 }), ); } config.resolve.fallback = { child_process: false, }; return config; }, output: mode, images: { unoptimized: mode === "export", }, experimental: { forceSwcTransforms: true, }, }; const CorsHeaders = [ { key: "Access-Control-Allow-Credentials", value: "true" }, { key: "Access-Control-Allow-Origin", value: "*" }, { key: "Access-Control-Allow-Methods", value: "*", }, { key: "Access-Control-Allow-Headers", value: "*", }, { key: "Access-Control-Max-Age", value: "86400", }, ]; if (mode !== "export") { nextConfig.headers = async () => { return [ { source: "/api/:path*", headers: CorsHeaders, }, ]; }; nextConfig.rewrites = async () => { const ret = [ // adjust for previous version directly using "/api/proxy/" as proxy base route // { // source: "/api/proxy/v1/:path*", // destination: "https://api.openai.com/v1/:path*", // }, { // https://{resource_name}.openai.azure.com/openai/deployments/{deploy_name}/chat/completions source: "/api/proxy/azure/:resource_name/deployments/:deploy_name/:path*", destination: "https://:resource_name.openai.azure.com/openai/deployments/:deploy_name/:path*", }, { source: "/api/proxy/google/:path*", destination: "https://generativelanguage.googleapis.com/:path*", }, { source: "/api/proxy/openai/:path*", destination: "https://api.openai.com/:path*", }, { source: "/api/proxy/anthropic/:path*", destination: "https://api.anthropic.com/:path*", }, { source: "/google-fonts/:path*", destination: "https://fonts.googleapis.com/:path*", }, { source: "/sharegpt", destination: "https://sharegpt.com/api/conversations", }, { source: "/api/proxy/alibaba/:path*", destination: "https://dashscope.aliyuncs.com/api/:path*", }, ]; return { beforeFiles: ret, }; }; } export default withSentryConfig(nextConfig, { // For all available options, see: // https://github.com/getsentry/sentry-webpack-plugin#options org: "kaiyan-medical", project: "kaiyangpt", // Only print logs for uploading source maps in CI silent: !process.env.CI, // For all available options, see: // https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/ // Upload a larger set of source maps for prettier stack traces (increases build time) widenClientFileUpload: true, // Automatically annotate React components to show their full name in breadcrumbs and session replay reactComponentAnnotation: { enabled: true, }, // Uncomment to route browser requests to Sentry through a Next.js rewrite to circumvent ad-blockers. // This can increase your server load as well as your hosting bill. // Note: Check that the configured route will not match with your Next.js middleware, otherwise reporting of client- // side errors will fail. // tunnelRoute: "/monitoring", // Hides source maps from generated client bundles hideSourceMaps: true, // Automatically tree-shake Sentry logger statements to reduce bundle size disableLogger: true, // Enables automatic instrumentation of Vercel Cron Monitors. (Does not yet work with App Router route handlers.) // See the following for more information: // https://docs.sentry.io/product/crons/ // https://vercel.com/docs/cron-jobs automaticVercelMonitors: true, });