Golang, is a statically typed, compiled programming language designed at Google that aids in building simple, reliable, and efficient software. Gin is a full-featured web framework for Go that achieves outstanding performance.
This boilerplate leverages the Gin framework to quickly prototype backend applications. It comes with database, logging, security, and authentication features out of the box.
-
Based on Gin.
-
Prisma ORM for Mongo. But can support MYSQL/PostgreSQL and Amazon Aurora.
-
Gin Sessions for Redis.
-
Gin Authz for role based access management. Internally, utilizing the powerful authentication library Casbin.
-
Viper for working with yaml configurations.
-
Gin Swagger for API specifications.
Please make sure to have Docker Desktop operational on the preferred operating system of choice to quickly get started. To get started, please see the following link.
Note: Despite the fact that Docker Desktop comes free for both Mac and Windows, it only supports the Pro edition of Windows 10. A common workaround is to get Docker Toolbox which will bypass the Windows 10 Pro restriction by executing Docker in a VM.
The Prisma CLI is essential for streamlining workflows in managing and deploying Prisma services. The CLI can to be downloaded using npm
; which requires NodeJS.
Then, the following command will download the Prisma command line interface:
// prisma cli
$ npm install -g prisma
If need be, replace the existing configuration variables in the config.yaml file with the preferred configuration values.
Changing the
server.env : "test"
toserver.env : "dev"
yields better logging that can come of use when developing.
VSCode permits the development of source code to happen exclusively in a Docker container. For more information on how this works, please read the following documentation.
This boilerplate comes with a .devcontainer
configuration enabling such a feature.
To get started:
- Clone this repository.
- Open VSCode and download the Remote-Containers extension.
- Press F1 and select the Remote-Containers: Open Folder in Container... command.
- Select the cloned copy of this folder, wait for the container to start.
- Run
make prisma-endpoint-to-docker
to guaranteeprisma deploy
works as intended. - Run
make prisma-deploy
orprisma deploy
. - Run
make dev
(server reloading) ormake run
(no server reloading) - Start developing!
Developing locally is still possible but requires some tweaks. The application dependencies such as Prisma, Mongo, and Redis will still require Docker to run. Mainly because Prisma can't be set up locally like Mongo and Redis. But the code itself will not be containerized.
- Execute the following command to run the application dependencies in Docker without building the web application container:
# runs the application locally with only dependencies executing in docker
$ make develop-locally
# entrypoint for web application
$ make dev
#or (for development without server reloading)
$ make run
The design behind making the session management, Redis based, instead of Mongo based, came down to understanding that constant reads and writes to a database for cookie management were redundant and ineffective. The focus was to leave the persistent data in Mongo and less important session-based data in Redis.
As mentioned before, this application leverages the Viper module, which can read in configuration variables from the config.yaml file.
This is a breakdown of the variables:
server.env - the application environment it will be executing in, either in development, production, or testing. Options: dev
, test
, or prod
.
server.port - the default port to expose the application to.
session.name - the name of the session for redis.
redis.idle_connections - the number of idle connections redis should support (default is 10).
redis.network_type - redis network type, default is "tcp" but "udp" is also supported.
redis.address - the URL to redis endpoint.
redis.secret_key - secret key to the redis store.
redis.password - redis password for authentication.
- Dep is a package manager for Go. It aids in managing packages for any Go application.
Getting stated with Dep:
On Mac:
$ brew install dep
$ brew upgrade dep
Other Platforms:
# downloads dep package manager
$ curl https://raw.githubusercontent.com/golang/dep/master/install.sh | sh
- Navigate to the project directory, initialize Dep by running
dep init
then remove thego.mod
andgo.sum
files.
# ensuring dep dependencies are present
$ dep ensure
Note: On Windows, please use Git Bash or WSL where curl is included by default.
One can choose Go Modules over Dep as its a native module version manager for Golang.
- Run
go mod init
- Run
go mod download
to ensure dependencies are downloaded in theGOPATH
. - Run
go mod tidy
to incorporate version locking. - Remove dep files with
rm -rf vendor Gopkg.*
Depending on where the development is occurring; in docker or not, tests can be executed through the Docker shell or locally.
$ go test -v ./tests/*
This boilerplate comes with a lot of crucial Makefile methods to aid in development.
develop-locally
: responsible for preparing the application to be developed locally, it composes redis, mongo and prisma to run locally.
build
: builds the application for deployment.
clean
: removes the generated binary from the build
command.
test
: runs e2e testing.
dev
: Starts the application with fresh to enable auto reloading on saves. Can be paired with docs
command to automate viewing api spec changes.
docs
: generates swagger docs.
run
: starts the server without fresh, meaning auto-reloading won't happen on file saves.
compose-deps
: composes prisma, mongo, and redis only.
prisma-endpoint-to-local
: changes the prisma.yml
endpoint to localhost so that prisma deploy
can work properly when developing locally.
prisma-endpoint-to-docker
: changes the prisma.yml
endpoint to the prisma container so that prisma deploy
can work properly when developing in a container.
prisma-deploy
: generates the prisma client files and deploys the prisma datamodel.