Using Sruja in Your Project
This guide is for teams and organizations that want to use Sruja in their own repositories to enhance their code: architecture-as-code, validation in CI, and AI-assisted generation with consistent rules.
What you get
- Architecture as code –
.srujafiles in Git; no separate diagram tool to keep in sync. - Validation –
sruja lintcatches undefined refs, circular dependencies, missing fields, orphans. - AI-friendly – Rules and skills so Cursor, Copilot, etc. generate valid Sruja and better architecture.
- CI – Fail PRs when architecture is invalid; optional export to Markdown/JSON/Mermaid for docs.
1. Install (your machine and/or CI)
CLI
Option A – from Git (recommended for now):
cargo install sruja-cli --git https://github.com/sruja-ai/sruja
Option B – install script (if available in repo):
curl -fsSL https://raw.githubusercontent.com/sruja-ai/sruja/main/scripts/install.sh | bash
Check:
sruja --help
sruja lint --help
VS Code extension
Install Sruja Language Support from the VS Code Marketplace (or Open VSX). You get syntax highlighting, LSP diagnostics, and optional diagram preview for .sruja files.
2. Add Sruja to your repo (5 minutes)
Step 1: Create or add architecture
# From your repo root
sruja init my-service
# Creates: my-service.sruja, .cursorrules, .copilot-instructions.md, .architecture-skill.md
Or add a single file, e.g. architecture.sruja or docs/architecture.sruja, and define your systems/containers/relationships (see Language specification and examples).
Step 2: AI editor integration (so AI-generated code follows rules)
The files created by sruja init are enough for most teams:
.cursorrules– Cursor uses this for Sruja DSL rules..copilot-instructions.md– GitHub Copilot uses this..architecture-skill.md– Short pointer; optional full skill:npx skills add sruja-ai/sruja --skill sruja-architecture.
Commit these so everyone (and CI) has the same setup. See AI editor integration in the repo for details.
Step 3: Validate in CI
In your repo you don't have the Sruja monorepo, so install the CLI in CI from Git, then run lint.
GitHub Actions example:
name: Validate Sruja
on:
push:
branches: [main, develop]
pull_request:
branches: [main, develop]
paths:
- '**/*.sruja'
jobs:
sruja:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
- name: Install Sruja CLI
run: cargo install sruja-cli --git https://github.com/sruja-ai/sruja --locked
- name: Lint all .sruja files
run: |
find . -name '*.sruja' -not -path './target/*' | while read f; do
echo "Linting $f"
sruja lint "$f"
done
Use --locked so the install matches the lockfile in the Sruja repo for reproducible CI.
Optional – export docs in CI:
- name: Export architecture to Markdown
run: |
for f in $(find . -name '*.sruja' -not -path './target/*'); do
out="${f%.sruja}.md"
sruja export markdown "$f" > "$out" || true
done
- name: Upload architecture docs
uses: actions/upload-artifact@v4
with:
name: architecture-docs
path: '**/*.sruja.md'
3. How this enhances your code
| Practice | How Sruja helps |
|---|---|
| PR reviews | CI fails if .sruja is invalid; reviewers see architecture changes in the diff. |
| Onboarding | New devs read .sruja and exported docs instead of hunting for "the" diagram. |
| AI-generated code | .cursorrules and Copilot instructions steer AI to valid DSL; sruja lint catches mistakes. |
| Compliance / governance | Policies and constraints in the DSL; lint enforces structure; export for auditors. |
| Multi-repo | Each repo can have its own architecture.sruja (or one per service); same CLI and CI pattern. |
4. Using Sruja across multiple repos
- Per-repo – Each repository that owns a service or app can have its own
.srujafile(s). Add the same CI job (install CLI from Git +sruja lint) and the same AI files (e.g. copy.cursorrulesand.copilot-instructions.mdfrom a template or runsruja initonce and commit). - Central docs repo – Some teams keep a single "docs" or "architecture" repo with one or more
.srujafiles and run Sruja CI there; link to exported Markdown/JSON from other repos. Other repos don't need the CLI unless they also own architecture files. - Shared rules – Use the same sruja-architecture skill (
npx skills add sruja-ai/sruja --skill sruja-architecture) across repos so AI and humans share the same patterns and trade-offs.
5. Where to go next
- Language specification – Language specification (full DSL reference in this book)
- AI editors and catching bugs – AI editor integration in the repo
- Reviewing AI-generated code – Reviewing AI-generated code in the repo
- Adoption and rollout – Adoption guide and Adoption playbook in this book
- Examples – examples/ in the Sruja repo
Sruja is open source. To report issues or suggest improvements, use GitHub Issues or Discussions.