Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/crazyoptimist/gin-starter
Gin REST API Starter for Minimalists
https://github.com/crazyoptimist/gin-starter
api boilerplate gin go golang jwt modular pagination rest-api starter-kit
Last synced: about 1 month ago
JSON representation
Gin REST API Starter for Minimalists
- Host: GitHub
- URL: https://github.com/crazyoptimist/gin-starter
- Owner: crazyoptimist
- License: mit
- Created: 2023-02-07T22:49:22.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-23T16:43:12.000Z (4 months ago)
- Last Synced: 2024-10-03T21:41:13.547Z (4 months ago)
- Topics: api, boilerplate, gin, go, golang, jwt, modular, pagination, rest-api, starter-kit
- Language: Go
- Homepage:
- Size: 367 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Gin Starter
This is a REST API boilerplate.
## Overview
This project implements the Clean Architecture proposed by Uncle Bob. I do not claim this to be a perfect implementation, but it makes sense to me and hopefully to you. It's important to note that Clean Architecture is not about directory structures, however, it significantly influences them to some extent.
The project has been organized adhering to several principles: Single Responsibility Principle (SRP), Common Closure Principle (CCP), Dependency Inversion Principle (DIP), and Acyclic Dependency Principle (ADP).
- `internal/domain/model`: This directory contains the entities, also known as the core business rules.
- Other directories within `internal/domain`: These hold the application-specific business rules.
- `internal/infrastructure`: This directory houses the low level details of the system.In this project, components such as the web server, router, and controller are details, obviously. The `repository` is a database access gateway, thus a detail. Any component that interacts with external services, like a Redis server or a third-party API, is also a detail.
Details can depend on application business rules, but not vice versa.
Application business rules can depend on core business rules, but not vice versa.We may need to utilize some external service in application business rules; Dependency Inversion comes to the rescue!
That concludes the overview for now. I believe this implementation is truly opinionated, though your perspective may differ.
## Development
Install [air](https://github.com/cosmtrek/air) for live reloading.
```bash
go install github.com/cosmtrek/air@latest
``````bash
air
```## Test
```bash
make test
```## Build
```bash
make build
```Binaries will be generated inside `PROJECT_ROOT/bin/`
## DB Migration
```bash
make migrate
```## API Documentation
[gin-swagger](https://github.com/swaggo/gin-swagger) is used for API documentation.
To browse the API documentation, open `BASE_URL/swagger/index.html`.
Generate/update docs:
```bash
go install github.com/swaggo/swag/cmd/swag@latestmake docs
```## License
MIT
Made with :heart: by crazyoptimist