Notes

This repo is a part of this article https://arisharyanto.medium.com/eventsourcing-and-cqrs-architecture-using-golang-grpc-nats-and-elasticsearch-c3ca50e425c2

Install All Dependencies

untuk menginstall semua library yang dibutuhkan cukup masuk ke foldernya dan tulis ini dicommand line kamu

go get -v ./...

Database Setup

untuk merubah database connection silahkan buka file database/connection.go pada fungsi init()

conn, err := gorm.Open("mysql", "username-kamu@(localhost)/db-kamu?charset=utf8&parseTime=True&loc=Local")

Run service yang diperlukan

Buka terminal untuk menjalankan service nats. service ini yang akan dipakai oleh service push notif nantinya jalankan elasticsearch ini digunakan untuk pengambilan data (query)

$ nats-streaming-server
$ elasticsearch

Run service

Buka 5 terminal ketikan masing-masing terminal

Untuk run service server

bagian ini untuk menerima request dari services client menggunakan grpc

$ cd services
$ go run main.go
Untuk run service client

bagian ini untuk mengirim request ke services server menggunakan grpc

$ cd client
$ go run main.go
Untuk run service create deposit

bagian ini untuk kita mengcreate deposit yang masuk yang dilisten dari nats streaming

$ cd deposit-create
$ go run main.go
Untuk run service approve deposit

bagian ini untuk kita mengapprove deposit yang sudah ada yang dilisten dari nats streaming

$ cd deposit-approve
$ go run main.go
Untuk run Log

bagian ini untuk melihat log proses dari services ketika ada request dari client

$ cd pushnotif
$ go run main.go

Untuk mengcompile protobuff

$ protoc -I proto/ proto/*.proto --go_out=plugins=grpc:proto