Skillshub golang-architecture
Standards for structural design, Clean Architecture, and project layout in Golang. Use when structuring Go projects or applying Clean Architecture in Go. (triggers: go.mod, internal/**, architecture, structure, folder layout, clean arch, dependency injection)
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/HoangNguyen0403/agent-skills-standard/golang-architecture" ~/.claude/skills/comeonoliver-skillshub-golang-architecture && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/golang-architecture/SKILL.mdsource content
Golang Architecture Standards
Priority: P0 (CRITICAL)
Principles
- Clean Architecture: Separate concerns. Inner layers (Domain) rely on nothing. Outer layers (Adapters) rely on Inner.
- Project Layout: Follow standard Go project layout (
,cmd
,internal
).pkg - Dependency Injection: Explicitly pass dependencies via constructors. Avoid global singletons.
- Package Oriented Design: Organize by feature/domain, not by layer (avoid
,controllers/
at root).services/ - Interface Segregation: Define interfaces where they are used (Consumer implementation).
Standard Project Layout
See Standard Project Layout for directory tree.
Layer Rules
- Domain: Inner-most. No deps.
- UseCase: Depends on Domain.
- Adapter: Outer-most. Depends on UseCase/Domain.
Guidelines
- Use Constructors:
.NewService(repo Repository) *Service - Inversion of Control: Service depends on
interface, notRepository
struct.SQLRepository - Wire up in Main: Main function composes the dependency graph.
Verification Checklist (Mandatory)
- No Globals: Are there any global singletons or package-level variables being mutated?
- DI: Are dependencies explicitly passed via constructors?
- Interfaces: Are interfaces defined at the consumer side (where they are used)?
- Layering: Does
have zero external dependencies?internal/domain - Composition: Are dependencies wired together in
?main.go
Anti-Patterns
- No Global Singletons: Use DI; avoid package-level mutable variables.
- No Layer Violations: Domain must not import from adapter/infrastructure layers.
- No God Services: Split large services into single-responsibility components.