feat: turbostarter boilerplate

Production-ready Next.js boilerplate with:
- Runtime env validation (fail-fast on missing vars)
- Feature-gated config (S3, Stripe, email, OAuth)
- Docker + Coolify deployment pipeline
- PostgreSQL + pgvector, MinIO S3, Better Auth
- TypeScript strict mode (no ignoreBuildErrors)
- i18n (en/es), AI modules, billing, monitoring

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Alejandro Gutiérrez
2026-02-02 17:29:12 +00:00
commit 3527e732d4
1618 changed files with 338230 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
import { expoClient } from "@better-auth/expo/client";
import { lastLoginMethodClient } from "@better-auth/expo/plugins";
import {
magicLinkClient,
twoFactorClient,
anonymousClient,
adminClient,
organizationClient,
inferAdditionalFields,
} from "better-auth/client/plugins";
import { createAuthClient } from "better-auth/react";
import type { AuthMobileClientOptions } from "..";
import type { auth } from "../server";
import type { AuthClientOptions } from "../types";
import type { LastLoginMethodClientConfig } from "@better-auth/expo/plugins";
export const createClient = ({
mobile,
lastLoginMethod,
...options
}: AuthClientOptions & {
mobile: AuthMobileClientOptions;
lastLoginMethod: LastLoginMethodClientConfig;
}) =>
createAuthClient({
...options,
plugins: [
...(options.plugins ?? []),
anonymousClient(),
magicLinkClient(),
twoFactorClient(),
adminClient(),
organizationClient(),
lastLoginMethodClient(lastLoginMethod),
inferAdditionalFields<typeof auth>(),
expoClient(mobile),
],
});

View File

@@ -0,0 +1,30 @@
import { passkeyClient } from "@better-auth/passkey/client";
import {
magicLinkClient,
twoFactorClient,
anonymousClient,
adminClient,
organizationClient,
inferAdditionalFields,
lastLoginMethodClient,
} from "better-auth/client/plugins";
import { createAuthClient } from "better-auth/react";
import type { auth } from "../server";
import type { AuthClientOptions } from "../types";
export const createClient = (options?: AuthClientOptions) =>
createAuthClient({
...options,
plugins: [
...(options?.plugins ?? []),
passkeyClient(),
anonymousClient(),
magicLinkClient(),
twoFactorClient(),
adminClient(),
organizationClient(),
lastLoginMethodClient(),
inferAdditionalFields<typeof auth>(),
],
});