Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ivanpaulovich/event-sourcing-jambo
An Hexagonal Architecture with DDD + Aggregates + Event Sourcing using .NET Core, Kafka e MongoDB (Blog Engine)
https://github.com/ivanpaulovich/event-sourcing-jambo
aggregate bearer-authentication cqrs cqrs-es ddd ddd-architecture domain-driven-design dotnet-core event-driven event-sourcing hexagonal-architecture kafka microservice microservices mongodb optimistic-updates service-bus solid solid-principles webapi
Last synced: about 1 month ago
JSON representation
An Hexagonal Architecture with DDD + Aggregates + Event Sourcing using .NET Core, Kafka e MongoDB (Blog Engine)
- Host: GitHub
- URL: https://github.com/ivanpaulovich/event-sourcing-jambo
- Owner: ivanpaulovich
- License: apache-2.0
- Created: 2016-11-01T15:51:47.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2018-03-23T22:10:46.000Z (almost 7 years ago)
- Last Synced: 2024-12-07T08:41:35.653Z (about 2 months ago)
- Topics: aggregate, bearer-authentication, cqrs, cqrs-es, ddd, ddd-architecture, domain-driven-design, dotnet-core, event-driven, event-sourcing, hexagonal-architecture, kafka, microservice, microservices, mongodb, optimistic-updates, service-bus, solid, solid-principles, webapi
- Language: C#
- Homepage: http://paulovich.net/jambo/
- Size: 76.6 MB
- Stars: 189
- Watchers: 29
- Forks: 68
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-list-microservice - event-sourcing-jambo
README
A solution based on a Event-Driven architecture with DDD and CQRS. The solution contains the following applications.
* A Producer Web API which receives Commands to produce Domain Events. This one also receives Queries and returns JSON.
* A Consumer Console App that reads the Event Stream and do a projection to a MongoDB database.
* A Web API for authentication and JWT generation.[Checkout the Source Code on GitHub](https://github.com/ivanpaulovich/jambo)
#### Requirements
* [Visual Studio 2017 + Update 3](https://www.visualstudio.com/en-us/news/releasenotes/vs2017-relnotes)
* [.NET CORE SDK 2.0](https://www.microsoft.com/net/download/core)
* [Docker](https://docs.docker.com/docker-for-windows/install/)#### Environment setup
*If you already have valid connections for Kafka and MongoDB you could skip this step and go to Running the applications step.*
* Run the `./up-kafka-mongodb.sh` bash script to run Kafka and MongoDB as Docker Containers. Please wait until the ~800mb download to be complete.
```
$ ./up-kafka-mongodb.sh
Pulling mongodb (mongo:latest)...
latest: Pulling from library/mongo
Digest: sha256:2c55bcc870c269771aeade05fc3dd3657800540e0a48755876a1dc70db1e76d9
Status: Downloaded newer image for mongo:latest
Pulling kafka (spotify/kafka:latest)...
latest: Pulling from spotify/kafka
Digest: sha256:cf8f8f760b48a07fb99df24fab8201ec8b647634751e842b67103a25a388981b
Status: Downloaded newer image for spotify/kafka:latest
Creating setup_mongodb_1 ...
Creating setup_kafka_1 ...
Creating setup_mongodb_1
Creating setup_mongodb_1 ... done
```
* Check if the data layer is ready with the following commands:```
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mongo latest d22888af0ce0 17 hours ago 361MB
spotify/kafka latest a9e0a5b8b15e 11 months ago 443MB
``````
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
32452776153f spotify/kafka "supervisord -n" 2 days ago Up 2 days 0.0.0.0:2181->2181/tcp, 0.0.0.0:9092->9092/tcp setup_kafka_1
ba28cf144478 mongo "docker-entrypoint..." 2 days ago Up 2 days 0.0.0.0:27017->27017/tcp setup_mongodb_1
```If Kafka is running well it will be working with the `10.0.75.1:9092` connection string.
if MongoDB is running well it will be working at `mongodb://10.0.75.1:27017` connection string.## Running the applications
You have two options to run the applications, one is by opening with Visual Studio 2017 and the other is by running dotnet core commands.
### Option 1 - Running with Visual Studio 2017
Open the three solutions on three Visual Studios them run the following projects.
* `Jambo.Auth.UI`.
* `Jambo.Consumer.UI`.
* `Jambo.Producer.UI`.### Option 2 - Running with dotnet commands
#### How to run the Bearer Authencation API
1. Run the command `dotnet run` at `source\Auth\Jambo.Auth.UI` folder.
```
$ dotnet run
Using launch settings from C:\git\jambo\source\Auth\Jambo.Auth.UI\Properties\launchSettings.json...
Hosting environment: Development
Content root path: C:\git\jambo\source\Auth\Jambo.Auth.UI
Now listening on: http://localhost:16024
Application started. Press Ctrl+C to shut down.
```
2. Navigate to the Swagger UI at (eg. http://localhost:16024/swagger).
3. Post the following credentials:
```
{
"username": "ivanpaulovich",
"password": "mysecret"
}
```
4. __Store the Bearer Token__ because you will need the token value to log on Producer API.
```
{
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiJhYzA4MmE3OS1lMWY3LTQ4MTktYmU1Mi1hOTQwMTBkM2VjZTciLCJzdWIiOiJzdHJpbmciLCJleHAiOjE1MTI0Nzg5ODgsImlzcyI6Imh0dHA6Ly9teWFjY291bnRhcGkiLCJhdWQiOiJodHRwOi8vbXlhY2NvdW50YXBpIn0.9YKGmKaptLBDcExHhPOQ3_j9TsdbkcRf8ZtvIkdq8Go",
"expiration": "2017-12-05T13:03:08Z"
}
```
#### How to run the Consumer API1. Run the command `dotnet run` at `source\Consumer\Jambo.Consumer.UI` folder
```
$ dotnet run
11/5/2017 11:17:20 AM Waiting for events..
11/5/2017 11:18:20 AM Waiting for events..
11/5/2017 11:19:20 AM Waiting for events..
11/5/2017 11:20:20 AM Waiting for events..
11/5/2017 11:21:20 AM Waiting for events..
11/5/2017 11:22:20 AM Waiting for events..
```3. __Attention:__ keep the Console App running for events processing.
#### How to run the Producer API
![Authorization](https://github.com/ivanpaulovich/jambo/blob/master/Producer.png)
1. Run the command `dotnet run` at the `source\Producer\Jambo.Producer.UI` folder.
```
$ dotnet run
Using launch settings from C:\git\jambo\source\Producer\Jambo.Producer.UI\Properties\launchSettings.json...
Hosting environment: Development
Content root path: C:\git\jambo\source\Producer\Jambo.Producer.UI
Now listening on: http://localhost:16959
Application started. Press Ctrl+C to shut down.
```2. Navigate to the Swagger UI (eg. http://localhost:14398/swagger).