Skip to content

Instantly share code, notes, and snippets.

@morisono
Forked from corlaez/README.md
Created August 18, 2025 04:57
Show Gist options
  • Save morisono/e146830f74fc093091b4196db708602f to your computer and use it in GitHub Desktop.
Save morisono/e146830f74fc093091b4196db708602f to your computer and use it in GitHub Desktop.
Hexagonal Architecture and Modular Implementation

Hexagonal Architecture

Conceptualized by Alistair Cockburn initially under the name "Ports and Adapters".

In a nutshell:

Application Driver -> Primary Adapter -> Primary Port -> Use Case -> Secondary Port -> Secondary Adapter -> External System/Side Effect

image

Use Cases

They define the business rules and they should not depend on code related on how the system communicates with the outside world. Throught the use of Ports and Adapters the Use Cases can be reliably tested and change mainly if the business rules change

Ports

They expose the ways in which the use cases can be reached (primary) or reach to (secondary) to the outside world. They are technology agnostic.

image

Adapters

They deal with with side effects such as: communication outside of the system, random generation, current time, etc.

image

Port and Adapter Implementation

image

Hexagonal Architecture - Modular Implementation

Based on talks by Jakub Nabrdalik such as https://www.youtube.com/watch?v=2vEoL3Irgiw

image

Modules Project Structure

There are multiple ways to implement the ideas of this architecture this is by no means the only one. This implementation is modular an can scale to implement a modular monolith (modulith).

  • In the following example I decided to move customerconsole package outside of the customer module because it required it's own module configuration. However there is nothing stopping that package to remain as a folder inside of com.abc.project.customer

  • Depending on the library choice or code implementation, your primary adapters may be required to be public. Jakub's package-private controllers are possible because he uses the Spring framework. Furthermore, primary adapters apen up an API to an external actor so you may want to think about it as a public API regardless of the access modifier used for the class.

image

Module configuration and it's relationship with mock testing:

https://gist.github.com/corlaez/aa2c1a657438f5c998af9340a3339051

Useful Links:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment