A progressive framework-agnostic API template following CLEAN architecture and SOLID principles. DDD inspired :)
Gomora provides the example for a module-based gRPC and REST server suitable for building progressive APIs (from monolith to distributed microservices).
data:image/s3,"s3://crabby-images/f6619/f66195c4cd90ec70e682cf0319a330f6b2db7281" alt="Screen Shot 2024-10-07 at 9 43 31 AM"
data:image/s3,"s3://crabby-images/b6fca/b6fca8e3de967ede4a4459493f6890115724bc1b" alt="Screen Shot 2024-10-07 at 9 41 10 AM"
data:image/s3,"s3://crabby-images/b29ad/b29ad66bce2b08e70da63b1b52b690d1024087c4" alt="Screen Shot 2024-10-07 at 9 44 17 AM"
data:image/s3,"s3://crabby-images/49363/49363d26481c694bd15e82fdb1212ee9e8d1ddcd" alt="Screen Shot 2024-10-07 at 9 46 05 AM"
Setup the .env file first
cp .env.example .env
To bootstrap everything, run:
make
The command above will install, build, and run the binary
For manual install:
make install
For lint:
make lint
Just ensure you installed golangci-lint.
To test:
make test
For manual build:
make build
# The output for this is in bin/
To build, run:
make run
To run the container:
make up
Gomora uses go-migrate (https://github.com/golang-migrate/migrate) to handle migration. Download and change your migrate database command accordingly.
To create a schema, run:
NAME=<init_schema> make migrate-schema
To migrate up, run:
STEPS=<remove STEPS to apply all or specify step number> make migrate-up
To migrate down, run:
STEPS=<remove STEPS to apply all or specify step number> make migrate-down
To check migrate version, run:
make migrate-version
To force migrate, run:
STEPS=<specify step number> make migrate-force
Made with ❤️ at Nuxify