A simple Golang API project template that uses the Echo Web framework to save you time and energy.
A simple GoLang WebAPI boilerplate project to accelerate Golang projects. Originally based on this template. Full Credit to Ben Davis
- Echo Web framework - https://echo.labstack.com/
- Zerolog - https://github.com/rs/zerolog
- Swaggo - https://github.com/swaggo/swag
- CI (Github Actions)
- Unit tests (coming soon)
- Container support with docker and docker-compose
- API key validation - https://echo.labstack.com/docs/middleware/key-auth
- Compression - https://echo.labstack.com/docs/middleware/gzip
- Rate limiting - https://echo.labstack.com/docs/middleware/rate-limiter
- Auto Recovery - https://echo.labstack.com/docs/middleware/recover
- Logging - https://echo.labstack.com/docs/middleware/logger
- CORS Support - https://echo.labstack.com/docs/middleware/cors
Click the Use this template button at the top of this project's GitHub page to get started.
- Configure the
go.mod
file and replacemodule github.com/AaronSaikovski/go-api-starter
with your specific project url. - Configure the
Makefile
targets and parameters - Update the name in the
LICENSE
or swap it out entirely - Configure the
.github/workflows/build.yml
file - Update the
CHANGELOG.md
with your own info - Rename other files/folders as needed and configure their content
- Delete this
README
and renameREADME_project.md
toREADME.md
- Run
go mod tidy
to ensure all the modules and packages are in place. - The build process is run from the
Makefile
and to test the project is working type:make run
and check the console for output.
View swagger docs at http://localhost:8080/swagger
- AIR server (supports hot reload) -
go install github.com/cosmtrek/air@latest
- Swagger -
go install github.com/swaggo/swag/cmd/swag@latest
help - Display help about make targets for this Makefile
localrelease - Builds the project in preparation for (local)release
docs - updates the swagger docs
debug - Builds the project in preparation for debug
buildandrun - builds and runs the program on the target platform
run - runs main.go for testing
clean - Remove the old builds and any debug information
unittest - executes unit tests
dep - fetches any external dependencies
vet - Vet examines Go source code and reports suspicious constructs
staticcheck - Runs static code analyzer staticcheck - currently broken
seccheck - Code vulnerability check
lint - format code and tidy modules
depupdate - Update dependencies
hotload - Uses the Air server for hot reloading support.
Uses a basic Ping/Pong approach for healthchecks. Uses the endpoint:
http://127.0.0.1:8080/api/v1/health
Returns:
OK
HTTP Status code - 200 OK:
If the API is running/healthy.
This project has been fully tested with Docker and includes a Dockerfile
and a docker-compose.yml
file and uses a multi-stage docker file to reduce the docker image to approx. 30MB.
The docker build process also optimises the Go executable down to a bare minimum.
To build the docker image type:
docker build -t golangapi:1.0.0 .
and to run the comtainer type:
docker run -p 8080:8080 golangapi:1.0.0
or you can streamline the container build and run process by typing:
docker compose up
and to tear it down type:
docker compose down
Please report any issues here.