e8de468b0b
* (executor-api) Make executor API talk GRPC The executor's REST API was very fragile and annoying to work with, lacking even basic type safety. Migrate to use GRPC instead. GRPC is a bit of a pain with how verbose it is, but that is probably a lesser evil. This is a fairly straightforward change, but it's also large so a solid round of testing is needed... The change set breaks out the GrpcStubPool previously residing in the QueryService, and makes it available to all clients. ServiceId.name was also renamed to avoid the very dangerous clash with Enum.name(). The boilerplate needed for grpc was also extracted into a common gradle file for inclusion into the appropriate build.gradle-files. |
||
---|---|---|
.. | ||
assistant-api | ||
executor-api | ||
index-api | ||
process-mqapi | ||
query-api | ||
readme.md |
Clients
Core Services
These are clients for the core services, along with what models are necessary for speaking to them. They each implement the abstract client classes from service-client.
All that is necessary is to @Inject
them into the constructor and then
requests can be sent.
Note: If you are looking for the public API, it's handled by the api service in services-application/api-service.
MQ-API Process API
process-mqapi defines requests and inboxes for the message queue based API used for interacting with processes.
See libraries/message-queue and services-application/control-service.