Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow connecting from clients with different user id #14

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

codedokode
Copy link

When client and proxy have different user ids, client cannot authenticate itself to the bus. The reason for this is that client sends an auth message with its user id, for example:

AUTH EXTERNAL 31303030\r\n

(this is hex-encoded string "1000"). Proxy passes this message to DBus server vebratim, but the server sees that user id doesn't match proxy's user id and rejects connection.

This can be tested by running a test command like this one:

DBUS_SESSION_BUS_ADDRESS=unix:path=/tmp/proxy.socket dbus-send --session --dest=org.freedesktop.DBus --print-reply /org/freedesktop/DBus org.freedesktop.DBus.ListNames

There will be connection error.

To fix it, I have changed the code so that the proxy can rewrite user's id in AUTH EXTERNAL line with proxy's user id. This way, clients with different user id are able to connect to the bus.

I also had to refactor code a little for better readability. Now the proxy parses and splits auth messages so if it will be necessary, further processing is possible. When --log option is used, auth messages now are printed which should aid debugging issues.

I also have added a CLI argument to allow whitelisting user ids that are able to connect to the proxy.

I have tested my changes using additional Python script which sends different types of messages, including sending messages byte-by-byte and filling messages with garbage to test that proxy doesn't crash. I used a build compiled with ASAN (address sanitizer) to make sure that there are no issues with invalid pointer usage.

I don't know if I can add this script to repository as it is not an automated but manual test.

I have also verified that there are no memory leaks by using heaptrack and connecting/disconnecting to proxy thousand times.

…or better readability, allow whitelisting connecting user ids, improved README
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant