Skip to content

Commit

Permalink
warpinator-launch.py: (bwrap) Deal with systems that use /tmp for
Browse files Browse the repository at this point in the history
their dbus session bus address.

Get the correct address via Gio and bind its path over warpinator's
new /tmp folder. Do the same for AT_SPI_BUS while we're at it.

Fixes #203

ref: #206
  • Loading branch information
mtwebster committed Feb 5, 2024
1 parent 1aeae3a commit fa06318
Showing 1 changed file with 35 additions and 0 deletions.
35 changes: 35 additions & 0 deletions src/warpinator-launch.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import sys
import os
import re
import argparse
import subprocess
from pathlib import Path
Expand Down Expand Up @@ -133,6 +134,38 @@
except KeyError:
rundir = "/run/user/%d" % os.getuid()

def path_from_bus_addr(addr):
return re.search(r"unix:(?:path|abstract)=(\/.+?)(?:,|$)", addr).group(1)

try:
session_socket_addr = Gio.dbus_address_get_for_bus_sync(Gio.BusType.SESSION, None)
if session_socket_addr is None:
session_socket_addr = os.environ.get("DBUS_SESSION_BUS_ADDRESS")

session_path = path_from_bus_addr(session_socket_addr)
except Exception as e:
print("Could not retrieve the session dbus address: %s" % e)
sys.exit(1)

try:
conn = Gio.bus_get_sync(Gio.BusType.SESSION, None)
res = conn.call_sync("org.a11y.Bus",
"/org/a11y/bus",
"org.a11y.Bus",
"GetAddress",
None, None,
Gio.DBusCallFlags.NONE,
-1, None)

if res is not None:
a11y_socket_addr = res[0]
else:
a11y_socket_addr = os.environ.get("AT_SPI_BUS_ADDRESS")

a11y_path = path_from_bus_addr(a11y_socket_addr)
except Exception as e:
print("Could not retrieve the AT_SPI bus address, accessibility features may not work: %s" % e)

launch_args = []

launch_args += ["/usr/bin/bwrap"]
Expand All @@ -141,6 +174,8 @@
launch_args += ["--bind", rundir + "/dconf", rundir + "/dconf"]
launch_args += ["--bind-try", rundir + "/gvfsd", rundir + "/gvfsd"]
launch_args += ["--tmpfs", "/tmp"]
launch_args += ["--ro-bind", session_path, session_path]
launch_args += ["--ro-bind-try", a11y_path, a11y_path]
# The following two items aren't necessary if org.freedesktop.FileManager1 works properly - in that case,
# the file manager is launched outside of the sandbox. If that fails, and the file manager isn't already running,
# it will spawn inside the sandbox and be restricted the same as Warpinator.
Expand Down

0 comments on commit fa06318

Please sign in to comment.