I wrote a simple python program to play and pause banshee music player.
While its working on my own machine, I have trouble doing it to a remote computer, connected to the same router (LAN).
I edited the session.conf of the remote machine, to add this line:
<listen>tcp:host=localhost,port=12434</listen>
and here is my program:
import dbus
bus_obj=dbus.bus.BusConnection("tcp:host=localhost,port=12434")
proxy_object=bus_obj.get_object('org.bansheeproject.Banshee',
'/org/bansheeproject/Banshee/PlayerEngine')
playerengine_iface=dbus.Interface(proxy_object,
dbus_interface='org.bansheeproject.Banshee.PlayerEngine')
var=0
while (var!="3"):
var=raw_input("\nPress\n1 to play\n2 to pause\n3 to exit\n")
if var=="1":
print "playing..."
playerengine_iface.Play()
elif var=="2":
print "pausing"
playerengine_iface.Pause()
This is what i get when i try to execute it
Traceback (most recent call last):
File "dbus3.py", line 4, in <module>
bus_obj=dbus.bus.BusConnection("tcp:host=localhost,port=12434")
File "/usr/lib/python2.7/dist-packages/dbus/bus.py", line 125, in __new__
bus = cls._new_for_bus(address_or_type, mainloop=mainloop)
dbus.exceptions.DBusException: org.freedesktop.DBus.Error.NoServer: Failed to connect to socket "localhost:12434" Connection refused
What am I doing wrong here?
should i edit /usr/lib/python2.7/dist-packages/dbus/bus.py
UPDATE:
ok, here is the deal
when i add
<listen>tcp:host=192.168.1.7,port=12434</listen>
to to /etc/dbus-1/session.conf, then reboot, hoping it would start listening on reboot,
It never boots. It gets stuck on loading screen and occasionally, a black screen with the following text flashes:
Pulseaudio Configured For Per-user Sessions Saned Disabled;edit/etc/default/saned
so, when i go ctrl+alt+f1 , change session.conf to original state and reboot, it boots properly.
Whats all that about?
How can I make dbus daemon listen for tcp connections, without encountering problems?
I recently needed to set this up, and discovered that the trick is: order matters for the
<listen>elements insession.conf. You should make sure the TCP element occurs first. Bizarre, I know, but true, at least for my case. (I see exactly the same black screen behavior if I reverse the order and put the UNIX socket<listen>element first.)Also, prepending the TCP
<listen>tag is necessary, but not sufficient. To make remote D-Bus connections via TCP work, you need to do three things:Add a
<listen>tag above the UNIX one, similar to this:Add a line (right below the
<listen>tags is fine) that says:Add another line below these that says:
The
<auth>tag should be added in addition to any other<auth>tags that may be contained in yoursession.conf. In summary, yoursession.confshould contain a snippet that looks like this:After doing these three things, you should be able to connect to the session bus remotely. Here’s how it looks when specifying a remote connection in D-Feet:
Note that, if you want to connect to the system bus, too, you need to make similar changes to
/etc/dbus-1/system.conf, but specify a different TCP port, for example 55557. (Oddly enough, the element order appears not to matter in this case.)The only weird behavior I’ve noticed in this configuration is that running Desktop apps with
sudo(e.g.,sudo gvim) tends to generate errors or fail outright saying “No D-BUS daemon running”. But this is something I need to do so rarely that it hardly matters.If you want to send to a remote machine using
dbus-send, you need to setDBUS_SESSION_BUS_ADDRESSaccordingly, e.g., to something like:This works even if the bus you want to send to is actually the system bus of the remote machine, as long as the setting matches the TCP
<listen>tag in/etc/dbus-1/system.confon the target. (Thanks to Martin Vidner for this tip. Until I stumbled across his answer to this question, I didn’t believedbus-sendsupported remote operation.)UPDATE: If you’re using systemd (and want to access the system bus), you might also need to add a line saying
ListenStream=55557to/lib/systemd/system/dbus.socket, like so:UPDATE2: Thanks to @altagir for pointing out that recent versions of D-Bus will enable AppArmor mediation on systems where it’s available, so you may also need to add
<apparmor mode="disabled"/>tosession.conf/system.conffor these instructions to work.