This file provides context for AI coding agents (Claude Code, GitHub Copilot, Cursor, etc.) working in this repository.
- Product family: Documentation
- Primary language(s): JavaScript
- Build system: npm (Antora)
- Test framework: Antora build (
npm run antora); link checking is documented indocs/checking-broken-links.md - CI system: GitHub Actions
site.yml-- Antora playbook defining all content sourcespackage.json-- npm scripts for building and servingext-antora/-- Custom Antora extensionsext-asciidoc/-- Custom AsciiDoc extensionsdocs/-- Documentation about the docs build system itselfresources/-- Shared resourcesfonts/-- Custom fontssupplemental/-- Supplemental UI filesbook_templates/-- PDF book templates
- Branching: master
- Commit messages: DCO sign-off required (
git commit -s) - Code style: Prettier (
.prettierrcor similar config present) - PR process: Open a PR against
master. All CI checks must pass.
# Build
npm run antora
# Test
# No automated test suite; verify by building (npm run antora).
# Link checking is documented in docs/checking-broken-links.md.
# Lint
Not detected (Prettier config present for formatting)- All code contributions must be compatible with the AGPL-3.0 license
- Do not introduce new copyleft-licensed dependencies (GPL, AGPL, LGPL, MPL) without explicit discussion in an issue first. This is especially important for repos migrating to Apache 2.0.
- Do not introduce new dependencies without discussion in an issue first
- Only use actions owned by
owncloud, created by GitHub (actions/*), verified on the GitHub Marketplace, or verified by the ownCloud Maintainers. - Pin all actions to their full commit SHA (not tags):
uses: actions/checkout@<SHA> # vX.Y.Z - Never introduce actions from unverified third parties.
- Dependabot is configured for automated dependency updates.
- Review and merge Dependabot PRs as part of regular maintenance.
- Do not introduce new dependencies without discussion in an issue first.
- Rebase policy: Always rebase; never create merge commits. Use
git pull --rebaseandgit rebasebefore pushing. - Signed commits: All commits must be PGP/GPG signed (
git commit -S -s). - DCO sign-off: Every commit needs a
Signed-off-byline (git commit -s). - Conventional Commits & Squash Merge: Use the Conventional Commits format where the repository enforces it. Many repos use squash merge, where the PR title becomes the commit message on the default branch — apply Conventional Commits format to PR titles as well. A reusable GitHub Actions workflow enforces this.
- Match existing code style
- Do not refactor unrelated code in the same PR
- Write tests for new functionality
- Keep PRs focused and atomic