RPC Implementation Guidelines¶
This page specifies the expected behaviour of RPCs for an implementation of the Device Manager.
Unimplemented features¶
If a feature present in the Device Management Interface API, as described in .proto files, is not implemented by the
Device Manager component for a particular device or set of devices, it is required that the component returns a
gRPC UNIMPLEMENTED (12)
error code for that API. More details on the gRPC codes can be found in
the gRPC specification.
The response for a certain API can change depending on the state of underlying device(s). As an example,
a bare minimum device with no software installed on it that has just BMC might support only image management APIs but
not events and metrics, returning UNIMPLEMENTED
for these.
Once a fully fledged software is installed on the device through BMC then the RPC responses for events and metrics will contain the elements that the device supports through a more complete protocol and set of calls.
API Specific details¶
Each API of the .protos
contained in the protos directory has his set of specific elements that
need to be taken into account, such as how to generate events and handle different states of operations.
Please refer to each of those files.
Errors returned in the response messages¶
Each of the response messages of the RPCs have a field called status
which says if there is an application level error in execution of the RPC or not.
When the status
field indicates that there is an error; the reason
field would give more information about the error.
There is also another field in the response messages called reason_detail
which can carry a free form, vendor specific string describing the error. It is recommended that upstream components/users of the DMI interface do not really interpret/parse this field, but rather use it for display purposes to the end user or use it for logging the error.