A Interprocess Hook for messagebased Services that generates ASP.NET Controllers for Swagger
So you have Services and in the cool and fancy decoupled world they all communicate async with Messages.
How can you develop this kind of Service ? Do you generate Messages in NServiceBus, MSMQ or RabbitMQ and hope that you didnt mess something up and susbcried to the Prod Queue ? What about out of order Delivery ? And Error Queues ? Whatever i really dont like this way off Developing. Having workaround over workaround and messy configuration on Developer Machine level (oO dont check it in or you get messages from somebody else) All the advantages of Message Queuing getting disadvantages while developing - or QA Testing.
A different way is to have HTTP Endpoints for each Operation. So you are forced to use ASP.Net MVC! (I am from the C# world so there only exists ASP.Net as WebApplication Framework for me) So you write operation after operation and also some Controller Plumbing Code.
Okay HTTP Endpoint - done, but its Productive Code which could cause issues and is also useless for Prod as it only exists for QA and Development. So you should take care of HTTPS because nobody except the QA should trigger the service Blackbox to do something. Which brings authentification and ....
It just getting more complicated or there is just more boilerplate.
- develop a service as (windows)service because it does not need HTTP endpoints
- hit refresh on your local deployed Instance of APILast.
- see the updated SWAGGER Contract of your Operation
- use SOAP UI (or product of your choice to genrate HTTP Requests) to create some message
- get a Response
- run assertions
- APILast will hook into the service process
- inject some required libs
- establish Interprocess Communication through named Pipes
- Export types and namespaces of service
- load required Assembies on APILast
- generate Controller Classes from Types and add to new assembly
- register the new Controllers
- ApiExplorer will hopefully pickup the new Controllers
- request to controller will modelBind the concrete class from Service
- this Model instance is pushed to the NamedPipe
- Service Process recieves the Message from NamedPipe
- resolve the MessageHandler from Windsor
- invoke the MessageHandler
- if exists push the MessageHandler response to the NamedPipe
- controller is waiting for this
- render response
- done