https://github.com/pkgzx/crediya.authentication
Authentication Microservice to crediya system using webflux and clean archichecture
https://github.com/pkgzx/crediya.authentication
authentication authorization microservice reactive-programming webflux
Last synced: 7 months ago
JSON representation
Authentication Microservice to crediya system using webflux and clean archichecture
- Host: GitHub
- URL: https://github.com/pkgzx/crediya.authentication
- Owner: pkgzx
- License: gpl-2.0
- Created: 2025-08-24T02:38:07.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2025-08-26T02:14:24.000Z (7 months ago)
- Last Synced: 2025-08-26T04:20:29.035Z (7 months ago)
- Topics: authentication, authorization, microservice, reactive-programming, webflux
- Language: Java
- Homepage:
- Size: 157 KB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Proyecto Base Implementando Clean Architecture
## Antes de Iniciar
Empezaremos por explicar los diferentes componentes del proyectos y partiremos de los componentes externos, continuando con los componentes core de negocio (dominio) y por último el inicio y configuración de la aplicación.
Lee el artículo [Clean Architecture — Aislando los detalles](https://medium.com/bancolombia-tech/clean-architecture-aislando-los-detalles-4f9530f35d7a)
# Arquitectura

## Domain
Es el módulo más interno de la arquitectura, pertenece a la capa del dominio y encapsula la lógica y reglas del negocio mediante modelos y entidades del dominio.
## Usecases
Este módulo gradle perteneciente a la capa del dominio, implementa los casos de uso del sistema, define lógica de aplicación y reacciona a las invocaciones desde el módulo de entry points, orquestando los flujos hacia el módulo de entities.
## Infrastructure
### Helpers
En el apartado de helpers tendremos utilidades generales para los Driven Adapters y Entry Points.
Estas utilidades no están arraigadas a objetos concretos, se realiza el uso de generics para modelar comportamientos
genéricos de los diferentes objetos de persistencia que puedan existir, este tipo de implementaciones se realizan
basadas en el patrón de diseño [Unit of Work y Repository](https://medium.com/@krzychukosobudzki/repository-design-pattern-bc490b256006)
Estas clases no puede existir solas y debe heredarse su compartimiento en los **Driven Adapters**
### Driven Adapters
Los driven adapter representan implementaciones externas a nuestro sistema, como lo son conexiones a servicios rest,
soap, bases de datos, lectura de archivos planos, y en concreto cualquier origen y fuente de datos con la que debamos
interactuar.
### Entry Points
Los entry points representan los puntos de entrada de la aplicación o el inicio de los flujos de negocio.
## Application
Este módulo es el más externo de la arquitectura, es el encargado de ensamblar los distintos módulos, resolver las dependencias y crear los beans de los casos de use (UseCases) de forma automática, inyectando en éstos instancias concretas de las dependencias declaradas. Además inicia la aplicación (es el único módulo del proyecto donde encontraremos la función “public static void main(String[] args)”.
**Los beans de los casos de uso se disponibilizan automaticamente gracias a un '@ComponentScan' ubicado en esta capa.**