Files
convex-monorepo-payload/docs/payload-cms.md
T
Gabriel Brown a12bf6071b
Build and Push Next App / quality (push) Successful in 1m8s
Build and Push Next App / build-next (push) Successful in 2m59s
Move to infisical. Create local dev environment. Add ci gates. Modernize repo
2026-06-21 14:04:02 -05:00

45 lines
2.3 KiB
Markdown

# Payload CMS
Payload is embedded in `apps/next` and manages marketing content. Convex remains
the application backend for auth, realtime data, files, and workflows.
Configuration lives in `apps/next/src/payload.config.ts`. Payload uses
`PAYLOAD_SECRET`, `PAYLOAD_DB_URL`, and `NEXT_PUBLIC_SITE_URL` from the validated
environment contract. Local `dev` values come from Infisical and point Payload
to Postgres at `localhost:5432`, because Next runs on the host.
Start the isolated services with `bun db:up`, then run `bun dev:next`. The local
database persists across `bun db:down`; `bun db:down:wipe` removes it. Local
Convex data is stored in a separate volume and Convex does not receive
`POSTGRES_URL` by default.
To refresh the local seed snapshot from current staging/production-derived
Payload content, stop Next and run `bun db:sync:payload`. The command uses
staging only as a read-only dump source, verifies the restore destination is
localhost, writes `.local/payload-staging.dump`, and force-applies it locally.
Normal `bun db:up` never contacts staging; it only restores that local snapshot
when `.local/payload-seed-state.env` is absent or does not match the current
snapshot. The marker stays outside Postgres so Payload schema push does not see
an unmanaged table. The snapshot is gitignored and contains sensitive
production-derived records, including Payload users and password hashes. Do not
share or commit it.
The public landing page is in `apps/next/src/app/(frontend)/page.tsx`; schemas
are under `apps/next/src/payload`, and rendering components are under
`apps/next/src/components/landing`. Custom routes belong in `(frontend)`, not
the generated `(payload)` route group.
Do not manually edit Payload-generated routes, layouts, import maps, or
`apps/next/payload-types.ts`. When schema changes require regeneration, run the
Payload generators through the package's environment wrapper:
```sh
cd apps/next
bun with-env bunx payload generate:types --config src/payload.config.ts
bun with-env bunx payload generate:db-schema --config src/payload.config.ts
```
For staging, use `INFISICAL_ENV=staging`; CI uses temporary Gitea-injected
configuration and never Infisical. Production Payload may use the existing
external/VPN Postgres URL or the commented optional Compose Postgres service.