mirror of
https://github.com/soconnor0919/beenvoice.git
synced 2026-05-08 09:38:55 -04:00
fbeca7cfee
- Deleted the start.sh script for container management. - Added AGENTS.md for project guidelines and development principles. - Introduced new SQL migration files for user appearance preferences and platform settings. - Implemented appearance provider to manage user interface themes and preferences. - Created branding utility to define and manage branding-related constants and types. Co-authored-by: Copilot <copilot@github.com>
106 lines
4.3 KiB
JavaScript
106 lines
4.3 KiB
JavaScript
import { createEnv } from "@t3-oss/env-nextjs";
|
|
import { z } from "zod";
|
|
|
|
export const env = createEnv({
|
|
/**
|
|
* Specify your server-side environment variables schema here. This way you can ensure the app
|
|
* isn't built with invalid env vars.
|
|
*/
|
|
server: {
|
|
AUTH_SECRET:
|
|
process.env.NODE_ENV === "production"
|
|
? z.string()
|
|
: z.string().optional(),
|
|
DATABASE_URL: z.string().url(),
|
|
BETTER_AUTH_URL: z.string().url().optional(),
|
|
RESEND_API_KEY: z.string().min(1).optional(),
|
|
RESEND_DOMAIN: z.string().optional(),
|
|
NODE_ENV: z
|
|
.enum(["development", "test", "production"])
|
|
.default("development"),
|
|
DB_DISABLE_SSL: z.coerce.boolean().optional(),
|
|
// SSO / Authentik (optional)
|
|
AUTHENTIK_ISSUER: z.string().url().optional(),
|
|
AUTHENTIK_CLIENT_ID: z.string().optional(),
|
|
AUTHENTIK_CLIENT_SECRET: z.string().optional(),
|
|
AUTHENTIK_ORIGIN: z.string().url().optional(),
|
|
},
|
|
|
|
/**
|
|
* Specify your client-side environment variables schema here. This way you can ensure the app
|
|
* isn't built with invalid env vars. To expose them to the client, prefix them with
|
|
* `NEXT_PUBLIC_`.
|
|
*/
|
|
client: {
|
|
NEXT_PUBLIC_APP_URL: z.string().url().optional(),
|
|
NEXT_PUBLIC_UMAMI_WEBSITE_ID: z.string().optional(),
|
|
NEXT_PUBLIC_UMAMI_SCRIPT_URL: z.string().url().optional(),
|
|
NEXT_PUBLIC_AUTHENTIK_ENABLED: z.coerce.boolean().optional(),
|
|
NEXT_PUBLIC_BRAND_NAME: z.string().optional(),
|
|
NEXT_PUBLIC_BRAND_TAGLINE: z.string().optional(),
|
|
NEXT_PUBLIC_BRAND_LOGO_TEXT: z.string().optional(),
|
|
NEXT_PUBLIC_BRAND_ICON: z.string().optional(),
|
|
NEXT_PUBLIC_DEFAULT_INTERFACE_THEME: z
|
|
.enum(["beenvoice", "shadcn", "minimal", "editorial"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_FONT: z
|
|
.enum(["brand", "platform", "inter", "serif"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_BODY_FONT: z
|
|
.enum(["brand", "platform", "inter", "serif"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_HEADING_FONT: z
|
|
.enum(["brand", "platform", "inter", "serif"])
|
|
.optional(),
|
|
NEXT_PUBLIC_DEFAULT_RADIUS: z.enum(["none", "sm", "md", "lg", "xl"]).optional(),
|
|
NEXT_PUBLIC_DEFAULT_SIDEBAR_STYLE: z
|
|
.enum(["floating", "docked"])
|
|
.optional(),
|
|
},
|
|
|
|
/**
|
|
* You can't destruct `process.env` as a regular object in the Next.js edge runtimes (e.g.
|
|
* middlewares) or client-side so we need to destruct manually.
|
|
*/
|
|
runtimeEnv: {
|
|
AUTH_SECRET: process.env.AUTH_SECRET,
|
|
DATABASE_URL: process.env.DATABASE_URL,
|
|
BETTER_AUTH_URL: process.env.BETTER_AUTH_URL,
|
|
RESEND_API_KEY: process.env.RESEND_API_KEY,
|
|
RESEND_DOMAIN: process.env.RESEND_DOMAIN,
|
|
NODE_ENV: process.env.NODE_ENV,
|
|
DB_DISABLE_SSL: process.env.DB_DISABLE_SSL,
|
|
AUTHENTIK_ISSUER: process.env.AUTHENTIK_ISSUER,
|
|
AUTHENTIK_CLIENT_ID: process.env.AUTHENTIK_CLIENT_ID,
|
|
AUTHENTIK_CLIENT_SECRET: process.env.AUTHENTIK_CLIENT_SECRET,
|
|
AUTHENTIK_ORIGIN: process.env.AUTHENTIK_ORIGIN,
|
|
NEXT_PUBLIC_APP_URL: process.env.NEXT_PUBLIC_APP_URL,
|
|
NEXT_PUBLIC_UMAMI_WEBSITE_ID: process.env.NEXT_PUBLIC_UMAMI_WEBSITE_ID,
|
|
NEXT_PUBLIC_UMAMI_SCRIPT_URL: process.env.NEXT_PUBLIC_UMAMI_SCRIPT_URL,
|
|
NEXT_PUBLIC_AUTHENTIK_ENABLED: process.env.NEXT_PUBLIC_AUTHENTIK_ENABLED,
|
|
NEXT_PUBLIC_BRAND_NAME: process.env.NEXT_PUBLIC_BRAND_NAME,
|
|
NEXT_PUBLIC_BRAND_TAGLINE: process.env.NEXT_PUBLIC_BRAND_TAGLINE,
|
|
NEXT_PUBLIC_BRAND_LOGO_TEXT: process.env.NEXT_PUBLIC_BRAND_LOGO_TEXT,
|
|
NEXT_PUBLIC_BRAND_ICON: process.env.NEXT_PUBLIC_BRAND_ICON,
|
|
NEXT_PUBLIC_DEFAULT_INTERFACE_THEME:
|
|
process.env.NEXT_PUBLIC_DEFAULT_INTERFACE_THEME,
|
|
NEXT_PUBLIC_DEFAULT_FONT: process.env.NEXT_PUBLIC_DEFAULT_FONT,
|
|
NEXT_PUBLIC_DEFAULT_BODY_FONT: process.env.NEXT_PUBLIC_DEFAULT_BODY_FONT,
|
|
NEXT_PUBLIC_DEFAULT_HEADING_FONT:
|
|
process.env.NEXT_PUBLIC_DEFAULT_HEADING_FONT,
|
|
NEXT_PUBLIC_DEFAULT_RADIUS: process.env.NEXT_PUBLIC_DEFAULT_RADIUS,
|
|
NEXT_PUBLIC_DEFAULT_SIDEBAR_STYLE:
|
|
process.env.NEXT_PUBLIC_DEFAULT_SIDEBAR_STYLE,
|
|
},
|
|
/**
|
|
* Run `build` or `dev` with `SKIP_ENV_VALIDATION` to skip env validation. This is especially
|
|
* useful for Docker builds.
|
|
*/
|
|
skipValidation: !!process.env.SKIP_ENV_VALIDATION,
|
|
/**
|
|
* Makes it so that empty strings are treated as undefined. `SOME_VAR: z.string()` and
|
|
* `SOME_VAR=''` will throw an error.
|
|
*/
|
|
emptyStringAsUndefined: true,
|
|
});
|