Skip to content

dossierhq/dossierhq

Repository files navigation

Dossier

Node CI Benchmark

Dossier enables you to build solutions where you’re in full control of the content. By bringing your own auth (authentication and authorization), database and backend, you can build a headless Content Management System (CMS) and integrate it with your app.

For more information about Dossier, head over to dossierhq.dev. The rest of this readme is focused on developing and contributing to Dossier itself.

If you just want to get started using Dossier, these destinations might get you there faster:

Published packages

Package Version Folder
@dossierhq/better-sqlite3 npm version libraries/better-sqlite3
@dossierhq/cloudinary npm version libraries/cloudinary
@dossierhq/core npm version libraries/core
@dossierhq/core-vitest npm version libraries/core-vitest
@dossierhq/database-adapter npm version libraries/database-adapter
@dossierhq/design npm version libraries/design
@dossierhq/graphql npm version libraries/graphql
@dossierhq/integration-test npm version libraries/integration-test
@dossierhq/leaflet npm version libraries/leaflet
@dossierhq/pg npm version libraries/pg
@dossierhq/postgres-core npm version libraries/postgres-core
@dossierhq/postgres-tools npm version libraries/postgres-tools
@dossierhq/react-components npm version libraries/react-components
@dossierhq/react-components2 npm version libraries/react-components2
@dossierhq/server npm version libraries/server
@dossierhq/sql.js npm version libraries/sql.js
@dossierhq/sqlite-core npm version libraries/sqlite-core
@dossierhq/typescript-generator npm version libraries/typescript-generator

Development dependencies

  • Use mise to install the tools in .tools-versions
  • brew install pgcli (optional, for Postgres access)
  • brew install gnuplot (for benchmarking)
  • npx playwright install (for installing browsers for Playwright testing)

Getting started

  • pnpm i to install dependencies.
  • In tools/generic-tools/:
    • By default the databases (test and example databases on PostgreSQL) are configured in Docker. To use another db set the env variable HOST_ROOT_DATABASE_URL
    • npm run db:start (only if running db in Docker)
    • npm run db:ensure-dbs
    • npm run db:make-users:superuser
    • npm run db:migrate:all
    • npm run db:make-users:no-superuser
  • pnpm run build

Dev container / Github Code Spaces

  • Start dev container
  • The script post-create.sh runs automatically on first run
  • When done, restart your shell since it sets up environment variables
  • For root access to the Postgres database, run psql "$HOST_ROOT_DATABASE_URL" or pgcli "$HOST_ROOT_DATABASE_URL"

Upgrade dependencies

  • Run pnpm tools:update
    • Update packageManager in package.json to match the version of pnpm you have installed
  • Run pnpm deps:update-interactive
  • Upgrade Deno dependencies in the 3 import-map.json files
  • Run (cd tools/generic-tools && npm run deno:reload-dependencies:all)
  • Upgrade the postgres version in ./docker-compose.yml

Publish packages

  • When making changes to published packages, create a changeset using pnpm changeset:add
  • The release workflow will automatically open a PR to bump the versions
  • Merge the PR to publish the packages

Ports

  • 3000: examples/tutorial
  • 3001: examples/next-web
  • 3002: apps/playground
  • 3003: apps/blog
  • 3004: apps/playground2
  • 4321: examples/astro
  • 4322: examples/astro (HMR)
  • 5173: examples/tutorial
  • 6006: libraries/react-components
  • 6007: libraries/design
  • 6008: libraries/react-components2
  • 9000: libraries/libsql - admin entity
  • 9001: libraries/libsql - advisory lock
  • 9002: libraries/libsql - advisory lock
  • 9003: libraries/libsql - published entity
  • 9004: libraries/libsql - schema
  • 9005: libraries/libsql - changelog
  • 9006: libraries/libsql - sync source
  • 9007: libraries/libsql - sync target