After cloning repo, run:
find . -type f \( -name "*.go" \) -exec sed -i '' 's/charmixer\/golang-api-template/your-repo-name/g' {} +;
go mod init <new repo eg. github.com/username/your-repo-name>
go mod tidy
go run main.go serve
To build with supported ldflags use:
go build -ldflags="-s -w -X main.version=1.0.0 -X main.commit=qwerty -X main.date=20210101 -X main.tag=v1.0.0 -X main.name=golang-template-api -X main.environment=production" .
Reading configuration in following order
- Read from yaml file by setting
CFG_PATH=/path/to/conf.yaml
- Read from environment
PATH_TO_STRUCT_FIELD=override-value
- Read from flags
go run main.go serve -f override-value
- If none of above use
default:"value"
tag from configuration struct
Middleware for prometheus has been added. Access metrics from /metrics
Includes defaults and stuff like total requests. Customize in middleware/metrics.go
Using the structs to setup your endpoints will allow for automatic generation of openapi spec.
Documentation can be found at /docs
and spec at /docs/openapi.yaml
If you get an error try setting -d localhost
- Automated documentation of endpoints (OpenAPI)
- Metrics endpoint with default collectors (Prometheus)
- Struct-based application config
- Config from yaml
- Override config with environment
- Override environment with flags
- Default configuration values
- Setup tracing with OpenTelemetry and Jaeger example
- Setup input / output validation with (https://github.com/go-playground/validator) - must be easy to remove/disable
- Input validation
- Output validation
- Setup some sort of error handling (rfc7807)
- Utils for parsing request body and query
- Show validation in docs (OpenAPI spec)
- Health checks with uptime and external deps setup (https://datatracker.ietf.org/doc/html/draft-inadarei-api-health-check)
- CI pipeline with fmt, vet, staticchecks, build & test
- CD pipeline using goreleaser - triggered by tag push
- Publish to Github Packages (ghcr.io) with GoReleaser - disable by adding skip flag to the docker section in:
.goreleaser.yml
(see GoReleaser docs) - Setup changelog generator (https://github.com/charmixer/auto-changelog-action) - currently creates pull requests
- Should somehow create the changelog before release tag is created, so it gets baked in
- Infrastructure reference stack - includes prometheus, jaeger and grafana
- Validation of cli inputs with go-playground lib
- README.md update with guides
- HTTP Client with easy tracing propagation