Skip to content

Contributing

Thanks for your interest in contributing. This guide covers how to participate, what we accept, and how to get started.

Ways to contribute

Issues (no setup required)

  • Bug reports - Something broken? Open a bug report with reproduction steps.
  • Feature requests - Have an idea? Start a discussion so the community can weigh in and upvote it.
  • Translation issues - Spot a wrong or missing translation? Open a translation issue.
  • Documentation issues - Something off in the docs? Open a documentation issue.

Code (requires CLA)

We accept pull requests for:

TypeProcess
Bug fixesOpen a PR directly (link the issue if one exists)
New translationsOpen a PR directly (see Translation Guide)
Documentation improvementsOpen a PR directly
Test coverage improvementsOpen a PR directly
New tools or featuresStart a discussion first; a maintainer converts approved ideas into a tracked issue before you write code
Refactors or architecture changesStart a discussion first and wait for maintainer sign-off before writing code

What we will not accept

  • Changes to CI/CD workflows, release config, or linter/compiler config
  • PRs without a signed Contributor License Agreement
  • PRs over 400 lines of change (break large work into smaller PRs)
  • Features that were not discussed and approved first
  • Changes to packages/ai/ without prior discussion

Contributor License Agreement

Before we can merge your first PR, you must sign our Individual CLA. This is a one-time requirement.

Why: SnapOtter is dual-licensed (AGPLv3 + commercial). The CLA grants us the right to distribute your contributions under both licenses. You retain full copyright ownership of your work.

How: When you open your first PR, the CLA Assistant bot will comment with a link. Click it, review the agreement, and sign with your GitHub account. Takes 30 seconds.

If you are contributing on behalf of your employer and your employer retains IP rights over your work, contact contact@snapotter.com to arrange a Corporate CLA before submitting.

Getting started

Prerequisites

  • Node.js 22+
  • pnpm 9+
  • Python 3.11+ (only for AI tools)
  • Docker (optional, for full integration testing)

Setup

bash
# Fork and clone
git clone https://github.com/<your-username>/snapotter.git
cd snapotter

# Start Postgres + Redis for local dev
docker compose -f docker-compose.dev.yml up -d

# Install dependencies
pnpm install

# Start dev servers (web on :1349, API on :13490)
pnpm dev

Running checks

Before submitting a PR, ensure all checks pass locally:

bash
pnpm lint          # Biome lint + format check
pnpm typecheck     # TypeScript across monorepo
pnpm test          # Vitest unit + integration tests

Pull request process

  1. Fork the repo and create a branch from main (feat/my-feature or fix/issue-123)
  2. Make your changes in focused, reviewable commits using conventional commits
  3. Add or update tests for your changes
  4. Run pnpm lint && pnpm typecheck && pnpm test locally
  5. Open a PR against main and fill out the template
  6. Sign the CLA if prompted
  7. Wait for CI to pass and a maintainer to review

Review expectations

  • We aim to respond to PRs within 7 days
  • Small, focused PRs get reviewed faster
  • If you have not heard back in 7 days, leave a comment pinging the thread
  • We may request changes, suggest a different approach, or close the PR if it does not align with project direction

After your PR is merged

Your contribution will be included in the next release and credited in the changelog.

Good first issues

Looking for something to work on? Check our good first issues for beginner-friendly tasks, or help wanted for larger items where we'd appreciate community help.

Code style

  • Biome handles formatting and linting (double quotes, semicolons, 2-space indent)
  • Pre-commit hook runs biome check --write on staged files automatically
  • If the linter complains, fix the code (do not modify Biome config)
  • ES modules everywhere (import/export)
  • Conventional commits: feat:, fix:, refactor:, docs:, test:, chore:

For full architecture details, see the Developer Guide.

Security

Do not open a public PR or issue for security vulnerabilities. Report them privately through GitHub Security Advisories or email contact@snapotter.com. See SECURITY.md for full details.

Questions?