Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codelytv/go-hexagonal_http_api-course
Ejemplos del curso de API HTTP en Go aplicando Arquitectura Hexagonal
https://github.com/codelytv/go-hexagonal_http_api-course
codelytv ddd domain-driven-design gin go golang hexagonal-architecture
Last synced: 4 days ago
JSON representation
Ejemplos del curso de API HTTP en Go aplicando Arquitectura Hexagonal
- Host: GitHub
- URL: https://github.com/codelytv/go-hexagonal_http_api-course
- Owner: CodelyTV
- Created: 2020-10-09T15:32:56.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-08-17T17:38:50.000Z (5 months ago)
- Last Synced: 2025-01-18T07:06:26.147Z (4 days ago)
- Topics: codelytv, ddd, domain-driven-design, gin, go, golang, hexagonal-architecture
- Language: Go
- Homepage: https://pro.codely.tv/library/api-go-hexagonal
- Size: 58.6 KB
- Stars: 138
- Watchers: 10
- Forks: 64
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## CodelyTV - Go HTTP API - Hexagonal Architecture
This repository contains the code examples used on the CodelyTV course.
### Requirements
- Go v1.15+
- MySQL (see below).### Contents
This project has been designed as a single Go module with multiple applications.
Each folder contains a completely functional application (binary) that can be executed isolated.Each folder corresponds to one of the course lessons / videos:
1. [`01-01-your-first-http-endpoint`](./01-01-your-first-http-endpoint) - Nuestro primer endpoint HTTP en Go
1. [`01-02-using-gin`](./01-02-using-gin) - Usando Gin: nuestro primer framework
1. [`01-03-architectured-healthcheck`](./01-03-architectured-healthcheck) - Arquitecturando nuestro health check
1. [`02-01-post-course-endpoint`](./02-01-post-course-endpoint) - Implementando el endpoint de creación de curso
1. [`02-02-repository-injection`](./02-02-repository-injection) - Inyectando nuestro repositorio
1. [`02-03-controller-test`](./02-03-controller-test) - Testeando nuestro endpoint
1. [`02-04-domain-validations`](./02-04-domain-validations) - Añadiendo validaciones a nuestro dominio
1. [`03-01-mysql-repository-implementation`](./03-01-mysql-repository-implementation) - Implementando nuestro repositorio para MySQL
1. [`03-02-repository-test`](./03-02-repository-test) - Testeando nuestro repositorio
1. [`04-01-application-service`](./04-01-application-service) - Refactorizando el endpoint para extraer el Application Service
1. [`04-02-application-service-test`](./04-02-application-service-test) - Testeando el Application Service
1. [`04-03-command-bus`](./04-03-command-bus) - Unificando nuestros casos de uso: Command Bus
1. [`05-01-graceful-shutdown`](./05-01-graceful-shutdown) - Graceful shutdown
1. [`05-02-timeouts`](./05-02-timeouts) - Timeouts en operaciones asíncronas: repositorio
1. [`06-01-http-middlewares`](./06-01-http-middlewares) - Usando middlewares HTTP en Go
1. [`06-02-time-parse-in-go`](./06-02-time-parse-in-go) - El secreto mejor guardado de Go y sus fechas
1. [`06-03-gin-middlewares`](./06-03-gin-middlewares) - Implementando el middleware de recuperación de errores en Gin
1. [`07-01-publishing-domain-events`](./07-01-publishing-domain-events) - Publicando eventos de curso creado
1. [`07-02-domain-events-subscriber`](./07-02-domain-events-subscriber) - Implementando nuestro suscriptor de eventos
1. [`07-03-event-bus-implementation`](./07-03-event-bus-implementation) - Implementando el Event Bus
1. [`08-01-reading-env-variables`](./08-01-reading-env-variables) - Leyendo configuración de variables de entorno
1. [`08-02-build-and-deploy`](./08-02-build-and-deploy) - Build, despliegue y ¡a producción!
1. [`08-03-debugging`](./08-03-debugging) - Generando la imagen de Docker y depurando errores### Usage
To execute the application from any lesson, just run:
```sh
export COURSE_LESSON=02-04-domain-validations; go run $COURSE_LESSON/cmd/api/main.go
```Replacing `COURSE_LESSON` value by any of the available ones.
#### Simple examples
Some lessons only contain a single `main.go` file with a few lines of code.
To run one of those lessons, just run:```sh
export COURSE_LESSON=01-01-your-first-http-endpoint; go run $COURSE_LESSON/main.go
```#### MySQL & Docker
From `02-01-post-course-endpoint` on, the application on each directory relies
on a MySQL database. So, to simplify its execution, we've added a
`docker-compose.yaml` file with a MySQL container already set up.To run it, just execute:
```sh
docker-compose up -d
```You can also use your own MySQL instance. Note that those applications
expects a MySQL instance to be available on `localhost:3306`,
identified by `codely:codely` and with a `codely` database.To set up your database, you can execute the `schema.sql` file
present on the `sql` directory. It's automatically loaded if
you use the provided `docker-compose.yaml` file.#### Tests
To execute all tests, just run:
```sh
go test ./...
```To execute only the tests present in one of the lessons, run:
```sh
go test ./02-04-domain-validations/...
```