mirror of
https://github.com/Significant-Gravitas/AutoGPT.git
synced 2026-01-09 07:08:09 -05:00
- Updated Next.js configuration to set body size limits for server
actions and API routes.
- Enhanced error handling in the API client to provide user-friendly
messages for file size errors.
- Added user-friendly error messages for 413 Payload Too Large responses
in API error parsing.
These changes ensure that file uploads are consistent with backend
limits and improve user experience during uploads.
### Checklist 📋
#### For code changes:
- [x] I have clearly listed my changes in the PR description
- [x] I have made a test plan
- [x] I have tested my changes according to the test plan:
<!-- Put your test plan here: -->
- [x] Upload a file bigger than 10MB and it works
- [X] Upload a file bigger than 256MB and you see a official error
stating the max file size is 256MB
121 lines
3.8 KiB
JavaScript
121 lines
3.8 KiB
JavaScript
import { withSentryConfig } from "@sentry/nextjs";
|
|
|
|
/** @type {import('next').NextConfig} */
|
|
const nextConfig = {
|
|
productionBrowserSourceMaps: true,
|
|
experimental: {
|
|
serverActions: {
|
|
bodySizeLimit: "256mb",
|
|
},
|
|
// Increase body size limit for API routes (file uploads) - 256MB to match backend limit
|
|
proxyClientMaxBodySize: "256mb",
|
|
middlewareClientMaxBodySize: "256mb",
|
|
},
|
|
images: {
|
|
domains: [
|
|
// We dont need to maintain alphabetical order here
|
|
// as we are doing logical grouping of domains
|
|
"images.unsplash.com",
|
|
"ddz4ak4pa3d19.cloudfront.net",
|
|
"upload.wikimedia.org",
|
|
"storage.googleapis.com",
|
|
|
|
"ideogram.ai", // for generated images
|
|
"picsum.photos", // for placeholder images
|
|
"example.com", // for local test data images
|
|
],
|
|
remotePatterns: [
|
|
{
|
|
protocol: "https",
|
|
hostname: "storage.googleapis.com",
|
|
pathname: "/**",
|
|
},
|
|
{
|
|
protocol: "https",
|
|
hostname: "storage.cloud.google.com",
|
|
pathname: "/**",
|
|
},
|
|
{
|
|
protocol: "https",
|
|
hostname: "lh3.googleusercontent.com",
|
|
pathname: "/**",
|
|
},
|
|
],
|
|
},
|
|
// Vercel has its own deployment mechanism and doesn't need standalone mode
|
|
...(process.env.VERCEL ? {} : { output: "standalone" }),
|
|
transpilePackages: ["geist"],
|
|
};
|
|
|
|
const isDevelopmentBuild = process.env.NODE_ENV !== "production";
|
|
|
|
export default isDevelopmentBuild
|
|
? nextConfig
|
|
: withSentryConfig(nextConfig, {
|
|
// For all available options, see:
|
|
// https://github.com/getsentry/sentry-webpack-plugin#options
|
|
|
|
org: "significant-gravitas",
|
|
project: "builder",
|
|
|
|
// Expose Vercel env to the client
|
|
env: {
|
|
NEXT_PUBLIC_VERCEL_ENV: process.env.VERCEL_ENV,
|
|
},
|
|
|
|
// 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,
|
|
},
|
|
|
|
// 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: "/store",
|
|
|
|
// No need to hide source maps from generated client bundles
|
|
// since the source is public anyway :)
|
|
hideSourceMaps: false,
|
|
|
|
// This helps Sentry with sourcemaps... https://docs.sentry.io/platforms/javascript/guides/nextjs/sourcemaps/
|
|
sourcemaps: {
|
|
disable: false,
|
|
assets: [".next/**/*.js", ".next/**/*.js.map"],
|
|
ignore: ["**/node_modules/**"],
|
|
deleteSourcemapsAfterUpload: false, // Source is public anyway :)
|
|
},
|
|
|
|
// 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,
|
|
|
|
async headers() {
|
|
return [
|
|
{
|
|
source: "/:path*",
|
|
headers: [
|
|
{
|
|
key: "Document-Policy",
|
|
value: "js-profiling",
|
|
},
|
|
],
|
|
},
|
|
];
|
|
},
|
|
});
|