Still trying to wrap my head around microservice architecture since I'm used to monolithic approach
Suppose we try to build a extremely simplified Uber booking system, to simplify things we let's say we have 3 services and a gateway api for the client:
Notification and we have the following workflow
When creating new booking:
Let's say all messaging is done through http call rather than messaging bus like kafka to keep things simple
So in this case, I thought that
Booking service can do the checking for existing booking. But then who should be getting the list of available drivers and notification? I'm thinking of doing it on the gateway level but then now logic is kind of splitted in two places:
Gateway- get list of available drivers + send notifications
Booking- check for existing booking
And I'm pretty sure gateway is not the right place to do it but I feel like if we are doing it in the
Booking service, it's becoming tightly coupled?
To make it more complicated, what happens if we have another project that wants to reuse the booking system but with its own business logic on top of it? That's why I thought of doing it in the gateway level so the new project gateway can have its own business logic separate from the existing one..
Another way of doing it I suppose is to have projects own booking service that will talk to the core booking service but not sure what's the best approach here :-)