52 lines
1.7 KiB
JavaScript
52 lines
1.7 KiB
JavaScript
import { createEnv } from '@t3-oss/env-nextjs';
|
|
import { z } from 'zod/v4';
|
|
import { process } from 'zod/v4/core';
|
|
|
|
export const env = createEnv({
|
|
shared: {
|
|
NODE_ENV: z
|
|
.enum(['development', 'production', 'test'])
|
|
.default('development'),
|
|
CI: z.boolean().default(false),
|
|
},
|
|
/**
|
|
* Specify your server-side environment variables schema here.
|
|
* This way you can ensure the app isn't built with invalid env vars.
|
|
*/
|
|
server: {
|
|
SENTRY_AUTH_TOKEN: z.string(),
|
|
},
|
|
|
|
/**
|
|
* Specify your client-side environment variables schema here.
|
|
* For them to be exposed to the client, prefix them with `NEXT_PUBLIC_`.
|
|
*/
|
|
client: {
|
|
NEXT_PUBLIC_SITE_URL: z.url(),
|
|
NEXT_PUBLIC_CONVEX_URL: z.url(),
|
|
NEXT_PUBLIC_PLAUSIBLE_URL: z.url(),
|
|
NEXT_PUBLIC_SENTRY_DSN: z.string(),
|
|
NEXT_PUBLIC_SENTRY_URL: z.string(),
|
|
NEXT_PUBLIC_SENTRY_ORG: z.string(),
|
|
NEXT_PUBLIC_SENTRY_PROJECT_NAME: z.string(),
|
|
},
|
|
/**
|
|
* Destructure all variables from `process.env` to make sure they aren't tree-shaken away.
|
|
*/
|
|
experimental__runtimeEnv: {
|
|
NODE_ENV: process.env.NODE_ENV,
|
|
CI: process.env.CI,
|
|
SENTRY_AUTH_TOKEN: process.env.SENTRY_AUTH_TOKEN,
|
|
NEXT_PUBLIC_SITE_URL: process.env.NEXT_PUBLIC_SITE_URL,
|
|
NEXT_PUBLIC_CONVEX_URL: process.env.NEXT_PUBLIC_CONVEX_URL,
|
|
NEXT_PUBLIC_PLAUSIBLE_URL: process.env.NEXT_PUBLIC_PLAUSIBLE_URL,
|
|
NEXT_PUBLIC_SENTRY_DSN: process.env.NEXT_PUBLIC_SENTRY_DSN,
|
|
NEXT_PUBLIC_SENTRY_URL: process.env.NEXT_PUBLIC_SENTRY_URL,
|
|
NEXT_PUBLIC_SENTRY_ORG: process.env.NEXT_PUBLIC_SENTRY_ORG,
|
|
NEXT_PUBLIC_SENTRY_PROJECT_NAME:
|
|
process.env.NEXT_PUBLIC_SENTRY_PROJECT_NAME,
|
|
},
|
|
skipValidation:
|
|
!!process.env.CI || process.env.npm_lifecycle_event === 'lint',
|
|
});
|