D-Bus Mojo Connection Service in Chrome is a D-Bus service that helps to bootstrap CrOS services' Mojo connection.
D-Bus Mojo Connection Service lives in //chrome/browser/chromeos/dbus/mojo_connection_service_provider.h.
Follow the example of CrOS Sensors' changelist.
- Add a method name in both CrOS platform and Chrome.
(Recommend:
platform2/system_api
) - Add the busconfig policy in MojoConnectionService.conf.
- Upon a D-Bus request coming from the CrOS service, pass one endpoint of the generated Mojo pipe to the component in Chrome that needs a Mojo channel to the CrOS service. Ex: RegisterServer in CrOS Sensors' usage.
- Respond to the D-Bus request with the other endpoint of the generated Mojo pipe. (Recommend: use the helper function SendResponse)
The Mojo pipe can also be generated in the CrOS process, and pass the endpoint of it as the D-Bus argument to the service provider, instead of allowing Chrome to generate the pipe.
- Add the busconfig policy in MojoConnectionService.conf.
And that’s it. The method name and the logic in the service provider can be reused.
UID filtering should be used to ensure only the needed processes are calling the specific D-Bus methods, as processes/applications calling D-Bus APIs are trusted (written and reviewed by Chromium/CrOS teams) and should have a well-known UID to be filtered.
UID filtering: Define access permission for each UID in MojoConnectionService.conf. Only the processes run under the specific UIDs can send respective D-Bus requests to the service provider.
Arguments/tokens in D-Bus methods are still available if needed, which should be enough for multi-login situations and handling failures. The arguments can also be used to determine if Chromium should accept the request, and which Mojo interface should be used to establish the Mojo channel.