Boilerplate API built using Golang: (Gin Framework for routing, Testify for testing, Swagger for Documentation, Viper for configuration, and Go Mod for dependency management). The intention is for this to be used as a starter application to build out a scalable and organized API service. With minimal configuration, this application can be built and deployed in a container using docker. We have done some research and have tried to stick to Golang best practices as much as possible. The routes and testing can be expanded to meet your needs.
- Gin Documentation
- Testify Documentation
- Swagger Documentation
- Viper Documentation
- Go Mod Documentation
-
Copy directory into your group/namespace
This can be done by forking this repository into your namespace. From there you can remove the fork relationship and update the name. These can be done in the advanced settings
-
Update naming.
Update the golang-rest-api-starter name throughout the project to your application name. This can be done with a simple find/replace
-
Start coding!
You should now be able to start coding. You can start expanding, building, and deploying. You can use make to build/ run your app:
make build make run
A quick look at the top-level files and directories you'll see in this project.
.
├── build
├── config
├── controllers
├── docs
├── middlewares
├── server
├── tests
├── utils
├── Dockerfile
├── Makefile
├── go.mod
├── go.sum
├── main.go
├── .gitignore
└── README.md
-
/build
: This directory contains the binary after a build -
/config
: This directory contains the viper configration and the property files. -
/controllers
: This directory contains the controllers that the router/handlers are configured to call. -
/docs
: Directory for swagger files. -
/middlewares
: This directory is used to house the middlewares used by the controllers. -
/server
: This Directory houses the router and service files which configure the route and start the server -
/tests
: This directory contains all the tests for your application and get kicked off by:make test
-
/utils
: This directory contains all the util classes used throughout the app. -
Dockerfile
: This file contains the buildsteps to build your image using a multi stage build. It is currently using a scratch image to keep it lightweight. -
Makefile
: This file allows the use of make to run tests, build locally, and is used to build in the pipeline. This can be expanded as needed -
go.mod/go.sum
: These files are generated by Go Mod dependency management and can be learned about in the documentation link provided above. -
main.go
: This file is the starting point for the application, which starts the server. -
.gitignore
: This file tells git which files it should not track / not maintain a version history for. -
README.md
: A text file containing useful reference information about your project.
There may be further configuration needed as you expand your application.
Configmap template: You can update the dev.yml file to include your properties.
- Neal Patel
- Chris Elias