go-microservice
This skill should be used when the user asks to "создать микросервис", "добавить домен", "имплементировать фичу", "использовать Uber FX", "создать репозиторий", "добавить gRPC endpoint", "добавить HTTP endpoint", "создать воркер", "составь план создания микросервиса", "использовать внутренние пакеты", "настроить kafka/redis/postgres/кафку/редис/постгрес", mentions "service_template", "shared", or needs guidance on Go microservice architecture, domain-driven design patterns, or backend development.
Best use case
go-microservice is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
This skill should be used when the user asks to "создать микросервис", "добавить домен", "имплементировать фичу", "использовать Uber FX", "создать репозиторий", "добавить gRPC endpoint", "добавить HTTP endpoint", "создать воркер", "составь план создания микросервиса", "использовать внутренние пакеты", "настроить kafka/redis/postgres/кафку/редис/постгрес", mentions "service_template", "shared", or needs guidance on Go microservice architecture, domain-driven design patterns, or backend development.
Teams using go-microservice should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/go-microservice/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How go-microservice Compares
| Feature / Agent | go-microservice | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
This skill should be used when the user asks to "создать микросервис", "добавить домен", "имплементировать фичу", "использовать Uber FX", "создать репозиторий", "добавить gRPC endpoint", "добавить HTTP endpoint", "создать воркер", "составь план создания микросервиса", "использовать внутренние пакеты", "настроить kafka/redis/postgres/кафку/редис/постгрес", mentions "service_template", "shared", or needs guidance on Go microservice architecture, domain-driven design patterns, or backend development.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# Go Microservice Development
This skill provides guidance for creating and extending Go microservices using the internal service template and backend packages.
## Overview
The microservice architecture follows Clean Architecture principles with Uber FX for dependency injection. All services share a common structure and use a set of internal infrastructure packages.
## Architecture Overview
```
cmd/app/main.go # Entry point with signal handling
config/config.go # Configuration with fx.Out pattern
internal/
├── app/app.go # fx bootstrap (CreateApp)
├── domain/ # Business logic (DDD)
│ ├── fx.go # Domain modules aggregation
│ └── {name}/ # Domain module
│ ├── fx.go # Module registration
│ ├── consts/ # Permission scopes
│ ├── entities/ # Domain entities
│ ├── dto/ # Request/Response objects
│ ├── deps/ # Interface definitions
│ ├── errors/ # Domain-specific errors
│ ├── repository/ # Data access (postgres, http_clients)
│ ├── usecase/ # Business logic
│ ├── delivery/ # HTTP, gRPC, Kafka, RabbitMQ handlers
│ └── workers/ # Background tasks
└── infrastructure/ # Servers, clients, interceptors
pkg/ # Local utilities (errors, httputil, ctxutil)
```
## Domain Development Quick Guide
### Creating New Domain - Checklist
```
1. [ ] Create directory: internal/domain/{name}/
2. [ ] Create subdirectories: entities/, dto/, deps/, repository/postgres/,
usecase/buissines/, delivery/http/, errors/
3. [ ] Define entities in entities/entities.go
4. [ ] Define DTOs in dto/dto.go
5. [ ] Define interfaces in deps/dep.go
6. [ ] Implement repository in repository/postgres/repo.go
7. [ ] Implement usecase in usecase/buissines/uc.go
8. [ ] Implement HTTP handlers in delivery/http/handlers.go
9. [ ] Implement router in delivery/http/router.go
10. [ ] Create fx.Module in fx.go
11. [ ] Register module in internal/domain/fx.go
12. [ ] Validate: go test -run Test__CreateApp ./internal/app
```
For detailed file templates, consult `examples/new-domain-checklist.md`.
## Layer Rules Summary
| Layer | Key Rules | Example Tags/Patterns |
|-------|-----------|----------------------|
| **Entities** | Use db/json tags, typed constants for enums | `db:"column" json:"field"` |
| **DTO** | Separate Request/Response, use validate tags | `validate:"required"` |
| **Deps** | Interface-only, context.Context first | `Create(ctx, entity) error` |
| **Repository** | Return interface, use NamedExec/Get/SelectContext | `func New(db) deps.Repo` |
| **Usecase** | Inject via interfaces, return DTOs, validate | Inject deps, return dto |
| **Delivery HTTP** | fasthttp, httputil.WriteResponse | `mapper.MapErrorToHttp(err)` |
| **Delivery gRPC** | OnStart/OnStop lifecycle | `lc.Append(fx.Hook{...})` |
| **Workers** | fx.Lifecycle, graceful shutdown via channels | `ticker + done channel` |
For detailed patterns and code examples, consult `references/layer-patterns.md`.
## Internal Packages Quick Reference
### Infrastructure Connectors
| Package | Purpose | FX Module | Key Interface |
|---------|---------|-----------|---------------|
| `pgconnector` | PostgreSQL | `pgconnectorfx.PGConnectorFx` | `IDB` |
| `redisconnector` | Redis/Sentinel | `redisfx.RedisFx` | `IRedis` |
| `kafkaconnector` | Kafka producer/consumer | Manual | `IProducer`, `IConsumer` |
| `rabbitconnector` | RabbitMQ | Manual | `IProducer`, `IConsumer` |
| `vaultconnector` | HashiCorp Vault | `VaultFx` | `Connector` |
| `s3` | S3 storage | `S3Fx` | `IS3` |
| `clickhouseconnector` | ClickHouse | `clickhouseconnectorfx.ClickHouseConnectorFx` | `ICH` |
### Observability
| Package | Purpose | FX Module | Key Interface |
|---------|---------|-----------|---------------|
| `logger` | Structured logging (zap) | `loggerfx.LoggerFx` | `ILogger` |
| `tracer` | OpenTelemetry tracing | `tracerfx.TracerFx` | `ITracer` |
| `meter` | Prometheus metrics | `meterFx` | `IMeter` |
| `healthcheck` | /healthz, /readyz probes | `healthfx.HealthCheckFx` | - |
### Utilities
| Package | Purpose |
|---------|---------|
| `configurator` | YAML/ENV configuration with validation |
| `events` | Event types for inter-service communication |
| `outbox` | Transactional Outbox pattern |
| `memcache` | In-memory cache (Cache, SnapshotCache, DeadlineCache) |
| `pagination` | Pagination primitives |
| `access_level_guard` | gRPC access control via protobuf annotations |
| `tlser` | TLS certificates for gRPC |
| `wallet_streamer` | Wallet subscription streaming |
For detailed usage with code examples, consult `references/internal-packages.md`.
## FX Module Essentials
### Module Registration Pattern
```go
// internal/domain/{name}/fx.go
var Module = fx.Module(
"{name}",
fx.Provide(
postgres.NewRepository,
buissines.NewUseCase,
http.NewHandlers,
http.NewRouter,
),
)
```
### Domain Aggregation
```go
// internal/domain/fx.go
var Module = fx.Module(
"domain",
order.Module,
user.Module,
// Add new domain modules here
)
```
### App Bootstrap
```go
// internal/app/app.go
func CreateApp() fx.Option {
return fx.Options(
loggerfx.LoggerFx,
healthfx.HealthCheckFx,
pgconnectorfx.PGConnectorFx,
redisfx.RedisFx,
domain.Module,
infrastructure.Module,
fx.Provide(config.Out, context.Background),
healthfx.ReadinessProbeFX,
)
}
```
### Workers with Lifecycle
```go
// internal/domain/{name}/workers/fx.go
var Module = fx.Module(
"{name}-workers",
fx.Provide(NewWorker),
fx.Invoke(registerLifecycle),
)
func registerLifecycle(lc fx.Lifecycle, w *Worker) {
lc.Append(fx.Hook{
OnStart: func(ctx context.Context) error { w.Start(ctx); return nil },
OnStop: func(ctx context.Context) error { w.Stop(); return nil },
})
}
```
For advanced patterns (fx.As, fx.Annotate, fx.In/Out), consult `references/fx-patterns.md`.
## Common Integration Scenarios
### Adding HTTP Endpoint
1. Add handler method to `delivery/http/handlers.go`
2. Register route in `delivery/http/router.go`
3. Add usecase method if needed
4. Add repository method if needed
5. Validate: `go test -run Test__CreateApp ./internal/app`
### Adding gRPC Endpoint
1. Update proto definition
2. Regenerate proto: `protoc --go_out=. --go-grpc_out=. *.proto`
3. Implement handler in `delivery/grpc/handlers.go`
4. Add usecase method if needed
5. Validate fx graph
### External HTTP Client Integration
1. Create client: `repository/http_clients/{service}/client.go`
2. Define interface in `deps/dep.go`
3. Add config in `config/config.go`:
```go
ServiceName containers.RepositoryConfig `envPrefix:"SERVICE_NAME_"`
```
4. Register in fx.Module
### Background Worker
1. Create worker: `workers/worker.go` with ticker + done channel
2. Create fx module: `workers/fx.go` with lifecycle hooks
3. Register in domain fx.Module
### New Configuration Field
1. Add field to `config/config.go` with env/yaml/validate tags
2. Add to Result struct with `fx.Out`
3. Return in `Out()` function
For detailed step-by-step scenarios, consult `references/template-structure.md`.
## Error Handling
### Error Types and HTTP Codes
| Type | HTTP Code | Constructor |
|------|-----------|-------------|
| `ValidationError` | 400 | `NewValidationError(msg)` |
| `UnauthorizedError` | 401 | `NewUnauthorizedError(msg)` |
| `PermissionError` | 403 | `NewPermissionError(msg)` |
| `NotFoundError` | 404 | `NewNotFoundError(msg)` |
| `ConflictError` | 409 | `NewConflictError(msg)` |
### Domain Errors Pattern
```go
// internal/domain/{name}/errors/errors.go
package errors
import pkgerrors "service/pkg/errors"
var (
OrderNotFound = pkgerrors.NewNotFoundError("order not found")
OrderAlreadyPaid = pkgerrors.NewConflictError("order already paid")
InvalidOrderAmount = pkgerrors.NewValidationError("invalid amount")
)
```
### Handler Error Mapping
```go
resp, err := h.uc.CreateOrder(ctx, &req)
if err != nil {
status, msg := h.mapper.MapErrorToHttp(err)
httputil.WriteErrorResponse(ctx, msg, status, err)
return
}
httputil.WriteResponse(ctx, resp)
```
## Local Utilities (pkg/)
| Package | Purpose | Key Functions |
|---------|---------|---------------|
| `pkg/errors` | Typed errors | `NewValidationError`, `NewNotFoundError`, `NewMapper` |
| `pkg/httputil` | HTTP helpers | `WriteResponse`, `WriteError`, `NewMiddlewareGroup` |
| `pkg/ctxutil` | Context helpers | `FromCtx[T](ctx, key)`, `HasInCtx(ctx, key)` |
| `pkg/generator` | Data generation | `GenerateApiKey(prefix, length)` |
| `pkg/hasher` | Password hashing | `HashPassword(pwd)`, `ValidatePassword(hash, pwd)` |
| `pkg/mapfn` | Slice transforms | `ConvertSlice[T,R](input, fn)` |
| `pkg/timetools` | Time formatting | `FrontendTime` (JSON-compatible) |
### Context Keys (infrastructure/constants)
```go
const (
UserIDContextKey = "user_id"
MerchantIDContextKey = "merchant_id"
SessionInfoContextKey = "session_info"
ApiKeyInfoContextKey = "api_key_info"
)
```
## Commands
```powershell
# Run application
go run ./cmd/app
# Run all tests
go test ./...
# Validate fx dependency graph
go test -run Test__CreateApp ./internal/app
# Generate swagger docs
swag init -g ./cmd/app/main.go -o ./docs
# Download dependencies
go mod download
```
## Additional Resources
### Reference Files
For detailed patterns and techniques, consult:
- **`references/template-structure.md`** - Complete file/folder structure with examples
- **`references/internal-packages.md`** - Detailed package documentation
- **`references/fx-patterns.md`** - Advanced FX DI patterns
- **`references/layer-patterns.md`** - Layer rules with code examples
### Example Files
Working examples in `examples/`:
- **`examples/new-domain-checklist.md`** - Step-by-step domain creation with copy-paste codeRelated Skills
microservices-orchestrator
Expert skill for designing, decomposing, and managing microservices architectures. Activates when users need help with microservices design, service decomposition, bounded contexts, API contracts, or transitioning from monolithic to microservices architectures.
design-microservices
マイクロサービス設計エージェント - ターゲットアーキテクチャ、変換計画、運用計画の策定。/design-microservices [対象パス] で呼び出し。
microservices-patterns
Design microservices architectures with service boundaries, event-driven communication, and resilience patterns. Use when building distributed systems, decomposing monoliths, or implementing micros...
microservices-architecture
Microservices architecture patterns and best practices. Use when designing distributed systems, breaking down monoliths, or implementing service communication.
Microservices Communication
Thiết kế kiến trúc giao tiếp Microservices (gRPC, message queues, event-driven pattern).
arch-microservices
Microservices: decomposition, API gateway Kong/Traefik, service mesh Istio, circuit breakers, saga/outbox
agent-microservices-architect
Distributed systems architect designing scalable microservice ecosystems. Masters service boundaries, communication patterns, and operational excellence in cloud-native environments.
bgo
Automates the complete Blender build-go workflow, from building and packaging your extension/add-on to removing old versions, installing, enabling, and launching Blender for quick testing and iteration.
openweather-api-automation
Automate Openweather API tasks via Rube MCP (Composio). Always search tools first for current schemas.
opentangl
Not a code generator — an entire dev team. You write the vision, it ships the code. Autonomous builds, PRs, reviews, and merges across multiple repos. Point it at any JS/TS project and a product vision. It plans features, writes code, verifies builds, creates PRs, reviews diffs, and merges — autonomously. Manages multiple repos as one product. Use when you want to ship code without writing it. AI code generation, autonomous development, workflow automation, multi-repo orchestration, TypeScript, JavaScript, GitHub, OpenAI, Anthropic, Claude, GPT, LLM, devtools, CI/CD, pull requests, code review.
openhue
Philips Hue smart lights control
opencode
OpenCode - Open source AI coding agent for terminal, desktop, and IDE with multi-provider LLM support, custom agents, MCP integration, and granular permissions