Files
zerobyte/AGENTS.md
2026-05-27 17:40:43 +02:00

2.3 KiB

Important instructions

  • Never create migration files manually. Always use the provided command to generate migrations
  • If you realize an automated migration is incorrect, make sure to remove all the associated entries from the _journal.json and the newly created files located in app/drizzle/ before re-generating the migration
  • The dev server runs through Portless. Start it with bun run dev, then use portless get zerobyte to get the current worktree-specific URL. Do not assume a fixed port like 3000 or 4096. Username is admin and password is password
  • The repo is https://github.com/nicotsx/zerobyte
  • If you need to run a specific restic command on a repository, you can open and use the dev panel with Meta+Shift+D

Project Overview

Zerobyte is a backup automation tool built on top of Restic that provides a web interface for scheduling, managing, and monitoring encrypted backups. It supports multiple volume backends (NFS, SMB, WebDAV, SFTP, local directories) and repository backends (S3, Azure, GCS, local, and rclone-based storage).

Development Server

# Start the dev server through Portless
bun run dev

# Get the current app URL for this worktree
portless get zerobyte

# Inspect active Portless routes if needed
portless list

Portless applies git worktree prefixes automatically, so linked worktrees may return URLs like https://branch-name.zerobyte.localhost. Use the Portless URL for browser testing and manual verification.

Type Checking

# Run type checking and generate React Router types
bun run tsc

Testing

# Run all tests
bun run test

# Run a specific test file
bunx dotenv-cli -e .env.test -- bunx --bun vitest run --project server path/to/test.ts

Building

# Build for production
bun run build

Database Migrations

# Generate new migration from schema changes
bun gen:migrations

# Generate a custom empty migration
bunx drizzle-kit generate --custom --name=fix-timestamps-to-ms

API Client Generation

bun run gen:api-client

Code Quality

# Format
vp fmt <path> --write

# Lint
bun run lint

Invalidation

The frontend has an automatic invalidation setup which runs after every mutation. Do not implement any invalidation logic in the frontend.