š goscaf - Awesome Go Library for Command Line

goscaf generates opinionated, production-quality Go project boilerplate via an interactive CLI. Stop copy-pasting skeleton code between projects
š·ļø Command Line
š Advanced Console UIs
ā 0 stars
Detailed Description of goscaf
What is goscaf?
goscaf generates opinionated, production-quality Go project boilerplate via an interactive CLI. Stop copy-pasting skeleton code between projects. Start with:
- Graceful shutdown with OS signal handling
- Structured JSON logging (slog, zerolog, or zap)
- Your choice of HTTP framework (gin, fiber, chi, echo, gorilla/mux)
- Your choice of Database driver (postgres, mysql, sqlite, mongo, gorm)
- Viper-powered config with
.envsupport - Optional infra clients: Redis, Kafka, NATS
- Multi-stage distroless Dockerfile + docker-compose
- Makefile, GitHub Actions CI, golangci-lint - ready to go on day one
Install
Go install
go install github.com/iyashjayesh/goscaf@latest
Homebrew (coming soon)
brew install goscaf-dev/tap/goscaf
From source
git clone https://github.com/iyashjayesh/goscaf.git
cd goscaf
make install
Usage
Interactive mode
goscaf init my-api
Sample prompt flow:
? Module name: (github.com/your-org/my-api)
? Go version: (1.25.0)
? HTTP framework: gin
? Structured logger: slog (stdlib)
? Add Viper for config & env management? (Y/n)
? Add Redis client (go-redis)? (y/N)
? Add Kafka client (franz-go)? (y/N)
? Add NATS client? (y/N)
? Database driver: (none)
? Add Dockerfile + docker-compose? (Y/n)
? Add Makefile? (Y/n)
? Add GitHub Actions CI? (Y/n)
? Add golangci-lint config? (Y/n)
? Add Swagger/OpenAPI scaffold? (y/N)
āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
Scaffolding project: my-api
Module: github.com/your-org/my-api
Go: 1.25.0
Framework: gin
Logger: slog
āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
ā cmd/main.go
ā go.mod
ā .gitignore
ā .env.example
ā internal/config/config.go
ā internal/handler/handler.go
ā internal/server/server.go
ā Dockerfile
ā docker-compose.yml
ā Makefile
ā .github/workflows/ci.yml
ā .golangci.yml
ā Running go mod tidy...
ā go mod tidy
ā Project created successfully!
Next steps:
cd my-api
cp .env.example .env
make docker-up
make run
Non-interactive / CI mode
goscaf init my-api --defaults
goscaf init my-api --framework fiber --logger zap --redis --kafka --docker
Flags
| Flag | Default | Description |
|---|---|---|
--module | "" | Go module path |
--go-version | 1.25.0 | Go version (1.23, 1.24, 1.25) |
--framework | gin | HTTP framework (gin|fiber|chi|echo|gorilla|none) |
--logger | slog | Structured logger (slog|zerolog|zap) |
--viper | true | Add Viper for config & env management |
--redis | false | Add Redis client (go-redis/v9) |
--kafka | false | Add Kafka client (franz-go) |
--nats | false | Add NATS client |
--db | none | Database driver (postgres|mysql|sqlite|mongo|gorm|none) |
--docker | true | Add Dockerfile + docker-compose |
--makefile | true | Add Makefile |
--github | true | Add GitHub Actions CI |
--lint | true | Add golangci-lint config |
--swagger | false | Add Swagger/OpenAPI scaffold |
--defaults | false | Skip all prompts, use recommended defaults |
--output | . | Output directory |
Generated Project Structure
my-api/
āāā cmd/
ā āāā main.go # Entrypoint with graceful shutdown
āāā internal/
ā āāā config/
ā ā āāā config.go # Viper (or stdlib) config loader
ā āāā server/
ā ā āāā server.go # HTTP server for chosen framework
ā āāā handler/
ā āāā handler.go # HTTP handlers
āāā pkg/
ā āāā db/db.go # (if selected) Database connection wrapper
ā āāā redis/redis.go # (if selected) go-redis wrapper
ā āāā kafka/kafka.go # (if selected) franz-go producer+consumer
ā āāā nats/nats.go # (if selected) NATS client wrapper
āāā .github/
ā āāā workflows/ci.yml
āāā .env.example
āāā .gitignore
āāā .golangci.yml
āāā Dockerfile
āāā docker-compose.yml
āāā go.mod
āāā Makefile
Generated Makefile Targets
| Target | Description |
|---|---|
make run | go run ./cmd/main.go |
make build | Build binary to bin/<name> |
make test | go test -race -cover ./... |
make test-coverage | Generate coverage.html report |
make lint | golangci-lint run ./... |
make fmt | gofmt -s -w . && goimports -w . |
make tidy | go mod tidy |
make docker-up | docker compose up -d |
make docker-down | docker compose down |
make docker-logs | docker compose logs -f app |
make clean | Remove bin/, coverage.* |
make install-tools | Install golangci-lint + goimports |
Supported Frameworks
| Flag value | Import path |
|---|---|
gin | github.com/gin-gonic/gin |
fiber | github.com/gofiber/fiber/v2 |
chi | github.com/go-chi/chi/v5 |
echo | github.com/labstack/echo/v4 |
gorilla | github.com/gorilla/mux |
none | stdlib net/http |
Supported Databases
| Flag value | Driver / Library |
|---|---|
postgres | github.com/jackc/pgx/v5 |
mysql | github.com/go-sql-driver/mysql |
sqlite | modernc.org/sqlite |
mongo | go.mongodb.org/mongo-driver |
gorm | gorm.io/gorm (with Postgres driver) |
none | No database scaffolded |
Contributing
# Clone and build
git clone https://github.com/iyashjayesh/goscaf.git
cd goscaf
make build
# Run the smoke test
make smoke-test
PRs welcome! Please open an issue first for major changes.