You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Micro ADR-32 now allows optional metadata to be specified on the the service and on endpoints. The metadata is simply Record<string,string>.
Note that schema report also includes any metadata associated with the endpoint.
The cross-client test has been updated (on the dev branch) if you are using it, it will flag if metadata is not specified in your test service.
Client authors please update with your progress. If you open issues in your own repositories as a result of this request, please link them to this one by pasting the issue URL in a comment or main issue description.
The text was updated successfully, but these errors were encountered:
Whilst playing with the metadata in the Java impl I bumped into the following:
I wanted to change/add metadata after the client was created. Seemed to be a nice way to have dynamic info available of each service from the monitor. Without making endpoints, and calling those based on the results of a discovery. Similar like endpoints in stats.
This doesn't work because the ServiceRespsonse gets serialized at the Service constructor with the metadata originally provided at the builder. Atleast, the ones for ping and info do.
For the stats context the story is different. When passing an empty map to the builder it's nulled in the Service constructor, losing the original pointer. But by adding any (garbage) value to the map before building, the Service keeps the pointer to the original map (which then actually comes from the reference of the cached pingServiceRespsonse before it is seriaziled). This way it is possible to expose some dynamic metadata using just the monitor client in the stats context. But this seems wrong?
Somehow it feels like it makes sense to have ping and info static, where stats is like endpoints. But in that case the isEmpty() should be removed to make its behaviour consistent? Or am I down a wrong path?
The metadata describes the service instance it’s not for dynamic use.
We are clarifying that in the spec and will enforce it in the clients.
Additionally we are adding a feature that allows you to build way to create an endpoint that expose your own metadata and that can be queried same as info in a 1;n manner.
Overview
Micro ADR-32 now allows optional
metadata
to be specified on the the service and on endpoints. The metadata is simplyRecord<string,string>
.Note that schema report also includes any
metadata
associated with the endpoint.The cross-client test has been updated (on the dev branch) if you are using it, it will flag if metadata is not specified in your test service.
Clients and Tools
Other Tasks
Implemented
Client authors please update with your progress. If you open issues in your own repositories as a result of this request, please link them to this one by pasting the issue URL in a comment or main issue description.
The text was updated successfully, but these errors were encountered: